如何使contourf画出图像等高线边界平滑处理matlab
1个回答
展开全部
[X Y Z]=peaks; %生成一个二维高斯分布曲面代替你的数据
[c h]=contourf(X,Y,Z,5); %画的时候要保存返回的c h
hc=get(h,'Children'); %获得等值线填充对象
n=length(hc);
v=zeros(n,1);
s=zeros(n,1);
for i=1:n
x=get(hc(i),'xdata'); %第i个填充对象x数据
y=get(hc(i),'ydata'); %第i个填充对象y数据
l=length(x);
s(i)=sum((x([2:l,1]) - x).*(y([2:l,1]) + y))/2; %计算第i个填充对象面积
v(i)=get(hc(i),'UserData'); %获得第i个对象对应的等值
end
[v m n]=unique(v); %找出相同等值的对象
s=accumarray(n,s); %合拼他们的面积
v表示等值线的所在的等值
s表示等值线包围的大于这个等值部分的面积
我想你最终是想求两个等值之间的面积
所以求大于某值的面积和小于某值的面积都是可以的
就matlab自己返回的数句求大于某等值的面积比较简单
[c h]=contourf(X,Y,Z,5); %画的时候要保存返回的c h
hc=get(h,'Children'); %获得等值线填充对象
n=length(hc);
v=zeros(n,1);
s=zeros(n,1);
for i=1:n
x=get(hc(i),'xdata'); %第i个填充对象x数据
y=get(hc(i),'ydata'); %第i个填充对象y数据
l=length(x);
s(i)=sum((x([2:l,1]) - x).*(y([2:l,1]) + y))/2; %计算第i个填充对象面积
v(i)=get(hc(i),'UserData'); %获得第i个对象对应的等值
end
[v m n]=unique(v); %找出相同等值的对象
s=accumarray(n,s); %合拼他们的面积
v表示等值线的所在的等值
s表示等值线包围的大于这个等值部分的面积
我想你最终是想求两个等值之间的面积
所以求大于某值的面积和小于某值的面积都是可以的
就matlab自己返回的数句求大于某等值的面积比较简单
光点科技
2023-08-15 广告
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件...
点击进入详情页
本回答由光点科技提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询