Matlab 中如何得到用isosurface 形成的曲面的点集

rt... rt 展开
 我来答
云倾城001
推荐于2016-02-14 · TA获得超过1209个赞
知道小有建树答主
回答量:585
采纳率:0%
帮助的人:401万
展开全部
//isosurface函数用于由体积数据中提取等值数据。
//使用方法如下
fv =
//使用方法如下
fv = isosurface(X,Y,Z,V,isovalue)
fv = isosurface(V,isovalue)
fvc = isosurface(...,colors)
[f,v] = isosurface(...)
[f,v,c] = isosurface(...)
isosurface(...)
//参数意义为,从由X,Y,Z构造的体积V数据中提取由isovalue指定的等值数据,返回结果fv为一个结构体,包含了等值面的顶点和面(顶点的次序),这些参数可以直接传给patch命令画出图形来。
//另外,可以在最后加上colors,返回值中也会得到每个面的颜色插值,这样能够使你用不同于计算等值面的数据控制等值面的颜色映射。


//示例:

[x y z v] = flow;
[fc vt] = isosurface(x, y, z, v, -3);%vt就是曲面点集
p=patch('Faces',fc,'Vertices',vt);
       isonormals(x,y,z,v, p)
       set(p, 'FaceColor', 'red', 'EdgeColor', 'none');
       daspect([1 1 1])
       view(3)
       camlight; lighting phong
figure
plot3(vt(:,1),vt(:,2),vt(:,3),'.')
我行我素850915
2015-05-17 · TA获得超过8241个赞
知道大有可为答主
回答量:5788
采纳率:77%
帮助的人:1750万
展开全部
这个命令的使用要根据程序需要而定的,它的输出参数是一个结构,可直接传给patch函数进行画图,如
[x, y, z, v] = flow;
q = z./x.*y.^3;
k=isosurface(x, y, z, q, -.08, v);
p = patch(k);
isonormals(x,y,z,q, p)
set(p, 'FaceColor', 'interp', 'EdgeColor', 'none');
daspect([1 1 1]); axis tight;
>> k
k =
vertices: [2318x3 double]
faces: [4344x3 double]
facevertexcdata: [2318x1 double]
其中的vertices是顶点集合,facevertexcdata是面集合
上面程序加上:
figure,plot(k.vertices)
figure,plot(k. facevertexcdata)
看看效果。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
greatdju
推荐于2016-09-06 · TA获得超过2.2万个赞
知道大有可为答主
回答量:2486
采纳率:50%
帮助的人:4184万
展开全部
举个例子
[x y z v] = flow;
[fc vt] = isosurface(x, y, z, v, -3);%vt就是曲面点集
p=patch('Faces',fc,'Vertices',vt);
isonormals(x,y,z,v, p)
set(p, 'FaceColor', 'red', 'EdgeColor', 'none');
daspect([1 1 1])
view(3)
camlight; lighting phong
figure
plot3(vt(:,1),vt(:,2),vt(:,3),'.')
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式