Slices through 3-D Volumes, formed by 1D-arrays
2 ビュー (過去 30 日間)
古いコメントを表示
f=data:image/s3,"s3://crabby-images/9eae0/9eae0bd2adba2e5cd83262fa3ee746c3b11ed210" alt=""
data:image/s3,"s3://crabby-images/9eae0/9eae0bd2adba2e5cd83262fa3ee746c3b11ed210" alt=""
I have a set of 1D - arrays
and values of the inequality f.
data:image/s3,"s3://crabby-images/82f3b/82f3b83ac67a92c7aa979e2e03679be2180f08b4" alt=""
I need to build a series of slices for any of the planes of this volume. I don't know how to do this in Matlab, because the data is in vector form. Please help.
2 件のコメント
KSSV
2023 年 1 月 12 日
Your data lies in a sphere. You can make circular planes of required radius and center.
採用された回答
Walter Roberson
2023 年 1 月 12 日
Nx = 50;
Ny = 51;
Nz = 52;
load f
load x
load y
load z
figure();
PointSize = 20;
scatter3(x, y, z, PointSize, f); colorbar();
minx = min(x); maxx = max(x);
miny = min(y); maxy = max(y);
minz = min(z); maxz = max(z);
xvec = linspace(minx, maxx, Nx);
yvec = linspace(miny, maxy, Ny);
zvec = linspace(minz, maxz, Nz);
[Xq, Yq, Zq] = meshgrid(xvec, yvec, zvec);
Fq = griddata(x, y, z, f, Xq, Yq, Zq);
mask = Fq < 1/2 | Fq > 1;
Fq(mask) = nan;
figure();
sx = linspace(minx, maxx, 7);
sy = linspace(miny, maxy, 7);
sz = linspace(minz, maxz, 7);
H = slice(Xq, Yq, Zq, Fq, sx, sy, sz);
set(H, 'EdgeColor', 'none');
2 件のコメント
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Volume Visualization についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!