Реализация лендвеберовской итерации для динамического преобразования Радона в MATLAB
Я работаю над динамическими обратными задачами и преобразованиями Радона. Под термином "Динамический" я подразумеваю, что объект (который в конечном итоге я собираюсь реконструировать, используя измерения), деформируется с течением времени. Вы можете представить Сердце или Легкие в человеческом теле. Поэтому обычные инструменты восстановления изображения (такие как отфильтрованные обратные проекции) необходимо изменить, чтобы справиться с деформацией. В моем случае деформация задается гладкой функцией в R^2
,
φ^t(x,y)=(φ(t,x),φ(t,y))=(x*(1+c*x), y*(1+d*y))
где обозначает, какая частица находится в положении(x,y)
в момент времениt
, Здесь коэффициенты c
а такжеd
даны
c=(5.*sin(5e-5.*t*p0./pi))^(1/4), d= (5.*sin(7e-5.*t*p0./pi))^(1/4)
Теперь рассмотрим следующий динамический обратный оператор (обобщенное преобразование Радона):
Af(s,t)=\iint_{R^2} f(φ^t(x,y)) \delta(x*cos t + y*sin t -s ) dx dy.
Вот\iint_{R^2}
двойное целоеR^2
а также \delta
это обычная дельта-функция. Используя изменение переменной, оператор выше можно записать в виде
g(s,t)=Af(s,t)=\iint_{R^2} J(t,x,y)f(x,y)*\delta(φ^{-1}(t,x)*cos t+φ^{-1}(t,y)*sin t-s)dxdy
где обратные функцииφ^{-1}
даны
φ^{-1}(t,x) = (\sqrt{1+4c*x}-1)/(2c), φ^{-1}(t,y)= (\sqrt{1+4d*y}-1)/(2d)
и якобиан
J(t,x,y)=1/(\sqrt{(1+4c*x)(1+4d*y)).
Вотt
это параметр, который определяет как время, так и направление луча (угол). Теперь функцияf(φ^t (x,y))
показывает состояние истинного объекта (Исходное изображение, которое мы называем Шепп-Логан SL) в момент времениt
, Например, когдаt=0
тогда функцияφ^t
это просто личность, поэтому мы получаем f(x,y)
который является исходным изображением SL.
Я хочу выполнить реконструкцию изображения с помощью итераций Landweber, поскольку кажется, что запуск по сравнению с другими методами не требует больших затрат. Лендвебер итераций принимает следующий вид
f^{k+1}(x,y)= f^k(x,y)+ \gamma*A^T(g-Af^k)(x,y),
где\gamma
это параметр длины шага, скажем 10^{-3}
, Здесь A^T
Я имею в виду сопряженное оператораA
который известен как обратная проекция. Поэтому для функцииh
, A^Th
примет следующую форму
A^Th(x,y)=\int_{R} J(t,x,y)*h(φ^{-1}(t,x)*cos t+φ^{-1}(t,y)*sin t,t)d t.
Поэтому, если мы заменим h
от g-Af^k
в приведенном выше сопряженном уравнении и подключившись к итерации Ландвебера, получим
f^{k+1}(x,y)= f^k(x,y)+\gamma*\int_{R} J(t,x,y)*(g-Af^k)(φ^{-1}(t,x)*cost+φ^{-1}(t,y)*sint,t)dt.
Вот моя цель. Допустим, мы искажаем исходный объект SL из t=0
в t=5
, Затем мы берем Радон деформированного SL в t=5
что дает нам измерение в t=5
, Мы с моим другом написали код MATLAB, в котором мы можем успешно деформировать исходный объект SL, а затем взять преобразование Радона (прямая задача). Теперь моя цель состоит в том, чтобы восстановить оригинальный объект SL в t=0
выполнив итерационную формулу Ландвебера (приведенную выше) из измерения деформированного SL в t=5
, Мы также написали код для этой части, но мы не можем восстановить исходный SL. Вот коды:
Оригинальный Объект Шепп Логан СЛ
function SLAmir = SLAmirFunc(Xsize)
% this function creates a Shepp-Logan like image
% xsize: is the desired size of the image
imageSizeX = Xsize;%100;
imageSizeY = Xsize;
[columnsInImage rowsInImage] = meshgrid(1:imageSizeX, 1:imageSizeY);
centerX = floor(Xsize/2);%50;
centerY = floor(Xsize/2);%50;
radius1 = floor(Xsize/2)-floor(Xsize/10);%40;
radius2 = floor(Xsize/2)-floor(Xsize/5.5);%32;
circlePixels_1 = (rowsInImage - centerY).^2 ./radius1.^2 ...
+ (columnsInImage - centerX).^2 ./radius2.^2<= 1;
centerX = floor(Xsize/2);
centerY = floor(Xsize/2);
radius1 = floor(Xsize/2)-floor(Xsize/7);%36;
radius2 = floor(Xsize/2)-floor(Xsize/5);%30;
circlePixels_2 = (rowsInImage - centerY).^2 ./radius1.^2 ...
+ (columnsInImage - centerX).^2 ./radius2.^2<= 1;
centerX = floor(Xsize/2);%50;
centerY = floor(Xsize/2)-floor(Xsize/7);%36;
radius = floor(centerY/3);%12;
circlePixels_3 = (rowsInImage - centerY).^2 ...
+ (columnsInImage - centerX).^2 <= radius.^2;
centerX = floor(Xsize/2)+floor(Xsize/7);%64;
centerY = floor(Xsize/2)+floor(Xsize/16);%56;
radius1 = floor(centerY/4.5);%12;
radius2 = floor(centerY/7);%8;
circlePixels_4 = (rowsInImage - centerY).^2 ./radius1.^2 ...
+ (columnsInImage - centerX).^2 ./radius2.^2<= 1;
circlePixels_4=imrotate(circlePixels_4,-30,'crop','bilinear');
centerX = floor(Xsize/2)-floor(Xsize/12.5);%42;
centerY = floor(Xsize/2)-floor(Xsize/10);%40;
radius1 = floor(centerY/2.5);%16;
radius2 = floor(centerY/4);%10;
circlePixels_5 = (rowsInImage - centerY).^2 ./radius1.^2 ...
+ (columnsInImage - centerX).^2 ./radius2.^2<= 1;
circlePixels_5=imrotate(circlePixels_5,45,'crop','bilinear');
circlePixels_6=circlePixels_1-.8.*circlePixels_2 + 0.2.*circlePixels_3
+.4.*circlePixels_4 -.1.*circlePixels_5;
sqIy=floor(Xsize/2)-floor(Xsize/10);
sqIx=floor(Xsize/2)+floor(Xsize/5.6);
circlePixels_6 (sqIx:sqIx+4,sqIy:sqIy+4)=circlePixels_6
(sqIx:sqIx+4,sqIy:sqIy+4)+.15;
SLAmir=circlePixels_6;
Передняя деформация:
function PPN3 = NonAffineTransform_v4(P,t,p0)
%performs the non-affine transform
%t:angle
%size_p:size of the main image +50
size_p=max(size(P));
xinit=(size_p-1)/200;
xx=-xinit:0.01:xinit;
yy=xx;
k=1;
for i=1:max(size(P))
for j=1:max(size(P))
xxO(k,:)=[xx(i),yy(j)];
k=k+1;
end
end
k=1;
cx = (5.*sin(5e-5.*t*p0./pi))^(1/4);
cy = (5.*sin(7e-5.*t*p0./pi))^(1/4);
for i=1:max(size(P))
for j=1:max(size(P))
xxt(k,:)= [xx(i).*((cx.*xx(i))^0+(cx.*xx(i))^1 +(cx.*xx(i))^2 +
(cx.*xx(i))^3+(cx.*xx(i))^4), ...%+(cx.*xx(i))^2+(cx.*xx(i))^3+
(cx.*xx(i))^4
yy(j).*((cy.*yy(j))^0+(cy.*yy(j))^1 +(cy.*yy(j))^2 +
(cy.*yy(j))^3+(cy.*yy(j))^4)];%+(cy.*yy(j))^2+(cy.*yy(j))^3+(cy.*yy(j))^4
k=k+1;
end
end
PPN=zeros(size_p,size_p);
mxx1=(max(size(xx))-1);
myy1=(max(size(yy))-1);
xx_idx=round(xxO*100+floor(mxx1/2)+1);% idx correspond to original image
xxt_idx=round(xxt*100+floor(mxx1/2)+1);%idx correspond to the deformed image
for i=1:max(size(xx))*max(size(yy))
if (xxt_idx(i,1)>0 && xxt_idx(i,2)>0) && (xxt_idx(i,1)<max(size(xx))+1 &&
xxt_idx(i,2)<max(size(xx))+1)
PPN(xxt_idx(i,1),xxt_idx(i,2))=P(xx_idx(i,1),xx_idx(i,2));%.*NormPhi(i)
end
end
PPN1=PPN;
kk=0;
loopCnt=1;
while kk ~=max(size(PPN1))
for j=1:max(size(xx))
aa=find(PPN1(:,j));
aams=max(size(aa));
if (isempty(aa)~=1)
AA=PPN1(aa(1):aa(aams),j);
bb = find(AA==0);
if (isempty(bb)~=1)
for i=1:max(size(bb))
PPN1(bb(i)+aa(1)-1,j)=PPN1(bb(i)+aa(1)-2,j);
end
else
kk=kk+1;
end
else
kk=kk+1;
end
end
if j==max(size(xx)) && kk ~=max(size(PPN1))
kk=0;
loopCnt=loopCnt+1;
end
end
%
PPN2=PPN1;
kk=0;
loopCnt=1;
while kk ~=max(size(PPN2))
for j=1:max(size(xx))
aa=find(PPN2(j,:));
aams=max(size(aa));
if (isempty(aa)~=1)
AA=PPN2(j,aa(1):aa(aams));
bb = find(AA==0);
if (isempty(bb)~=1)
for i=1:max(size(bb))
PPN2(j,bb(i)+aa(1)-1)=PPN2(j,bb(i)+aa(1)-2);
end
else
kk=kk+1;
end
else
kk=kk+1;
end
end
if j==max(size(xx)) && kk ~=max(size(PPN2))
kk=0;
loopCnt=loopCnt+1;
end
end
PPN3=PPN2;%.*NormPhi;%./sum(NormPhi(:));
Обратная деформация:
function fxy = invNonAffineTransform_v41(g,sp,t,tt,x,y,dxx)
p0=300;
ts=max(size(t));
xs=max(size(x));
ys=max(size(y));
temp=0;
mxx1=(max(size(x))-1);
myy1=(max(size(y))-1);
fxy=zeros(xs,ys);
for i=1:xs
for j=1:ys
for k=1:ts
cx = (5.*sin(5e-5.*t(k)*p0./pi))^(1/4);%(t(k)+pi/2)
cy = (5.*sin(7e-5.*t(k)*p0./pi))^(1/4);
invphix = (sqrt(1+4.*cx.*x(i))-1)./(2.*cx);
invphiy = (sqrt(1+4.*cy.*y(j))-1)./(2.*cy);
Stemp = invphix.*cos(t(k)+pi/2)+ invphiy.*sin(t(k)+pi/2);
%StempIdx= floor(Stemp./dxx);
StempIdx = floor(Stemp.*100);
spIdx=find(sp==StempIdx);
J=sqrt(1/((1+2.*cx.*x(i)).*(1+2.*cy.*y(j))));
if isempty(spIdx)
temp=temp+0;
else
temp = temp +J.*g(spIdx,k);
end
end
fxy(i,j) = fxy(i,j)+ tt.*temp;
temp =0;
end
end
Бежать:
clear all
clc
close all
size_p=151;
P=zeros(size_p,size_p);
DisSide=40;
P1 = SLAmirFunc(size_p-DisSide);%
P(DisSide/2+1:size_p-DisSide/2,DisSide/2+1:size_p-DisSide/2)=P1;
p0=300;
size_p=max(size(P));
xinit=(size_p-1)/200;
xx=-xinit:0.01:xinit;
yy=xx;
j=1;
tt=[25:5:300].*pi./p0;
fxy=P;
for i=1:max(size(tt))
PPN3p = NonAffineTransform_v4(fxy,tt(i),p0);
PPN3 = PPN3p;
figure;imagesc(PPN3), colormap(bone), colorbar;
end
ttdeg=tt.*180./pi;
[g,sp] = radon(PPN3,ttdeg);
I1 = iradon(g,ttdeg,size_p);
Afpre=zeros(max(size(sp)),max(size(tt)));
fold=zeros(size_p,size_p);
stepsize=0.0001;
ssp=max(size(sp));
dxx=(xx(size_p)-xx(1)+1)/ssp;
Dt=tt(2)-tt(1);
for it=1:10
g1=g-Afpre;
fnew = fold + stepsize.*invNonAffineTransform_v41(g1,sp,tt,Dt,xx,yy,dxx);
for i=1:max(size(tt))
PPN3p = NonAffineTransform_v4(fnew,tt(i),p0);
clear PPN3
PPN3 = PPN3p;
end
[Afpre,sp] = radon(PPN3,ttdeg);
fold = fnew;
end
Мне было интересно, если кто-нибудь здесь знаком с этой темой и может быть любая помощь.
Если это не ясно, пожалуйста, прокомментируйте, и я буду отвечать на ваши вопросы. Заранее спасибо.