zoukankan      html  css  js  c++  java
  • MATLAB LBP,局部二值模型

    一种图像特征的提取算法。

    算法步骤:

    1.用3*3的模板对图像每个像素进行处理,比较当前像素和周围像素的大小,将大于当前像素的置1,小于的置0。

    2.对这周围八个像素进行编码,这八个0和1正好是可以组成一个byte数,然后按一定的规则组成这个无符号数。

    3.把这个数赋值给当前像素。

    4.通常对处理后的图像进行区域划分,比如分成4*4 、10*10或16*16的区域,对每个区域求得直方图,得到16、100或256个直方图。(划分都不是固定的)

    5.这些直方图就是特征了,可以根据需要任意使用了。

    下面是简单的实现:

     1 clear all;
     2 close all;
     3 clc;
     4 
     5 img=imread('lena.jpg');
     6 [m n]=size(img);
     7 
     8 imgn=zeros(m,n);
     9 for i=2:m-1
    10    for j=2:n-2 
    11         
    12        pow=0;
    13         for p=i-1:i+1
    14             for q =j-1:j+1
    15                 if img(p,q) > img(i,j)
    16                     if p~=i || q~=j         %有的文章这里是3*3的顺时针编码,我就按处理顺序编码了。
    17                                             %反正都是特征描述啥的,只要按相同规则就行了。
    18                       imgn(i,j)=imgn(i,j)+2^pow;
    19                       pow=pow+1;
    20                     end
    21                 end
    22             end
    23         end
    24             
    25    end
    26 end
    27 figure;
    28 imshow(imgn,[]);
    29 hist=cell(1,4);     %划分四个区域求直方图,10*10的太多了,这里搞简单点
    30 hist{1}=imhist(img(1:floor(m/2),1:floor(n/2)));
    31 hist{2}=imhist(img(1:floor(m/2),floor(n/2)+1:n));
    32 hist{3}=imhist(img(floor(m/2)+1:m,1:floor(n/2)));
    33 hist{4}=imhist(img(floor(m/2)+1:m,floor(n/2)+1:n));
    34 for i=1:4
    35    figure;
    36    plot(hist{i});
    37 end

    效果:

    原图

    LBP特征图

    直方图1

    直方图2

    直方图3

    直方图4

  • 相关阅读:
    教师资格证考试全部重点名词解释
    计算机软考中高级职称评定条件
    如何计算教师工龄?工龄和教龄的区别
    vue.js中 this.$nextTick()的使用
    数组的合并 总结的几种方法
    CSS3实现了左右固定中间自适应的几种方法
    文本溢出省略号
    MVC/MVP/MVVM
    vue中父组件给子组件传值的方法
    vue实例的生命周期
  • 原文地址:https://www.cnblogs.com/ybqjymy/p/13646449.html
Copyright © 2011-2022 走看看