ImageVerifierCode 换一换
格式:DOCX , 页数:40 ,大小:157.28KB ,
资源ID:8435126      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8435126.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(三体问题的仿真与实现.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

三体问题的仿真与实现.docx

1、三体问题的仿真与实现1 前 言1.1 论文的背景在太阳系内的天体都可以近似看做球形,并且与他们之间的距离相比,他们的的大小就可以忽略不计,因而他们能被看做质点。因此,可以用现代动力天文学的基础理论来研究这个问题。这部分的天体力学以牛顿的万有引力理论开始。从1687年的数学原理出版之时开始,证实牛顿的理论是否能够独立的提供一个完整的关于天体如何在太空中运动的认识是非常重要的。沿着这个思路进行研究,我们需要根据牛顿的万有引力定律来确定彼此吸引的n体之间的相对运动。 牛顿曾经用几何学原理解决了只存在相互引力作用的两个球的运动这一两体问题。在1710年,JohannBernoulli证明,在两体问题中

2、,一个粒子相对于另外一个粒子的运动可以被描述为一个圆锥曲线。在1734年,DanielBernoulli因为他关于分析处理两体问题的研究获得了法国科学院奖。在1744年,这个问题被Euler完全的解决了。同时对多维问题的研究也已经在进行中。在需要关于月球运动知识的驱动下,研究人员研究了太阳,地球和月亮构成的三体系统,并且月球理论很快就成为了早期研究的问题。在经典力学,量子力学和天文学中,三体问题是一个出名的,还没有解决的问题,它被Whittaker描述为在所有动力学问题中最出名的问题,Hilbert认为它是一个完美数学问题的标准。天体物理中的三体问题可以简单的被描述为:三个天体在他们之间的相互

3、之间的万有引力作用下,给出各个天体的初始条件,包括三个天体的质量、初始位置和初始速度,确定它们的后续运动,包括位置和速度随时间的变化。像许多数学问题一样,简单的问题声明后面往往覆盖了问题解决方法的复杂性。虽然一体和两体的问题能够以封闭的形式通过初等函数方式来解决,但是三体问题是一个复杂的线性问题,没有相似的解决方法存在。探究三体问题的方式大抵能够分为三类:第一类是分析方法,其基本原理是把天体的坐标和速度展开为时间或其它小参数的级数形式的近似解析表达式,讨论天体的坐标和轨道要素随时间的变化规律;第二类是定性方法,选用微分方程的定性理论来研究很长一段时间内三体运动的宏观运动规律和全局性质;第三类是

4、数值方法,这是直接依据微分方程的计算方式得出天体在特定时刻的详细位置和速度。这三类方法各有利弊。因为求解三体问题的困难在于它的不确定性和不可预测性,可以考虑计算机在迭代计算中的优势,选择第三类方法,基于受力分析和经典力学,求其数值解。1.2 论文相关的国内外动态及研究价值从三体问题被提出的300年间,人们只发现3族周期性特解。在十八和十九世纪,几乎所有著名的数学家们都曾试图解决这个问题,但是问题的进展不大。截止到目前为止,三体问题特解的族数被扩充到了16族。与此同时,在失败的尝试中,微分方程的理论不断地发展成为数学的一门更成熟的分支。作为一个能被简单描述的问题,除了其内在的吸引力,三体问题与太

5、阳系统稳定性有着密切的联系,这使得对三体系统的研究成为潜在的解决太阳系统稳定性问题的解决方案。多年来,人们对这个问题进行了大量的研究,从1750年到20世纪初,关于这个问题有800多篇援引了许多杰出的数学家和天文学家成果的论文发表。因此,除了解决一个重要的难题,更重要的是在解决问题的过程当中产生了好几种崭新的数学思想。这些数学理论的进步已经深入到不同的领域,包括近代动力学问题的理论。三体问题的研究加深了人们对天体运动的认识,激励了天体力学和数学物理的进一步成长,尤其是对人们研究太空火箭轨道和双星演变很有帮助。1.3 本文的研究内容本文决定通过计算机的数值运算,利用经典力学中的牛顿三大定律和万有

6、引力定律迭代求解天体运动中的三体问题。同时,本文利用MATLAB的GUI功能,设计出简洁友好的界面,并且通过动画的方法将天体的位置和速度在空间直角坐标系上实时的表示出来,作出了天体物理实验用计算机模拟来进行的尝试。1.4 本文的创新之处首先:通过理论与实践相结合的方式生动的展示了原本静态的文字概念。其次:通过MATLAB的GUI界面,可以让用户在不必了解程序内部实现的情况下,给出三个天体的初始条件,包括三个天体的质量、初始位置和初始速度,就可以知道随着时间的推移其宏观的位置和速度以及运动的宏观规律和全局性质。同时,还可以在不同的观察角度了解它们的运动过程。2 模型假设1) 忽略相对论效应的影响

7、;2) 不考虑其它天体对系统的作用,所处宇宙空间是各向同性的;3) 忽略宇宙空间粒子、潮汐力的影响;4) 假设运动过程中没有能量损失;5) 将天体视为质点,不考虑它们在运动的过程中彼此之间的相互碰撞;3 模型建立3.1 具体时刻的状态因为三个天体的位置和速度是随时间变化的,现在取很短的时间间隔t,假定这段时间间隔内系统参数没有变化,则可以考虑从系统每一时刻的状态计算后下一时刻的状态。在每一时刻,每一个天体都有各自的位置与速度,三个天体总共有六个未知量,每两个天体之间应用万有引力定律和牛顿第二定律可以列出两个方程,总共六个方程,这六个方程组成的方程组足可以求解这六个未知量。如果分割的时间间隔无限

8、小,则可以求出精确解,但是在现实中这是没法完成的。因此,我们可以将时间分成许多小部分,用计算机迭代求解,得到随时间变化的系统的各个参量和系统的末状态。3.2 受力分析如图3-1所示,每个天体都受到其他两个天体的万有引力作用。为方便计算,将天体1对天体2的作用,天体2对天体3的作用,天体3对天体1的作用分别按直角坐标系分解为f12x,f12y,f12z,f23x,f23y,f23z,f31x,f31y,f31z。由于f12=f21,f23=f32,f31=f13,可以用式子右边等效表示左边。在万有引力f12、f23、f31作用下,天体1、天体2、天体3的加速度分别为,。图3-1 三体问题受力分析

9、3.3 运动规律及迭代方程一、 万有引力定律二、 牛顿第二定律三、 速度迭代四、 位置迭代 求解时还须将加速度a,速度迭代方程,位置迭代方程按直角坐标系分解如附录1。 用计算机编程求解,即可得任意时刻三个天体的位置和速度。4 模型求解与系统仿真4.1 编码与运行(1)系统所需的软、硬件 系统所用的硬件是普通的PC机。本程序的编码和界面设计部分用MATLAB进行开发。(2)三体问题的编码1o三个天体各个参数的初始化部分。函数ThreeBodyProblem_OpeningFcn(hObject, eventdata, handles, varargin)是该程序的启动函数。初始化各个天体参数的部

10、分已在程序代码中标注:function ThreeBodyProblem_OpeningFcn(hObject, eventdata, handles, varargin)ThreeBodyProblem的创建函数,此函数没有返回值,详情请参见OutputFcnhObject 图形句柄eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,可以通过它获取整个界面的信息varargin ThreeBodyProblem 的启动参数(详情请参见 VARARGIN)初始化第一个天体的质量,位置和速度 handles.FirstBodyMData

11、 = 0;handles.FirstBodyXData = 0;handles.FirstBodyYData = 0;handles.FirstBodyZData = 0;handles.FirstBodyUData = 0;handles.FirstBodyVData = 0;handles.FirstBodyWData = 0;初始化第二个天体的质量,位置和速度 handles.SecondBodyMData = 0;handles.SecondBodyXData = 0;handles.SecondBodyYData = 0;handles.SecondBodyZData = 0;han

12、dles.SecondBodyUData = 0;handles.SecondBodyVData = 0;handles.SecondBodyWData = 0;初始化第三个天体的质量,位置和速度 handles.ThirdBodyMData = 0;handles.ThirdBodyXData = 0;handles.ThirdBodyYData = 0;handles.ThirdBodyZData = 0;handles.ThirdBodyUData = 0;handles.ThirdBodyVData = 0;handles.ThirdBodyWData = 0;handles.outp

13、ut = hObject;此前指令更改了handles,必须靠guidata指令才能把更新了的handles加以保存,以供后续使用guidata(hObject, handles);默认值按钮的回调函数,用于设置三个天体的默认参数值,并且将设置的默认参数值显示到图形界面上:function default_Callback(hObject, eventdata, handles)hObject default控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,可以通过它获取整个界面的信息(详情请参见G

14、UIDATA)在图形界面的第一个天体的文本输入框内显示默认的输入值,此输入值为太阳的参数。set(handles.FirstBodyM,String,19.89);set(handles.FirstBodyX,String,0);set(handles.FirstBodyY,String,0);set(handles.FirstBodyZ,String,0);set(handles.FirstBodyU,String,0);set(handles.FirstBodyV,String,0);set(handles.FirstBodyW,String,0);将太阳的参数保存为“GUI数据”形式,以

15、便共享handles.FirstBodyMData = 19.89*1029;handles.FirstBodyXData = 0;handles.FirstBodyYData = 0;handles.FirstBodyZData = 0;handles.FirstBodyUData = 0;handles.FirstBodyVData = 0;handles.FirstBodyWData = 0;在图形界面的第二个天体的文本输入框内显示默认的输入值,此输入值为地球的参数。set(handles.SecondBodyM,String,59.742);set(handles.SecondBody

16、X,String,14.960);set(handles.SecondBodyY,String,0);set(handles.SecondBodyZ,String,0);set(handles.SecondBodyU,String,0);set(handles.SecondBodyV,String,29.78);set(handles.SecondBodyW,String,0);将地球的参数保存为“GUI数据”形式,以便共享handles.SecondBodyMData = 59.742*1023;handles.SecondBodyXData = 14.960*1010;handles.Se

17、condBodyYData = 0;handles.SecondBodyZData = 0;handles.SecondBodyUData = 0;handles.SecondBodyVData = 29.78*103;handles.SecondBodyWData = 0;在图形界面的第三个天体的文本输入框内显示默认的输入值,此输入值为月球的参数。set(handles.ThirdBodyM,String,0.7349);set(handles.ThirdBodyX,String,14.9984);set(handles.ThirdBodyY,String,0);set(handles.Th

18、irdBodyZ,String,0);set(handles.ThirdBodyU,String,0);set(handles.ThirdBodyV,String,33.7953);set(handles.ThirdBodyW,String,0); 将月球的参数保存为“GUI数据”形式,以便共享handles.ThirdBodyMData = 0.7349*1023;handles.ThirdBodyXData = 14.9984*1010;handles.ThirdBodyYData = 0;handles.ThirdBodyZData = 0;handles.ThirdBodyUData

19、= 0;handles.ThirdBodyVData = 33.7953*103;handles.ThirdBodyWData = 0;此前指令更改了handles,必须靠guidata指令才能把更新了的handles加以保存,以供后续使用guidata(hObject,handles);2o从文本输入框中按顺序输入三个天体的各个参数。第一个天体的各个文本输入框的回调函数,用于获得文本输入框内输入的值,代码的具体解释已在程序中给出:function FirstBodyX_Callback(hObject, eventdata, handles)hObject FirstBodyX 控件的句柄(

20、详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,可以通过它获取整个界面的信息(详情请参见GUIDATA)获得当前输入框的输入字符tempData=get(hObject,String);将字符转换为双精度数handles.FirstBodyXData=str2double(tempData)*1010;此前指令更改了handles,必须靠guidata指令才能把更新了的handles加以保存,以供后续使用guidata(hObject,handles);设置完所有属性后,在对象的创建过程中执行以下代码func

21、tion FirstBodyX_CreateFcn(hObject, eventdata, handles)hObject FirstBodyX 控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,它会在调用完所有的CreateFcn函数后创建提示: 可编辑文本框控件通常在窗口上有一个白色的背景,更多详情请参见ISPC 和COMPUTER.if ispc & isequal(get(hObject,BackgroundColor), get(0,defaultUicontrolBackgroundCo

22、lor) set(hObject,BackgroundColor,white);endfunction FirstBodyY_Callback(hObject, eventdata, handles)hObject FirstBodyY控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,可以通过它获取整个界面的信息(详情请参见GUIDATA)获得当前输入框的输入字符tempData=get(hObject,String);将字符转换为双精度数handles.FirstBodyYData=str2dou

23、ble(tempData)*1010;此前指令更改了handles,必须靠guidata指令才能把更新了的handles加以保存,以供后续使用guidata(hObject,handles);设置完所有属性后,在对象的创建过程中执行以下代码function FirstBodyY_CreateFcn(hObject, eventdata, handles)hObject FirstBodyY 控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,它会在调用完所有的CreateFcn函数后创建提示: 可编辑

24、文本框控件通常在窗口上有一个白色的背景,更多详情请参见ISPC和COMPUTER.if ispc & isequal(get(hObject,BackgroundColor), get(0,defaultUicontrolBackgroundColor) set(hObject,BackgroundColor,white);endfunction FirstBodyZ_Callback(hObject, eventdata, handles)hObject FirstBodyZ控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用han

25、dles GUI界面的句柄,可以通过它获取整个界面的信息(详情请参见GUIDATA)获得当前输入框的输入字符tempData=get(hObject,String);将字符转换为双精度数handles.FirstBodyZData=str2double(tempData)*1010;此前指令更改了handles,必须靠guidata指令才能把更新了的handles加以保存,以供后续使用guidata(hObject,handles);设置完所有属性后,在对象的创建过程中执行以下代码function FirstBodyZ_CreateFcn(hObject, eventdata, handles

26、)hObject FirstBodyZ 控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,它会在调用完所有的CreateFcn函数后创建提示: 可编辑文本框控件通常在窗口上有一个白色的背景,更多详情请参见ISPC 和COMPUTER.if ispc & isequal(get(hObject,BackgroundColor), get(0,defaultUicontrolBackgroundColor) set(hObject,BackgroundColor,white);endfunction F

27、irstBodyU_Callback(hObject, eventdata, handles)hObject 控件的句柄(详情请参见 GCBO)FirstBodyUeventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,可以通过它获取整个界面的信息(详情请参见GUIDATA)获得当前输入框的输入字符tempData=get(hObject,String);将字符转换为双精度数handles.FirstBodyUData=str2double(tempData)*103;此前指令更改了handles,必须靠guidata指令才能把更新了的h

28、andles加以保存,以供后续使用guidata(hObject,handles);设置完所有属性后,在对象的创建过程中执行以下代码function FirstBodyU_CreateFcn(hObject, eventdata, handles)设置完所有属性后,在对象的创建过程中执行以下代码function FirstBodyX_CreateFcn(hObject, eventdata, handles)hObject FirstBodyU 控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,它会

29、在调用完所有的CreateFcn函数后创建提示: 可编辑文本框控件通常在窗口上有一个白色的背景,更多详情请参见ISPC 和COMPUTER.if ispc & isequal(get(hObject,BackgroundColor), get(0,defaultUicontrolBackgroundColor) set(hObject,BackgroundColor,white);endfunction FirstBodyV_Callback(hObject, eventdata, handles)hObject FirstBodyV控件的句柄(详情请参见 GCBO)eventdata 保留在

30、MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,可以通过它获取整个界面的信息(详情请参见GUIDATA)获得当前输入框的输入字符tempData=get(hObject,String);将字符转换为双精度数handles.FirstBodyVData=str2double(tempData)*103;此前指令更改了handles,必须靠guidata指令才能把更新了的handles加以保存,以供后续使用guidata(hObject,handles);设置完所有属性后,在对象的创建过程中执行以下代码function FirstBodyV_CreateFcn

31、(hObject, eventdata, handles)hObject FirstBodyV 控件的句柄(详情请参见 GCBO)eventdata 保留在MATLAB里面的参数,它的作用是方便后面的程序使用handles GUI界面的句柄,它会在调用完所有的CreateFcn函数后创建提示: 可编辑文本框控件通常在窗口上有一个白色的背景,更多详情请参见ISPC 和COMPUTER.if ispc & isequal(get(hObject,BackgroundColor), get(0,defaultUicontrolBackgroundColor) set(hObject,BackgroundColor,white);endfunction FirstBodyW_Callback(hObje

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1