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

rongewu2006 2009-11-16 01:13:17
假如曲线方程:y = a0 + a1*x + a2*x^2 + a3*x^3 + .......
怎么求一个不在曲线上的点到这条曲线的距离。
...全文
7812 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2009-11-16
  • 打赏
  • 举报
回复 1
如果精度要求不高,还可以编程序对曲线上每个点求到给定点的距离,得出近似解。
berryluo 2009-11-16
  • 打赏
  • 举报
回复
假设要求得点是(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的多项式,求导取得极值点,计算比较之,不过好像这个算起来也比较复杂
[Quote=引用楼主 rongewu2006 的回复:]
假如曲线方程:y = a0 + a1*x + a2*x^2 + a3*x^3 + .......
怎么求一个不在曲线上的点到这条曲线的距离。
[/Quote]
xingzhe2001 2009-11-16
  • 打赏
  • 举报
回复
求导阿,加入求得点是(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为极值点,就是你要找的点
内容概要:本文详细介绍了利用Simulink进行变压器开路试验的电路连接配置与仿真实现方法,重点在于通过仿真手段还原实际电力系统中变压器在空载条件下的电气特性,从而深入理解其工作原理与性能表现。文章作为电力系统仿真系列研究的一部分,系统阐述了从电路模型搭建、参数设定、仿真运行到结果分析的完整流程,突出展示了MATLAB/Simulink在电力设备建模与教学科研中的强大功能与应用价值。; 适合人群:具备电力系统基础知识,熟悉MATLAB/Simulink仿真环境,从事电气工程、自动化及相关领域的研发人员,以及高年级本科生和研究生。; 使用场景及目标:①掌握变压器开路试验的基本原理与Simulink仿真建模的具体步骤;②通过仿真实验深入理解空载电流、铁芯损耗及励磁特性等关键参数的物理意义;③为后续开展变压器短路试验、暂态过程分析以及其他电力设备的仿真研究奠定理论与实践基础。; 阅读建议:建议结合Simulink软件动手实践,逐步构建并调试电路模型,重点关注各元件参数的设置方法与测量模块的应用技巧,同时推荐参考文中提及的其他相关仿真案例进行拓展学习,以全面提升对电力系统仿真实践的整体认知与操作能力。

3,881

社区成员

发帖
与我相关
我的任务
社区描述
C/C++ 其它技术问题
社区管理员
  • 其它技术问题社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧