四面体化可视化Octave

问题描述:

嗨有谁知道如何在Octave中显示delaunay3()函数的输出中的四面体?四面体化可视化Octave

http://www.obihiro.ac.jp/~suzukim/masuda/octave/html3/octave_151.html

在MATLAB这个可视化与tetramesh()函数来完成,但倍频没有内置这个功能!

链接确实提到了triplottrimesh函数,但它们只创建三角形,而不是四面体。

不幸的是,我对此没有足够的了解,无法对此有任何想法。但是,如果您之前没有看到过,我想提一下以下内容。已经有discussions on tetramesh before。一个快速的解决办法是写了由martin_helm

function tetramesh(T, X, C) 
    if nargin < 3 
    C = mod((1:size(T, 1))'-1, size(colormap(), 1) + 1); 
    endif 
    triang = [T(:, 1) T(:, 2) T(:, 3); ... 
      T(:, 2) T(:, 3) T(:, 4); ... 
      T(:, 3) T(:, 4) T(:, 1); ... 
      T(:, 4) T(:, 1) T(:, 2)]; 
    patch("Faces", triang, "Vertices", X, "FaceVertexCData", [C; C; C; C]) 
endfunction 

随着一些用法示例:

backend("fltk") % backend("gnuplot") could also be used 
d = [-1 1]; 
[x,y,z] = meshgrid(d,d,d); 
x = [x(:);0]; 
y = [y(:);0]; 
z = [z(:);0]; 

tetra = delaunay3(x,y,z); 
X = [x(:) y(:) z(:)]; 
tetramesh(tetra, X) 
view(30,30)