前处理系列,结果整理。伽马校正,高斯差分滤波,对比度均衡,特征比对

本文主要是介绍前处理系列,结果整理。伽马校正,高斯差分滤波,对比度均衡,特征比对,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://blog.sina.com.cn/s/blog_48e673350100vcg5.html

自己调研之后,写的伽马校正:

TestImgNum =1  ;00 335
str = strcat('.\',num2str(TestImgNum),'.bmp');
L_FaceImg = imread(str);
figure,imshow(uint8(L_FaceImg));
temp = double(L_FaceImg);
temp = temp./256;
gamma = 1/2.2;
 y = imadjust(temp,[0; 1],[0; 1],gamma)
% y=gamma(temp);%实现gamma校正
 y = gamma_filter(temp,gamma);
y = y.*256;
figure,imshow(uint8(y));

 

原理不明,只是会用而已。具体过程就是归一化人脸图像到[0,1]之间之后,运用imadjust函数,将其根据伽马值gamma转换到另一个范围在[0,1]的空间中去,然后乘以255加以倍数,输出即得伽马校正的结果。

 

xb调研完之后,写的代码:

L_FaceImg=double(L_FaceImg_org);
%L_FaceImg=L_FaceImg.^0.2;
gama=2;
p=255/255^(gama);p=(1/p)^(1/gama);
for i=1:imrow
    for j=1:imcol
        %for l=1:k
       % r(i,j,l)=floor(p*double(I(i,j,l))^(1/gama));
        L_FaceImg_gmma(i,j)=floor(p*L_FaceImg(i,j)^(1/gama));
        %end
    end
end
完全是原理性的东西。

高斯查分滤波,在网上查DoG查了好久,最后终于终于在pudn上面找到相关c代码,结果被xb两句话解决了……具体见下面:

low= imfilter(L_FaceImg_gmma,fspecial('gaussian',7,1),'same','replicate');
lowlow=imfilter(L_FaceImg_gmma,fspecial('gaussian',9,2),'same','replicate');

Resimage=low-lowlow;
其中L_FaceImg_gmma是经过伽马光线校正之后的图像,分别作滤波,之后差分相减,就得到高斯差分滤波的结果了……囧。明天去pudn上查查代码,看看是不是这样写的……

下面是fspecial函数的使用样例,写上来原因是蛮喜欢subplot函数,哇咔咔~

  I = imread('cameraman.tif');
       subplot(2,2,1);imshow(I);title('Original Image');
       H = fspecial('motion',20,45);
       MotionBlur = imfilter(I,H,'replicate');%replicate表示Input array values outside the bounds of the array  are assumed to equal the nearest array border value 输入值自动对齐到最近邻
       subplot(2,2,2);imshow(MotionBlur);title('Motion Blurred Image');
       H = fspecial('disk',10);
       blurred = imfilter(I,H,'replicate');
       subplot(2,2,3);imshow(blurred);title('Blurred Image');
       H = fspecial('unsharp');
       sharpened = imfilter(I,H,'replicate');
       subplot(2,2,4);imshow(sharpened);title('Sharpened Image');

 

对比均衡化还没搞明白,先把代码贴出来,供慢慢研究……

%Contrast Equalization.
a=0.1;
for i=1:imrow
       for j=1:imcol
       Resimage_temp(i,j)=(abs(Resimage(i,j)))^a;   
    end
end
 mu=mean(mean(Resimage_temp));
 Resimage=Resimage./(mu^(1/a));

tt=10;
for i=1:imrow
       for j=1:imcol
       Resimage_temp(i,j)=min(tt,(abs(Resimage(i,j)))^a);   
    end
end
mu=mean(mean(Resimage_temp));
Resimage=Resimage./(mu^(1/a));
Resimage=tt*tanh(Resimage/tt);
Resimage_max=max(max(Resimage));
Resimage_min=min(min(Resimage));
 for i=1:imrow
       for j=1:imcol
       Resimage(i,j)=(Resimage(i,j)-Resimage_min)/(Resimage_max-Resimage_min)*255;   
    end
 end
% imshow(uint8(Resimage));
 
 %提取LBP模板
% [result , Lbpface] = lbp(L_FaceImg);
 %figure,imshow(uint8(Lbpface));
L_FaceImg_bandpass=uint8(Resimage);

    TestImage = strcat('.\M00模糊脸_bandpass\',num2str(ii),'.bmp');
    imwrite(uint8(L_FaceImg_bandpass),TestImage,'bmp');
    figure,imshow(uint8(blurred));
end

 

晕死,就俩公式:前处理系列,结果整理。伽马校正,高斯差分滤波,还有什么呢,特征比对

其中a = 0.1,t= 10.看着挺简单,我咋就做不出来呢?

真是的啊我

这篇关于前处理系列,结果整理。伽马校正,高斯差分滤波,对比度均衡,特征比对的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/770152

相关文章

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

Python处理大量Excel文件的十个技巧分享

《Python处理大量Excel文件的十个技巧分享》每天被大量Excel文件折磨的你看过来!这是一份Python程序员整理的实用技巧,不说废话,直接上干货,文章通过代码示例讲解的非常详细,需要的朋友可... 目录一、批量读取多个Excel文件二、选择性读取工作表和列三、自动调整格式和样式四、智能数据清洗五、

SpringBoot如何对密码等敏感信息进行脱敏处理

《SpringBoot如何对密码等敏感信息进行脱敏处理》这篇文章主要为大家详细介绍了SpringBoot对密码等敏感信息进行脱敏处理的几个常用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录​1. 配置文件敏感信息脱敏​​2. 日志脱敏​​3. API响应脱敏​​4. 其他注意事项​​总结