fd = fopen('video_test_pattern_avalon_generator_source_data.txt'); //打开像素源文件 A = fscanf(fd,'%d'); //读入文件中的数据 fclose(fd);
%先申明向量用于存储数据 B = zeros(224,224); C = zeros(224,224); R1 = zeros(50176,1); R2 = zeros(50176,1); R3 = zeros(224,224); G1 = zeros(50176,1); G2 = zeros(50176,1); G3 = zeros(224,224); B1 = zeros(50176,1); B2 = zeros(224,224);
for j = 1:224 for i = 1:224 B(j,i) = A((j-1)*224+i); end end
% 24-Bit RGB数据结构 % R---1111 1111 --- 0000 0000 --- 0000 0000 = 16711680 % G---0000 0000 --- 1111 1111 --- 0000 0000 = 65280 % B---0000 0000 --- 0000 0000 --- 1111 1111 = 255 %---R for i = 1:50176 R1(i) = bitand(A(i),16711680); //与操作,得到数据的高8位 end for i = 1:50176 R2(i) = bitshift(R1(i),-16); //移位操作,将数据向右移动16位 end for j = 1:224 for i = 1:224 R3(j,i) = R2((j-1)*224+i); //将数据还原成二维矩阵224X224格式 end end %---G for i = 1:50176 G1(i) = bitand(A(i),65280); end for i = 1:50176 G2(i) = bitshift(G1(i),-8); end for j = 1:224 for i = 1:224 G3(j,i) = G2((j-1)*224+i); end end %---B for i = 1:50176 B1(i) = bitand(A(i),255); end for j = 1:224 for i = 1:224 B2(j,i) = B1((j-1)*224+i); end end %---display image(:,:,1) = R3; //将RGB源信息存在3维数组中 image(:,:,2) = G3; image(:,:,3) = B2; imshow(uint8(image)); //将3维数组信息转化为uint8格式,并显示成图片
Matlab位运算函数:
例子:
a = 60; % 60 = 0011 1100 b = 13; % 13 = 0000 1101 c = bitand(a, b) % 12 = 0000 1100 c = bitor(a, b) % 61 = 0011 1101 c = bitxor(a, b) % 49 = 0011 0001 c = bitshift(a, 2) % 240 = 1111 0000 */ c = bitshift(a,-2) % 15 = 0000 1111 */
运行结果:
c = 12 c = 61 c = 49 c = 240 c = 15