最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

MATLAB 寻找离散点拐点

IT圈 admin 2浏览 0评论

MATLAB 寻找离散点拐点

最近用matlab拟合离散数据,曲线由两段圆弧和直线组成,如下图所示,现在想要通过代码寻找曲线的拐点也就是开始弯曲的位置,原理很简单,对离散数据求导,直线段的导数比较小,当曲线发生弯曲导数会突然变大,根据选取的阈值来控制选点的精度,阈值越小选取的点越精确。寻找拐点时分为两个部分分别寻找,上升区域和下降区域,m为数据点的个数。

matlab 寻找离散点拐点代码实现:

J= gradient(y,x);                                                          %求导
a=find(abs(J(1,1:floor(m/2)))>0.09);                                       %此处阈值设置为0.09
a1=find(abs(J(1,floor(m/2):end))>0.09)+floor(m/2)-1;
b=y(a(end));                                                               %上升趋势的最后一个点的纵坐标
b1=y(a1(1));                                                               %下降趋势的第一个点的纵坐标
c1=x(a1(1));                                                               %下降趋势的第一个点的横坐标 

 

MATLAB 寻找离散点拐点

最近用matlab拟合离散数据,曲线由两段圆弧和直线组成,如下图所示,现在想要通过代码寻找曲线的拐点也就是开始弯曲的位置,原理很简单,对离散数据求导,直线段的导数比较小,当曲线发生弯曲导数会突然变大,根据选取的阈值来控制选点的精度,阈值越小选取的点越精确。寻找拐点时分为两个部分分别寻找,上升区域和下降区域,m为数据点的个数。

matlab 寻找离散点拐点代码实现:

J= gradient(y,x);                                                          %求导
a=find(abs(J(1,1:floor(m/2)))>0.09);                                       %此处阈值设置为0.09
a1=find(abs(J(1,floor(m/2):end))>0.09)+floor(m/2)-1;
b=y(a(end));                                                               %上升趋势的最后一个点的纵坐标
b1=y(a1(1));                                                               %下降趋势的第一个点的纵坐标
c1=x(a1(1));                                                               %下降趋势的第一个点的横坐标 

 

与本文相关的文章

发布评论

评论列表 (0)

  1. 暂无评论