matlab练习程序(LBP,局部二值模型)
来源:互联网 发布:盈建科三维软件停止 编辑:程序博客网 时间:2024/05/15 14:13
一种图像特征的提取算法。
算法步骤:
1.用3*3的模板对图像每个像素进行处理,比较当前像素和周围像素的大小,将大于当前像素的置1,小于的置0。
2.对这周围八个像素进行编码,这八个0和1正好是可以组成一个byte数,然后按一定的规则组成这个无符号数。
3.把这个数赋值给当前像素。
4.通常对处理后的图像进行区域划分,比如分成4*4 、10*10或16*16的区域,对每个区域求得直方图,得到16、100或256个直方图。(划分都不是固定的)
5.这些直方图就是特征了,可以根据需要任意使用了。
下面是简单的实现:
close all;clc;img=imread('lena.jpg');[m n]=size(img);imgn=zeros(m,n);for i=2:m-1 for j=2:n-2 pow=0; for p=i-1:i+1 for q =j-1:j+1 if img(p,q) > img(i,j) if p~=i || q~=j %有的文章这里是3*3的顺时针编码,我就按处理顺序编码了。 %反正都是特征描述啥的,只要按相同规则就行了。 imgn(i,j)=imgn(i,j)+2^pow; pow=pow+1; end end end end endendfigure;imshow(imgn,[]);hist=cell(1,4); %划分四个区域求直方图,10*10的太多了,这里搞简单点hist{1}=imhist(img(1:floor(m/2),1:floor(n/2)));hist{2}=imhist(img(1:floor(m/2),floor(n/2)+1:n));hist{3}=imhist(img(floor(m/2)+1:m,1:floor(n/2)));hist{4}=imhist(img(floor(m/2)+1:m,floor(n/2)+1:n));for i=1:4 figure; plot(hist{i});end
效果:
原图
LBP特征图
直方图1
直方图2
直方图3
直方图4
参考:
1.http://blog.csdn.net/carson2005/article/details/6292905
2.http://blog.csdn.net/abcjennifer/article/details/7425483
阅读全文
0 0
- matlab练习程序(LBP,局部二值模型)
- matlab练习程序(LBP,局部二值模型)
- LBP,局部二值模型)
- 局部二值模式(LBP)
- 特征提取--基于局部二值模型(LBP)的特征提取
- LBP(局部二值模式)
- 人脸表情识别笔记(二)特征提取之LBP(局部二值模式)原理及MATLAB代码
- 局部二值模式(LBP)中间过程的可视化
- LBP(Local Binary Pattern,局部二值模式)
- LBP(局部二值模式)基础知识篇
- LBP(局部二值模式)实现人脸识别
- LBP局部二值模式研究(待完善)
- opencv2笔记05-局部二值模式(LBP)
- LBP(局部二值模式)特征提取原理
- 局部二值模式(LBP)理论学习与算法实现
- matlab练习程序(二值图像内外边界跟踪)
- LBP matlab 算法实现练习
- 局部二值模式LBP(Local Binary Pattern)实现代码
- 简要谈谈前端性能优化的问题
- 组合和继承
- 将new Date()获取的日期格式化
- 第26讲项目6-定期存款利息计算器
- Android开发艺术探索_View的工作原理(四)
- matlab练习程序(LBP,局部二值模型)
- PostgreSQL Daily Maintenance
- SDIO驱动总结
- OSG自定义拖拽器
- Java方法中通过传递参数改变变量的值
- 操作系统常见面试题目
- JAVA性能优化
- 素数
- 新网站如何快速被搜索引擎收录