在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 1980|回复: 0

HOG的matlab源码

[复制链接]
发表于 2016-8-24 09:45:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
function HOGFeature = ImgHOGFeature( imgPathName, cell_size, nblock,...,    overlap, angle, bin_num)% 计算输入图像的特征描述子% imgPathName:图片路径% cell_size: cell的长宽% nblock: block的width、height包括的cell的个数% overlap: block重叠的比例% angle: 180\360% bin_num: 方向bin的数目 if nargin<2    % default parameter    cell_size=8;    nblock=2;    overlap=0.5;    angle=180;    bin_num=9;elseif nargin<6    error('Input parameters are not enough.');end Img = imread(imgPathName);if size(Img,3) == 3    % 简化计算,直接转换成灰度图像    G = rgb2gray(Img);else    G = Img;end [height, width] = size(G); % 计算x、y方向的梯度hx = [-1,0,1];hy = -hx';grad_x = imfilter(double(G),hx);grad_y = imfilter(double(G),hy); % 计算梯度的模长grad_mag=sqrt(grad_x.^2+grad_y.^2); % 计算梯度的方向index= grad_x==0;grad_x(index)=1e-5;YX=grad_y./grad_x;if angle==180    grad_angle= ((atan(YX)+(pi/2))*180)./pi; elseif angle==360    grad_angle= ((atan2(grad_y,grad_x)+pi).*180)./pi;end % orient binbin_angle=angle/bin_num;grad_orient=ceil(grad_angle./bin_angle); % 计算block的个数block_size=cell_size*nblock;skip_step=block_size*overlap;x_step_num=floor((width-block_size)/skip_step+1);y_step_num=floor((height-block_size)/skip_step+1); % 初始化hog特征描述子feat_dim=bin_num*nblock^2;HOGFeature=zeros(feat_dim,x_step_num*y_step_num); for k=1:y_step_num    for j=1:x_step_num        % block的左上角坐标        x_off = (j-1)*skip_step+1;        y_off = (k-1)*skip_step+1;         % 取得block的梯度大小和方向        b_mag=grad_mag(y_off:y_off+block_size-1,x_off:x_off+block_size-1);        b_orient=grad_orient(y_off:y_off+block_size-1,x_off:x_off+block_size-1);         % 当前block的hog直方图        currFeat = BinHOGFeature(b_mag, b_orient, cell_size,nblock, bin_num, false);        HOGFeature(:, (k-1)*x_step_num+j) = currFeat;     endend end

function blockfeat = BinHOGFeature( b_mag,b_orient,cell_size,nblock,...    bin_num, weight_vote)% 计算1个block的hog% weight_vote: 是否进行高斯加权投票 % block的HOG直方图blockfeat=zeros(bin_num*nblock^2,1); % 高斯权重gaussian_weight=fspecial('gaussian',cell_size*nblock,0.5*cell_size*nblock); % 分割blockfor n=1:nblock    for m=1:nblock        % cell的左上角坐标        x_off = (m-1)*cell_size+1;        y_off = (n-1)*cell_size+1;         % cell的梯度大小和方向        c_mag=b_mag(y_off:y_off+cell_size-1,x_off:x_off+cell_size-1);        c_orient=b_orient(y_off:y_off+cell_size-1,x_off:x_off+cell_size-1);         % cell的hog直方图        c_feat=zeros(bin_num,1);        for i=1:bin_num            % 是否进行高斯加权 投票            if weight_vote==false                c_feat(i)=sum(c_mag(c_orient==i));            else                c_feat(i)=sum(c_mag(c_orient==i).*gaussian_weight(c_orient==i));            end        end         % 合并到block的HOG直方图中        count=(n-1)*nblock+m;        blockfeat((count-1)*bin_num+1:count*bin_num,1)=c_feat;    endend % 归一化 L2-normsump=sum(blockfeat.^2);blockfeat = blockfeat./sqrt(sump+eps^2);
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-1-5 15:23 , Processed in 0.026636 second(s), 10 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表