【编程实践】使用matlab求椭圆弧长
创始人
2024-06-03 16:00:00
0

1 椭圆的表达式

Standard equation:
x2a2+y2b2=1\frac{x^2}{a^2}+\frac{y^2} {b^2}=1 a2x2​+b2y2​=1
Parametric equation:
x=acosαy=bsinα\begin{align*} x=acos\alpha \\y=bsin\alpha \end{align*}x=acosαy=bsinα​
General form equation:
Ax2+Bxy+Cy2+Dx+Ey+F=0Ax^2+Bxy+Cy^2+Dx+Ey+F=0Ax2+Bxy+Cy2+Dx+Ey+F=0
thereinto

A=a2sin2θ+b2cos2θB=2(b2−a2)sinθcosθC=a2cos2θ+b2sin2θD=−2Ax0−By0E=−Bx0−2Cy0F=−12(Dx0+Ey0)−a2b2\begin{align*} A = a^2sin^2\theta+b^2cos^2\theta \\B=2(b^2-a^2) sin\theta cos\theta \\C=a^2cos^2\theta +b^2sin^2\theta \\D=-2Ax_0-By_0 \\E=-Bx_0-2Cy_0 \\F=-\frac{1}{2}(Dx_0+Ey_0)-a^2b^2 \end{align*}A=a2sin2θ+b2cos2θB=2(b2−a2)sinθcosθC=a2cos2θ+b2sin2θD=−2Ax0​−By0​E=−Bx0​−2Cy0​F=−21​(Dx0​+Ey0​)−a2b2​
x0,y0x_0,y_0x0​,y0​为椭圆圆心坐标,a,ba,ba,b分别为椭圆的长短半轴,θ\thetaθ为长半轴与x轴的夹角。

2 椭圆的弧长计算理论公式

l=a∫θ1θ21−e2sin2θ,θ1,θ2∈[0,π2]l=a\int_{\theta_1}^{\theta_2}\sqrt{1-e^2sin^2\theta} ,\theta_1,\theta_2\in[0,\frac{\pi}{2}]l=a∫θ1​θ2​​1−e2sin2θ​,θ1​,θ2​∈[0,2π​]
thereinto, e=1−b2a2e=\sqrt{1-\frac{b^2}{a^2}}e=1−a2b2​​. Here, the angle we talk about is in the first quadrant.

C=4lC=4lC=4l
Using the Taylor series expansion, the circumference of the ellipse is
C≈π(a+b)C\approx\pi(a+b) C≈π(a+b)

3 以具体案例计算

x232+y222=1\frac{x^2}{3^2}+\frac{y^2}{2^2}=132x2​+22y2​=1

// 参数方程
theta = 0:0.01:2*pi %起止角度和步长
X = 3*cos(theta)
Y = 2*sin(theta)
plot(X,Y)

绘图输出显示🦢:
在这里插入图片描述

// 标准形式
theta = 0:0.01:2*pi
f =@(X,Y)X.^2/9+Y.^2/4-1
plot(X,Y)

绘图输出显示🦏:
在这里插入图片描述

// An highlighted block% 参数设定
a = 3
b = 2
e = sqrt(1-b^2/a^2)theta_1 = 0 %起始角度
theta_2 = pi/2 %终止角度
theta_x = theta_1:0.01:theta_2 % 被积区间y= a * sqrt(1-e.^2*sin(theta_x).^2) % 直接以被积函数声明
syms theta_vx
y2=@(theta_vx)a * sqrt(1-e.^2*sin(theta_vx).^2) % 匿名函数,被积函数句柄trapz(theta_x,y) % 梯度积分,trapz(X,Y)根据X指定的坐标或标量间距对Y进行积分,因椭圆第一象限曲线为凸曲线,则梯度法计算结果略小于精确值
quadgk(y2,theta_1,theta_2) % 高斯-勒让德积分,使用高阶全局自适应积分和默认误差容限在区间内对函数句柄求积分
integral(y2,theta_1,theta_2) % 数值积分,使用全局自适应积分和模型误差容限在区间内以数值形式为函数求积分

运行结果🐳:
在这里插入图片描述
另,[0,π2][0, \frac{\pi}{2}][0,2π​]区间四分之一椭圆弧长不精确计算结果:
ans=π∗(a+b)/4=3.1415∗(2+3)/4=3.9268ans=\pi*(a+b)/4=3.1415*(2+3)/4=3.9268ans=π∗(a+b)/4=3.1415∗(2+3)/4=3.9268

相同角度范围,椭圆弧长结果对比:
----------🌴----------[π4,π2][\frac{\pi}{4},\frac{\pi}{2}][4π​,2π​]间距下,

----------🌴----------[0,π4][0,\frac{\pi}{4}][0,4π​]间距下,
在这里插入图片描述

相关内容

热门资讯

安卓系统账号怎么改,轻松实现账... 你是不是也和我一样,在使用安卓手机的时候,突然觉得账号名字太老土了,想要来个焕然一新的改变呢?别急,...
离线语音系统安卓版下载,随时随... 你有没有想过,在手机上也能实现语音助手的功能,而且完全不需要联网?没错,就是那种离线语音系统,听起来...
华为os系统是基于安卓系统吗,... 你有没有想过,华为的手机里那个神秘的OS系统,它是不是就是安卓系统呢?别急,今天就来揭开这个谜底,让...
各品牌安卓系统多大,探索各大品... 你有没有想过,那些我们每天离不开的安卓手机,它们背后的系统到底有多大呢?这可不是一个小问题哦,因为系...
不是安卓系统电视机,探索非安卓... 你有没有想过,家里的电视是不是安卓系统呢?现在市面上,安卓系统电视机可是越来越流行了。但是,你知道吗...
谷歌安卓系统开源免费用,免费体... 你知道吗?在科技的世界里,有时候最让人惊喜的就是那些免费又好用的东西。今天,就让我来给你揭秘一个超级...
安卓电脑版怎么装系统,轻松实现... 你有没有想过,你的安卓电脑版突然间卡得像蜗牛一样,慢得让人抓狂?别急,今天就来教你怎么给它来个焕然一...
安卓系统有几种语音,揭秘多样化... 你知道吗?安卓系统里的语音功能可真是让人爱不释手呢!想象你只需要动动嘴,就能完成各种操作,是不是觉得...
扫码系统推荐安卓游戏,畅享指尖... 你有没有发现,最近手机里的游戏推荐越来越贴心了?没错,就是那个神奇的扫码系统!今天,就让我带你一探究...
手机系统安卓做的最好,探索最佳... 你有没有发现,现在手机市场上,安卓系统简直是要风得风,要雨得雨,简直是手机系统中的佼佼者!不信?那就...
安卓系统越拉越难用,越拉越难用... 你有没有发现,最近安卓系统越来越难用了?是不是每次打开手机,都感觉卡得要命,各种广告弹窗让人头疼不已...
卓安系统创始人,引领科技浪潮的... 你有没有想过,在这个信息爆炸的时代,谁才是那个站在风口浪尖,引领科技潮流的先锋?今天,我要带你认识一...
安卓10系统经常断网,安卓10... 最近是不是你也遇到了安卓10系统经常断网的问题?这可真是让人头疼啊!手机断网,就像失去了方向感的指南...
开发安卓系统用什么,从工具到实... 你有没有想过,为什么你的手机里装了那么多应用,却还是觉得不够用呢?其实,这一切都离不开一个强大的操作...
安卓系统如何双开抖音,安卓系统... 如何在安卓系统上双开抖音:让你的娱乐生活更加丰富多彩在数字化时代,手机已经成为我们生活中不可或缺的一...
安卓8.0系统内测地址,探索系... 你有没有听说最近安卓8.0系统内测的消息?这可是科技圈的大事啊!作为一个紧跟潮流的数码爱好者,我可是...
安卓系统可以账号同步吗,安卓系... 你有没有想过,你的安卓手机里的各种账户信息,比如微信、QQ、支付宝,能不能像变魔术一样,一键同步到另...
安卓系统的平板怎么下载,畅享应... 你有没有想过,拥有一款安卓系统的平板电脑,那感觉简直就像拥有了整个世界?想象随时随地都能畅游网络海洋...
win平板上装安卓系统咋样,开... 亲爱的读者们,你是否曾想过在Windows平板上体验安卓系统的魅力?想象那双熟悉的Windows界面...
给安卓车机写系统,安卓车机系统... 你有没有想过,你的安卓车机系统其实可以焕然一新?想象当你驾驶着爱车,车机界面流畅得像丝滑的巧克力,功...