专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > C++

求点到曲线的最短距离的算法解决方法

发布时间:2011-06-29 00:12:08 文章来源:www.iduyao.cn 采编人员:星星草
求点到曲线的最短距离的算法
假如曲线方程:y = a0 + a1*x + a2*x^2 + a3*x^3 + .......
怎么求一个不在曲线上的点到这条曲线的距离。

------解决方案--------------------
求导阿,加入求得点是(x0,y0),
则点到曲线上任一点距离的平方(为了少计算开方)为

f = d^2 = (x-x0)^2 + (y-y0)^2.

对x求导

df/dx = 2(x-x0) + 2(y-y0).dy/dx

其中y和dy/dx根据你给的曲线方程求

df/dx=0为极值点,就是你要找的点
------解决方案--------------------
假设要求得点是(x0,y0), 则点到直接上任何一点的距离为
d = ((y-y0)^2 + (x-x0)^2)^0.5
= ((a0 + a1*x + a2*x^2 + a3*x^3 + .......-y0)^2 + (x-x0)^2)^0.5
d^2 = (a0 + a1*x + a2*x^2 + a3*x^3 + .......-x0)^2 + (x-x0)^2
d^2是关于x的多项式,求导取得极值点,计算比较之,不过好像这个算起来也比较复杂
探讨
假如曲线方程:y = a0 + a1*x + a2*x^2 + a3*x^3 + .......
怎么求一个不在曲线上的点到这条曲线的距离。

------解决方案--------------------
如果精度要求不高,还可以编程序对曲线上每个点求到给定点的距离,得出近似解。
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: