三維重建之多頻外差解包裹學習筆記

 

附matlab多頻外差解相位程序


%參考博客:https://blog.csdn.net/qq_15295565/article/details/99704919,並進行修改
clc;
close all;
clear;
 
%%  初始化
width  = 1024;  
heigth = 768;

 %三頻四步
FREQ = 3;
STEP  = 4;

%freq爲三個正弦條紋對應的週期數,λ=width/freq:代表每個條紋的週期(波長)
% 也可理解爲頻率,三個頻率參考李中偉的博士論文
freq = [70 64 59];  
freq12    = 6 ;
freq23    = 5 ;  
freq123  = 1 ;
%% Step0 生成條紋圖
% 利用分塊矩陣C存儲3組共計12張圖,三種頻率,四步相位
C = cell(FREQ,STEP);  
for i=1:FREQ
    for j=1:STEP
        C{i,j} = zeros(heigth,width);
    end
end
 
% 利用餘弦函數計算12張圖的灰度值,圖像的生成
% 三種頻率,四組相位
for i = 1:FREQ       % 對應三種頻率
    for  j = 0:(STEP) % 對應四步相位
        for k = 1:width
            C{i,j+1}(:,k) = 128+127*sin(2*pi*k*freq(i)/width+j*pi/2);
        end
    end
end
 
% 歸一化處理
for i = 1:3
    for j = 1:4
        C{i,j} = mat2gray(C{i,j});
    end
end
 
% 顯示12張圖
% for i = 1:FREQ
%     for j = 1:STEP
%         n = STEP*(i-1)+j;
%         h = figure(n);
%         imshow(C{i,j});
%     end
% end
 
%% Step1 求解相位主值

% phi存儲相位主值圖像
phi = cell(FREQ,1);
for i = 1:FREQ
    phi{i,1} = zeros(heigth,width);
end
 
% 計算每種頻率對應的相位主值
% 輸出三種頻率的相位主值,用於相差計算
for i = 1:FREQ % 對於3組中的每一組圖片,每一組相同頻率的有四張圖片
     I1 = C{i,1};
     I2 = C{i,2};
     I3 = C{i,3};
     I4 = C{i,4};
      for g = 1:heigth
          for k = 1:width          
            if     I4(g,k)==I2(g,k)&&I1(g,k)>I3(g,k)   %四個特殊位置
                    phi{i,1}(g,k)=0;
            elseif I4(g,k)==I2(g,k)&&I1(g,k)<I3(g,k) %四個特殊位置
                    phi{i,1}(g,k)=pi; 
            elseif I1(g,k)==I3(g,k)&&I4(g,k)>I2(g,k) %四個特殊位置
                    phi{i,1}(g,k)=pi/2;
            elseif I1(g,k)==I3(g,k)&&I4(g,k)<I2(g,k) %四個特殊位置
                    phi{i,1}(g,k)=3*pi/2;
            elseif I1(g,k)<I3(g,k) %二三象限
                    phi{i,1}(g,k)=atan((I4(g,k)-I2(g,k))./(I1(g,k)-I3(g,k)))+pi;
            elseif I1(g,k)>I3(g,k)&&I4(g,k)>I2(g,k) %第一象限
                    phi{i,1}(g,k)=atan((I4(g,k)-I2(g,k))./(I1(g,k)-I3(g,k)));
            elseif I1(g,k)>I3(g,k)&&I4(g,k)<I2(g,k) %第四象限
                    phi{i,1}(g,k)=atan((I4(g,k)-I2(g,k))./(I1(g,k)-I3(g,k)))+2*pi;  
            end %endif
            
          end             
     end
end
 
% 顯示
% figure,imshow(mat2gray(PH1));title('1相位主值'); 
% figure,imshow(mat2gray(PH2));title('2相位主值'); 
% figure,imshow(mat2gray(PH3));title('3相位主值'); 

%% Step2 利用外差原理疊加不同頻率的相位主值,得到整幅圖像只有一個週期的相位
PH1 = phi{1,1};   %頻率1
PH2 = phi{2,1};   %頻率2
PH3 = phi{3,1};   %頻率3

PH12   = zeros(heigth,width);
PH23   = zeros(heigth,width);
PH123 = zeros(heigth,width);
 
for g = 1:heigth
	for k = 1:width
		% 計算第1組和第2組的相差
		if PH1(g,k)>PH2(g,k)
			PH12(g,k) = PH1(g,k)-PH2(g,k);
		else
			PH12(g,k) = PH1(g,k)+2*pi-PH2(g,k);
        end
        
		% 計算第2組和第3組的相差
		if PH2(g,k)>PH3(g,k)
			PH23(g,k) = PH2(g,k)-PH3(g,k);
		else
			PH23(g,k) = PH2(g,k)+2*pi-PH3(g,k);
        end
        
        % 計算第12組和第23組的相差
        if PH12(g,k)>PH23(g,k)
			PH123(g,k) = PH12(g,k)-PH23(g,k);
		else
			PH123(g,k) = PH12(g,k)+2*pi-PH23(g,k);
        end
        
	end
end

%顯示
figure,imshow(mat2gray(PH12));title('1,2外差');  
figure,imshow(mat2gray(PH23));title('2,3外差'); 
figure,imshow(mat2gray(PH123));title('1,2,3外差');

%% Step3 相位解包裹;
%根據公式:
%η = floor(((delta_φ*delta_λ/λ)-φ)/2π),
%Φ = 2πη+φ ,
%由PH123、PH23、PH12反計算出PH1、PH2、PH3的連續相位

%初始化解包裹相位
phUnWrap = cell(3,1);
for i = 1:3
    phUnWrap{i,1} = zeros(heigth,width);
end

% 解包裹23:求PH23的絕對相位,deltaPh = PH123,phWrap = PH23
deltaPh = PH123;
phWrap = PH23;
R = freq23/freq123;

Nwrap = floor((deltaPh*R-phWrap)/(2*pi)+0.5);
ph23UnWrap= (2*pi)*Nwrap +phWrap;

% 解包裹12:求PH12的絕對相位,deltaPh = PH123,phWrap = PH12
deltaPh = PH123;
phWrap = PH12;
R = freq12/freq123;

Nwrap = floor((deltaPh*R-phWrap)/(2*pi)+0.5);
ph12UnWrap= (2*pi)*Nwrap +phWrap;

% 解包裹1:求PH1的絕對相位,deltaPh = PH12,phWrap = PH1
deltaPh = ph12UnWrap;
phWrap = PH1;
R = freq(1)/freq12;

Nwrap = floor((deltaPh*R-phWrap)/(2*pi)+0.5);
phUnWrap{1,1}= (2*pi)*Nwrap +phWrap;

% 解包裹2:求PH2的絕對相位,deltaPh = PH12,phWrap = PH2
deltaPh = ph12UnWrap;
phWrap = PH2;
R = freq(2)/freq12;

Nwrap = floor((deltaPh*R-phWrap)/(2*pi)+0.5);
phUnWrap{2,1}= (2*pi)*Nwrap +phWrap;

% 解包裹3:求PH2的絕對相位,deltaPh = PH23,phWrap = PH3
deltaPh = ph23UnWrap;
phWrap = PH3;
R = freq(3)/freq23;

Nwrap = floor((deltaPh*R-phWrap)/(2*pi)+0.5);
phUnWrap{3,1}= (2*pi)*Nwrap +phWrap;

%% show phUnWrap
figure
plot(PH123(100,:),'r');hold on
plot(PH23(100,:),'g');hold on
plot(ph23UnWrap(100,:));
grid on
legend('deltaPh','wrapPH','phUnWrap');
title('解包裹23'); 

figure
plot(PH123(100,:),'r');hold on
plot(PH12(100,:),'g');hold on
plot(ph12UnWrap(100,:));
grid on
legend('deltaPh','wrapPH','phUnWrap');
title('解包裹12'); 

figure
plot(ph12UnWrap(100,:),'r');hold on
plot(PH1(100,:),'g');hold on
plot(phUnWrap{1,1}(100,:));
grid on
legend('deltaPh','wrapPH','phUnWrap');
title('解包裹1'); 

figure
plot(ph12UnWrap(100,:),'r');hold on
plot(PH2(100,:),'g');hold on
plot(phUnWrap{2,1}(100,:));
grid on
legend('deltaPh','wrapPH','phUnWrap');
title('解包裹2'); 

figure
plot(ph23UnWrap(100,:),'r');hold on
plot(PH3(100,:),'g');hold on
plot(phUnWrap{3,1}(100,:));
grid on
legend('deltaPh','wrapPH','phUnWrap');
title('解包裹3'); 

參考:

https://blog.csdn.net/qq_15295565/article/details/99704919
https://blog.csdn.net/gao_summer_cola/article/details/75308618
https://mp.weixin.qq.com/s/eTlkyNrqDk_qrb7eS91ktQ
https://zhuanlan.zhihu.com/p/82521153

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章