-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFsatMRI_Cart8foldRec_Learn_from_real_imag_8.m
82 lines (64 loc) · 2.92 KB
/
FsatMRI_Cart8foldRec_Learn_from_real_imag_8.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
%% set to 0 if you want to run on CPU (very slow)
gpu = 1; %2
% if gpu
% gpuDevice(gpu);
% end
%% #######%%%%% read sampling---start %%%%
load .\test_data_mask_FastMRI50\8_fold_cart_320;
figure(355); imshow(mask,[]); %
figure(356); imshow(fftshift(mask),[]);
n = size(mask,2);
fprintf(1, 'n=%d, k=%d, Unsamped=%f\n', n, sum(sum(mask)),1-sum(sum(mask))/n/n); %
%% #######%%%%% read sampling---end %%%%
resulti = [];
for i=1:1 %1:50 %[1,11,18,34,38]
% Tmp= load(fullfile(folder{fi},filepaths(i).name));
Tmp= load(['.\test_data_mask_FastMRI50\fastMRIdata_50\knee' num2str(i,'%02d') '.mat']);
image= Tmp.Img;
im_ori = double(image);
im_ori = (im_ori - min(im_ori(:)))/(max(im_ori(:)) - min(im_ori(:)));
im_orifft = fft2(im_ori);
Img = ifft2(ifftshift(im_orifft));
gt = 255*Img./max(abs(Img(:)));
figure(334);imshow(abs(gt),[]);
sigma_d = 0 * 255;
noise = randn(size(gt));
partialdata = mask.*(fft2(gt) + noise * sigma_d + (0+1i)*noise * sigma_d); %
zero_filled = ifft2(partialdata);
figure(335);imshow(abs(zero_filled),[]);
%% #######%%%%% load network for solver---start %%%%
params.gt = gt; params.num_iter = 200;
params.sigma_net = 10; params.sigma_net2 = 10; %8;
load('.\models\fastMRIdata_2941_MWCNN_GDSigmaReal8\fastMRIdata_2941_MWCNN_GDSigmaReal8-epoch-45'); net1 = net;
net1 = dagnn.DagNN.loadobj(net1) ;
net1.removeLayer('objective') ;
out_idx = net1.getVarIndex('prediction') ;
net1.vars(net1.getVarIndex('prediction')).precious = 1 ;
net1.mode = 'test';
if gpu
net1.move('gpu');
end
load('.\models\fastMRIdata_2941_MWCNN_GDSigmaImag8\fastMRIdata_2941_MWCNN_GDSigmaImag8-epoch-45'); net2 = net;
net2 = dagnn.DagNN.loadobj(net2) ;
net2.removeLayer('objective') ;
out_idx = net2.getVarIndex('prediction') ;
net2.vars(net2.getVarIndex('prediction')).precious = 1 ;
net2.mode = 'test';
if gpu
net2.move('gpu');
end
%% #######%%%%% load network for solver---end %%%%
%% #######%%%%% MEDMSPRec Reconstruction---start %%%%
params.out_idx = out_idx; params.gpu = gpu;
[MEDMSPRec,resultimax] = FastMRI_DMSPMRIRec_2sigma(gt, zero_filled, partialdata, mask, params, net1, net2);
%% #######%%%%% MEDMSPRec Reconstruction---end %%%%
%% #######%%%%% display %%%%
figure(666);
subplot(2,3,[4,5,6]);imshow([abs(zero_filled-gt)/255,abs(MEDMSPRec-gt)/255],[]); title('Recon-error');colormap(jet);colorbar;
subplot(2,3,1);imshow(abs(gt)/255); title('Ground-truth');colormap(gray);
subplot(2,3,2);imshow(abs(zero_filled)/255); title('Zero-filled');colormap(gray);
subplot(2,3,3);imshow(abs(MEDMSPRec)/255); title('Net-recon');colormap(gray);
figure(667);imshow([real(gt)/255,imag(gt)/255,abs(gt)/255],[]);
figure(668);imshow([abs(zero_filled-gt)/255,abs(MEDMSPRec-gt)/255],[]); colormap(jet);colorbar;
resulti = [resulti;resultimax]
end