インデックス付き画像 i、j、k である解剖学的ボリューム画像 (B) があります。
B(1,1,1)=0 %for example.
ファイルには 0 と 1 のみが含まれます。
等値面で正しく視覚化できます。
isosurface(B);
jのある座標でボリュームをカットしたいと思います(ボリュームごとに異なります)。
問題は、ボリュームが垂直に傾いていることです。おそらく 45% の角度を持っているため、カットは解剖学的ボリュームに沿っていません。
データの新しい直交座標系を取得したいので、座標 j の平面はより正確な方法で解剖学的ボリュームを切断します。
PCAでやるように言われましたが、やり方が分からず、ヘルプページを読んでも役に立ちませんでした。どんな方向でも大歓迎です!
編集:私は推奨事項に従ってきましたが、今では中心がゼロの新しいボリュームを取得しましたが、軸が解剖学的イメージに従っていないと思います。これらは前後の画像です。
これは、画像を作成するために使用したコードです(回答からいくつかのコードを取得し、コメントからアイデアを取得しました):
clear all; close all; clc;
hippo3d = MRIread('lh_hippo.mgz');
vol = hippo3d.vol;
[I J K] = size(vol);
figure;
isosurface(vol);
% customize view and color-mapping of original volume
daspect([1,1,1])
axis tight vis3d;
camlight; lighting gouraud
camproj perspective
colormap(flipud(jet(16))); caxis([0 1]); colorbar
xlabel x; ylabel y; zlabel z
box on
% create the 2D data matrix
a = 0;
for i=1:K
for j=1:J
for k=1:I
a = a + 1;
x(a) = i;
y(a) = j;
z(a) = k;
v(a) = vol(k, j, i);
end
end
end
[COEFF SCORE] = princomp([x; y; z; v]');
% check that we get exactly the same image when going back
figure;
atzera = reshape(v, I, J, K);
isosurface(atzera);
% customize view and color-mapping for the check image
daspect([1,1,1])
axis tight vis3d;
camlight; lighting gouraud
camproj perspective
colormap(flipud(jet(16))); caxis([0 1]); colorbar
xlabel x; ylabel y; zlabel z
box on
% Convert all columns from SCORE
xx = reshape(SCORE(:,1), I, J, K);
yy = reshape(SCORE(:,2), I, J, K);
zz = reshape(SCORE(:,3), I, J, K);
vv = reshape(SCORE(:,4), I, J, K);
% prepare figure
%clf
figure;
set(gcf, 'Renderer','zbuffer')
% render isosurface at level=0.5 as a wire-frame
isoval = 0.5;
[pf,pv] = isosurface(xx, yy, zz, vv, isoval);
p = patch('Faces',pf, 'Vertices',pv, 'FaceColor','none', 'EdgeColor',[0.5 1 0.5]);
% customize view and color-mapping
daspect([1,1,1])
axis tight vis3d;view(-45,35);
camlight; lighting gouraud
camproj perspective
colormap(flipud(jet(16))); caxis([0 1]); colorbar
xlabel x; ylabel y; zlabel z
box on
誰が何が起こっているのかヒントを提供できますか? 問題は reshape コマンドにあるようですが、以前に行った作業をキャンセルしている可能性はありますか?