灰度图像的8位平面分解

版权声明:本文为博主原创文章,转载请注明原地址。 https://blog.csdn.net/xiamentingtao/article/details/52398679

所谓灰度图像,即指8位256颜色的图像。将图像的每一位分别取出来,我们就可以将一幅图像分解开来,形成8幅图像。下面我们分别介绍使用matlab分解图像与使用halcon/c++分解图像的方法。

matlab8位分解

clc;
clear all;
A = imread('lena.tif');
% 显示原始图像
subplot(3,3,1);
imshow(A);title('原始图像');
% 显示8个位平面图像
for i=8:-1:1
    A_bitplane = bitshift(bitget(A,i),i-1);
    subplot(3, 3, 9-i+1);
    imshow(A_bitplane);
    title(['位平面 ' num2str(i)]);
end 

效果:





matlab8位合并复原

clc;
clear all;
A = imread('lena.tif');
Array=cell(1,8);
% 显示8个位平面图像
for i=8:-1:1
     Array{i} = bitshift(bitget(A,i),i-1);
end 

%%%复原
%%定义全0矩阵
[M,N]=size(Array{1});
B=zeros(M,N,'uint8');

for i=1:8
  B=bitset(B,i,bitget(Array{i},i));
end
figure;
subplot(1,2,1);
imshow(A);title('原始图像');
subplot(1,2,2)
imshow(B);title('复原后图像');



结果:



halcon分解

方法一,自己实现

void Bit()
{
  using namespace Halcon;

  cout << endl << "Shifting & cutting out bit values:" << endl;

  HByteImage image("mreut");
  HWindow  w(0,0,image.Width(),image.Height());
  w.SetPart(0,0,image.Height()-1,image.Width()-1);
  image.Display(w);

  int i;

  cout << "- cutting out bit slices" << endl; 
  for (i=0; i<8; i++) 
  {
    HRegion reg = (image & (1<<i)) != 0; //按照位切片
    w.ClearWindow();
    reg.Display(w);
    cout << "  & bit " << i << endl;
  }
 
}


方法二,使用自带函数

void Bit()
{
  using namespace Halcon;

  cout << endl << "Shifting & cutting out bit values:" << endl;

  HByteImage image("mreut");
  HWindow  w(0,0,image.Width(),image.Height());
  w.SetPart(0,0,image.Height()-1,image.Width()-1);
  image.Display(w);

  int i;
  cout << "- cutting out bit slices2" << endl;
  for (i = 0; i < 8; i++)
  {
	  HRegion reg = (image.BitSlice(i+1)) != 0; //按照位切片
	  w.ClearWindow();
	  reg.Display(w);
	  cout << "  & bit " << i << endl;
  }

}

附加matlab一个好的教程:

参考文献:












阅读更多

扫码向博主提问

xiamentingtao

随便问吧,无论学术还是人生
  • 擅长领域:
  • cv
  • math
  • 考博
  • 算法
  • AI
去开通我的Chat快问

位平面分解的函数

04-05

下面程序我自己编的针对24位BMP位平面分解与显示的程序,其中位平面分解函数是改动的一个处理8位灰度图像的一个api函数,但是结果只能处理一副图像的一半还不知道处理的对不对,并且只能到第8副图像,(应该有24副吧),求各位大神帮忙看看,代码如下:rnBOOL Crenwu1_1View::DIBBITPLANE(CDib * pDib, BYTE bBitNum)rnrn // 如果输入的数不符合要求,不进行分解rn if(bBitNum <1 || bBitNum >24)rn return FALSE;rn rn // 指向源图像的指针rn BYTE * lpSrc;rnrn //图象的宽度和高度rn LONG lWidth;rn LONG lHeight;rnrn // 图像每行的字节数rn LONG lLineBytes;rn rn // 循环变量rn LONG i;rn LONG j;rnrn // 中间变量rn BYTE bTemp;rn BYTE bA;rnrn // 二进制第i位对应的十进制值rn BYTE bCount;rn rn //得到图象的宽度和高度rn CSize SizeDim;rn SizeDim = pDib->GetDimension();rn lWidth = SizeDim.cx;rn lHeight = SizeDim.cy; rn rn //得到实际的Dib图象存储大小rn CSize SizeRealDim;rn SizeRealDim = pDib->GetDibSaveDim();rnrn // 计算图像每行的字节数rn lLineBytes = SizeRealDim.cx;rn rn //图像数据的指针rn LPBYTE lpDIBBits = pDib->m_lpData; rn rn bCount = 1<<(bBitNum - 1);rn rn for (i = 0; im_pDibInit;rn rn rn rn //LPBITMAPINFOHEADER lpBMIH=pDib->m_lpBmpInfoHeader;(这句没用了)rnrn /* 判断是否是24-bmp位图(这里为了方便,只处理24-bmp位图的位平面分解)*/rn if (Cdib.GetBitCount() != 24)rn rn // 提示用户rn MessageBox("目前只支持24位图的位平面分解!", "系统提示" ,rn MB_ICONINFORMATION | MB_OK);rn rn // 返回rn return;rn rn DIBBITPLANE(&Cdib,dlgCoding.m_BItNumber);rn //statedoc=1;rnrn // 设置脏标记rn pDoc->SetModifiedFlag(TRUE);rn rn // 更新视图rn pDoc->UpdateAllViews(NULL);rn // TODO: 在此添加命令处理程序代码rnrnrnrn[img=C:\Documents and Settings\Owner\桌面][/img]rn这是第一位平面rn[img=C:\Documents and Settings\Owner\桌面][/img]rn这是第8位平面rn谢谢!!

没有更多推荐了,返回首页