matlab 3维 数据拟合,利用matlab将三维数据拟合成三维曲线

拟合三维曲线貌似可以用相信回归做,但是matlab有一个自带的polyfit函数,可以直接算出二维数据的拟合曲线,用的是最小二乘法的思想。

思路其实很简单,将两条拟合的二维曲线组合在一起就是三维曲线了。

先上代码吧

clc;clear all;

%fb = load('./LeafCloud/bend.txt');

fb = load('./LeafCloud/vertical.txt');

fb = fb(:,1:3);

x = fb(:,1);

y = fb(:,2);

z = fb(:,3);

figure(1)

plot3(x,y,z,'yo'); hold on

xlabel('x');

ylabel('y');

zlabel('z');

% 分别拟合两个二维的曲线,然后统一到一起

p_yx = polyfit(y,x,4);

x_out = polyval(p_yx, y);

p_yz = polyfit(y,z,4);

z_out = polyval(p_yz, y);

plot3(x_out ,y, z_out, 'r*'); hold on;

% 得出曲线函数 x_out = f(z_out) z_out = f(y)

p_zx_out = polyfit(z_out,x_out,4);

x_out_f = polyval(p_zx_out,z_out);

plot3(x_out_f,y,z_out,'b*'); hold on;

fb是从外部读进来的数据,我读的是点云数据,x y z 各个坐标的数据,plot3绘制三维数据的图像。

polyfit(y,x,4)拟合曲线函数 y是自变量,x是因变量,4是阶数, 即曲线是 x = a*y^4 + b*y^3 + c*y^2 +d*y + e; 这样的,阶数视情况而定, polyval 已经给出因变量x的方程,不用自己写了。 下面的polyfit(y,z,4)类似。

最后由自变量y 得出因变量x_out, z_out, 便可以绘制出三维曲线的图像了,结合起来就可以得出曲线函数 ,需要注意的是要一个自变量得出两个因变量,即我的是x = f(y), z = f(y),

看看我的拟合效果:

0a702f29fc8fb65b25948253ce09bb28.png

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值