资源简介
很长的程序,很有用很难找的专业程序,研究生阶段用到
代码片段和文件信息
% 卷积反投影重建;庄天戈《CT原理与算法》/卷积反投影重建/f3.27;笔束平移旋转扫描
%%
clear;
clc;
close all;
tic;
%% initial
I=phantom(256);
subplot(221)
imshow(I[]);
title(‘256*256原始图像‘);
[NN]=size(I);
z=2*ceil(norm(size(I)-floor((size(I)-1)/2)-1))+3;% radon变换默认平移点数/角度
Nt=360;% 角度采样点数
Nd=N;% 平移数
x=pi/180;% 角度增量
d=N/Nd;% 平移步长
theta = 1:Nt;
a=zeros(N);
%%
% 产生无噪声投影数据
[Rxp] = radon(Itheta);% 产生I投影默认z点/角度即使指定N点也是z点.
% 所以为避免重建图像放大或缩小下面计算取投影时需补偿补偿量e
% 如对256的图像补偿为55即pm的第55个点作为计算用的第一个投影
e=floor((z-Nd)/2)+2;
R=R(e:(Nd+e-1):);
R1=reshape(R256360);
% 添加噪声
[mmnn]=size(R1);
di=lognrnd(00.15mmnn);
R1= 10*(R1-min(R1(:)))/( max(R1(:))-min(R1(:)));
I0 = 1.5e5; % incident photons; decrease this for simulating “low dose“ scans
rand(‘state‘ 0) randn(‘state‘ 0);
yi= poissrnd(I0 * di.*exp(-R1))+3*randn(size(R1));
if any(yi(:) == 0)
warn(‘%d of %d values are 0 in sinogram!‘ ...
sum(yi(:)==0) length(yi(:)));
end
R1 = log(I0 ./ max(yi0.01)); % noisy sinogram
R1=max(R10); % R1 加噪的投影数据
% load R3.MAT
ff=2;
uu=22000;
v=ff*exp(R1/uu);
subplot(222)
imagesc(R1);
title(‘256*360有噪声平行投影‘);
colormap(gray)
colorbar
Q=reshape(R1256360);
%%
% designing RL filter
g=-(Nd/2-1):(Nd/2);
for i=1:256
if g(i)==0
hl(i)=1/(4*d^2);
else if mod(g(i)2)==0
hl(i)=0;
else
hl(i)=(-1)/(pi^2*d^2*(g(i)^2));
end
end
end
k=Nd/2:(3*Nd/2-1);% 取卷积结果时用
%%
% 重建过程
for m=1:Nt
% reading projection
pm=Q(:m);% 读取投影数据
u=conv(hlpm);% 卷积
评论
共有 条评论