百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

图像颜色特征提取

ztj100 2024-11-21 00:30 12 浏览 0 评论

图像的颜色一直是研究和关注的热点,也是特征工程不可或缺的feature,今天就简单介绍一种非常基础的颜色的rgb特征。


  1. 目的:

我们希望图片的rgb特征转化成一个可衡量的指标,例如人的身高、体重 这样的指标173cm, 60kg,用于后续工作。那么怎么转化呢?首先我们需要定一个标准,这里是从图片中提取了8种颜色(红、橙、黄....)用来反映图片的RGB指标, 就好比表述一个人的健康指标,可能回身高、体重、血常规等等。


2.颜色提取:

首先我们可以在网上找到hex颜色和对应名称的网页,如下:


通过html解析,我们就可以获得hex颜色和颜色名称的对应关系,然后再通过hex -> rgb转化就可以得到 rgb和颜色名称,如下表:

    ### 颜色转化方法
    def hex_to_int(s):
    	""" hex to rgb"""
        s = s.lstrip("#")
        return int(s[:2], 16), int(s[2:4], 16), int(s[4:6], 16)


有了对应关系后,我们需要抽提出我们关心的颜色,如红色,黄色等,但问题就是红色可能会有很多种,这时就需要我们队将相近颜色进行合并。

def distance(coord1, coord2):
    """ 相近颜色计算方法 """
    return math.sqrt(sum([(i - j)**2 for i, j in zip(coord1, coord2)]))


我们先来测试一下相近颜色计算方法:

(1)我们比较一下距离: 红色 vs 绿色 距离 是不是 大于 红色 vs 粉色 ? 结果发现红色和粉色更接近,说明我们可以按照这样的方法进行。

distance(colors['red'], colors['green']) # 273.70787347096905
distance(colors['red'], colors['pink']) # 232.76812496559748
print(f"{distance(colors['red'], colors['green']) > distance(colors['red'], colors['pink'])}") ## True


(2)比较一下颜色:就是把每个颜色相近的颜色拿出来,大致检查一下即可,方法如下:

#### 通过相似度算法进行相近颜色合并
all_imgs = []
for color_name in ['red', 'orange', 'yellow', 'green', 'blue', 'purple', 'grey', 'pink']:
    topk = 5
    imgs = []
    closest_names = closest(colors, colors[color_name], topk)
    closest_colors = list(map(colors.get, closest_names))
    
    print(f"{color_name}: {closest_names}")
    for i, (name, rgb) in enumerate(zip(closest_names, closest_colors)):
        img = show_color(rgb, size=100)
        imgs.append(pil2cv_img(img))
    imgs = np.hstack(imgs)
    all_imgs.append(imgs)
all_imgs = np.vstack(all_imgs)

cv2_pilimg(all_imgs)

这样我们就拿到了指标颜色。有了指标颜色,后面的就简单了。我们先那一张图片测试一下颜色提取效果:

这样的很简单的就可以拿到rgb特征了。当然,方法有很多种,这只是其中的一种。

相关推荐

利用navicat将postgresql转为mysql

导航"拿来主义"吃得亏自己动手,丰衣足食...

Navicat的详细教程「偷偷收藏」(navicatlite)

Navicat是一套快速、可靠并价格适宜的数据库管理工具,适用于三种平台:Windows、macOS及Linux。可以用来对本机或远程的MySQL、SQLServer、SQLite、...

Linux系统安装SQL Server数据库(linux安装数据库命令)

一、官方说明...

Navicat推出免费数据库管理软件Premium Lite

IT之家6月26日消息,Navicat推出一款免费的数据库管理开发工具——NavicatPremiumLite,针对入门级用户,支持基础的数据库管理和协同合作功能。▲Navicat...

Docker安装部署Oracle/Sql Server

一、Docker安装Oracle12cOracle简介...

Docker安装MS SQL Server并使用Navicat远程连接

...

Web性能的计算方式与优化方案(二)

通过前面《...

网络入侵检测系统之Suricata(十四)——匹配流程

其实规则的匹配流程和加载流程是强相关的,你如何组织规则那么就会采用该种数据结构去匹配,例如你用radixtree组织海量ip规则,那么匹配的时候也是采用bittest确定前缀节点,然后逐一左右子树...

使用deepseek写一个图片转换代码(deepnode处理图片)

写一个photoshop代码,要求:可以将文件夹里面的图片都处理成CMYK模式。软件版本:photoshop2022,然后生成的代码如下://Photoshop2022CMYK批量转换专业版脚...

AI助力AUTOCAD,生成LSP插件(ai里面cad插件怎么使用)

以下是用AI生成的,用AUTOLISP语言编写的cad插件,分享给大家:一、将单线偏移为双线;;;;;;;;;;;;;;;;;;;;;;单线变双线...

Core Audio音频基础概述(core 音乐)

1、CoreAudioCoreAudio提供了数字音频服务为iOS与OSX,它提供了一系列框架去处理音频....

BlazorUI 组件库——反馈与弹层 (1)

组件是前端的基础。组件库也是前端框架的核心中的重点。组件库中有一个重要的板块:反馈与弹层!反馈与弹层在组件形态上,与Button、Input类等嵌入界面的组件有所不同,通常以层的形式出现。本篇文章...

怎样创建一个Xcode插件(xcode如何新建一个main.c)

译者:@yohunl译者注:原文使用的是xcode6.3.2,我翻译的时候,使用的是xcode7.2.1,经过验证,本部分中说的依然是有效的.在文中你可以学习到一系列的技能,非常值得一看.这些技能不单...

让SSL/TLS协议流行起来:深度解读SSL/TLS实现1

一前言SSL/TLS协议是网络安全通信的重要基石,本系列将简单介绍SSL/TLS协议,主要关注SSL/TLS协议的安全性,特别是SSL规范的正确实现。本系列的文章大体分为3个部分:SSL/TLS协...

社交软件开发6-客户端开发-ios端开发验证登陆部分

欢迎订阅我的头条号:一点热上一节说到,Android客户端的开发,主要是编写了,如何使用Androidstudio如何创建一个Android项目,已经使用gradle来加载第三方库,并且使用了异步...

取消回复欢迎 发表评论: