利用matlab仿真两星球之间的万有引力运动_星间切换时延matlab-程序员宅基地

技术标签: matlab  开发语言  

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

看三体电视剧时,突然有了一个想法,想用matlab建模进行模拟仿真三体中三体星球和三体星球附近的三个太阳乱序的关系,主要利用万有引力公式进行建模。


一、目前进行阶段

目前只完成了两个星球的运动仿真,例如地球和月球的运动仿真,参数是随便写的。

二、matlab仿真

1.代码

代码如下(示例):

clc;
clear;
ts=0.1;%时间间隔
t=0:ts:1000;%仿真时长
%两个星球参数
h1=animatedline('Color','r','Marker','o','MaximumNumPoints',1,'MarkerSize',10,MarkerFaceColor='r');
h2=animatedline('Color','b','Marker','o','MaximumNumPoints',1,'MarkerSize',20,MarkerFaceColor='b');
axis([-500,500,-500,500,-500,500]);
grid on;
m1=1000;%月球质量
m2=81000;%地球质量
G=1;    %引力常量
%初始位置
x1=-200;
y1=-200;
z1=200;
x2=0;
y2=0;
z2=0;
%初始速度
vx1=-12;vy1=12;vz1=-1;
vx2=0;vy2=0;vz2=0;
%三维观看
view(-37.5,30);
%进行仿真
for i=1:length(t)
    
r=sqrt((y1-y2)*(y1-y2)+(x1-x2)*(x1-x2)+(z1-z2)*(z1-z2));%两星球距离
%坐标系两个角度alfa、beta
alfa=atan((y1-y2)/(x1-x2));
if alfa<0
    alfa=alfa+pi;
end
beta=atan((z1-z2)/(sqrt((y1-y2)*(y1-y2)+(x1-x2)*(x1-x2))));
%万有引力公式求加速度
%F=G*m1*m2/r=m1*a1=m2*a2;
    a1=G*m1*m2/(r*r*m1);
    a2=G*m1*m2/(r*r*m2);
%对加速度在xyz轴进行分解
if y1>y2
    ax1=-a1*cos(alfa)*cos(beta);ay1=-a1*sin(alfa)*cos(beta);
    ax2=a2*cos(alfa)*cos(beta);ay2=a2*sin(alfa)*cos(beta);
    az1=-a1*sin(beta);
    az2=a2*sin(beta);
else
    ax1=a1*cos(alfa)*cos(beta);ay1=a1*sin(alfa)*cos(beta);
    ax2=-a2*cos(alfa)*cos(beta);ay2=-a2*sin(alfa)*cos(beta);
    az1=-a1*sin(beta);
    az2=a2*sin(beta);
end
%速度分解求解
vx1=vx1+ax1*ts; vy1=vy1+ay1*ts;vz1=vz1+az1*ts;
vx2=vx2+ax2*ts; vy2=vy2+ay2*ts;vz2=vz2+az2*ts;
%位移分解求解
x1=x1+vx1*ts;y1=y1+vy1*ts;z1=z1+vz1*ts;
x2=x2+vx2*ts;y2=y2+vy2*ts;z2=z2+vz2*ts;
%瞄点画图
addpoints(h1,x1,y1,z1);
addpoints(h2,x2,y2,z2);
drawnow;
end

2.仿真结果

在这里插入图片描述


总结

完成两个星球运动的三维仿真,下步完成三个星球之间受万有引力影响的运动的仿真。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_48767862/article/details/128744433

智能推荐

【转载南非蚂蚁】MYSQL企业常用架构与调优经验分享-程序员宅基地

文章浏览阅读63次。http://ixdba.blog.51cto.com/blog/2895551/1751377 好文章,防止以后找不到了,先转载一份过来。 转载于:https://blog.51cto.com/lee90/1757425

IntelliJ IDEA设置代码自动提示的快捷键_idea开启自动提示 快捷键-程序员宅基地

文章浏览阅读6k次,点赞8次,收藏6次。前言:使用 eclipse 都习惯使用快捷键ALT+/ 来代码自动提示,后来使用IntelliJ Idea这个快捷键并不管用,十分不便,这里记录如何使更改idea代码自动提示快捷键。打开Settings设置 [ 快捷键 Ctrl + Alt + S ]File ––> Settings ––> KeyMap进入快捷键设置界面。idea中默认的代码自动提示快捷键是Basic Ctrl + 空格(可以再搜索框中输入 basic快速查找),这个和安装的中文输入法切换快捷键冲突,所以需要修改._idea开启自动提示 快捷键

字符4串my_atoi_while (*psz != '\0' && *psz != 0x0d && *psz != 0x0-程序员宅基地

文章浏览阅读608次。//#include //#include //#include //int my_atoi(const char *psz);//int main()//{// char str[] = " -23j1";// int a = my_atoi(str);// printf("%d\n",a);// return 0;//}////int my__while (*psz != '\0' && *psz != 0x0d && *psz != 0x0a)

你不知道的Echarts柱状图应用在React中_react柱状图怎么给series赋值-程序员宅基地

文章浏览阅读943次。echarts 柱状图在React里面的运用:正常的echarts 都是竖直型的,或者一个里边包含多个的。 这次做个不同的, y轴为坐标,x轴为值,左右都为正数展开。(1)、引入相关的文件import React, { Compoent } from 'react';import { Spin } from 'antd';import echarts from 'echarts'..._react柱状图怎么给series赋值

Uncaught TypeError: Cannot read property 'addMethod' of undefined_uncaught typeerror: cannot read properties of unde-程序员宅基地

文章浏览阅读6.4k次,点赞4次,收藏2次。目录1:js 引入顺序2:‘$’ 冲突出现以上错误有俩种情况:1:js 引入顺序jquery.validate.js 引入的顺序一定要在执行$.validator.addMethod()之前引入。解决方案:保证 jquery.validate.js 优先引入。2:‘$’ 冲突当前 .html 文件引用函数 $.validator.addMethod() ,明明引入..._uncaught typeerror: cannot read properties of undefined (reading 'addmethod

随便推点

邮件群发,如何选择最好用的电子邮箱?_群发邮件邮箱评比-程序员宅基地

文章浏览阅读1.4k次。偶然看到有人在如何选择最适合、最好用的群发邮箱?恰巧最近我接触到了一款很好的邮箱~TOM VIP邮箱,在此分享给各位~邮件群发,如何选择最好用的电子邮箱?首先,TOM VIP邮箱拥有十多年邮件系统研发和服务经验,超高送达率,发qq,发163,发国外,发国内,发外贸迅速抵达。同时,就其35位靓号的稀有性来讲就比较赞。目前多数邮箱靓号也是有的,但是35位这种超短靓号还是比较稀缺的,更遑论豹子号..._群发邮件邮箱评比

浅谈电商场景中的扣除库存问题_如果支付时扣库存,有什么问题-程序员宅基地

文章浏览阅读1.1k次,点赞14次,收藏23次。电商场景中扣库存需要考虑秒杀高并发、事务一致性等场景,需要根据业务和场景来选择不同的方案。_如果支付时扣库存,有什么问题

c++笔试题(带答案)值得我们一看_c++题目描述有这样一个四位数,其千位和百位之和为偶数,十位和个位之和为奇数,-程序员宅基地

文章浏览阅读3.8k次。C++笔试题目大全(笔试宝典)(不断完善中) 收藏 (转)1.new 、 delete 、 malloc 、 free 关系 delete 会调用对象的析构函数 , 和 new 对应 free 只会释放内存, new 调用构造函数。 malloc 与 free 是 C++/C 语言的标准库函数, new/delete 是 C++ 的运算符。它们都可用于申请动态内存和释放内存。对于非内部数据类型的对象而言,光用 maloc/free 无法满足动态对象的要求。对象_c++题目描述有这样一个四位数,其千位和百位之和为偶数,十位和个位之和为奇数,

基于OHCI的USB主机 —— USB设备设置地址-程序员宅基地

文章浏览阅读135次。设置地址设置地址需要注意的是该命令只能从地址0、端口0发送,等到执行成功以后,需要设置协议栈对象的usbAddr为新的地址,以后所有命令的收发都只能通过新地址进行:/***给USB设备设置地址*/shortusbSetAddress(unsignedchar*pDataBuf,unsignedshorta..._usb主机 设置地址

JVM-性能调优-3-运行时参数_jvm jit xmixed-程序员宅基地

文章浏览阅读85次。官网地址:https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html1.JVM参数选项类型类型一:标准参数选项特点:比较稳定,后续版本基本不会变化,以-开头各种选项:运行java或者java -help可以看到所有的标准选项类型二:-X参数选项特点:非标准化参数,功能还是比较稳定的。但是官方说后续版本可能会变更,以-X开头。各种选项:运行java -X命令可以看到所有的X选项。JVM的JIT编译模式相关的选_jvm jit xmixed

AO4805&19-VB一种2个P沟道SOP8封装MOS管-程序员宅基地

文章浏览阅读374次,点赞11次,收藏8次。5. **开态电阻 (On-State Resistance):** RDS(ON) = 21mΩ @ VGS=10V, VGS=12V,说明在特定的栅源电压下,开态时的电阻。6. **阈值电压 (Threshold Voltage):** Vth = -1.8V,表示在栅源电压作用下,器件从关态切换到开态所需的最小电压。4. **最大电流 (Maximum Current):** -8.5A,表示器件能够承受的最大电流,负号表示电流方向为从漏极到源极。- 阈值电压: Vth = -1.8V。

推荐文章

热门文章

相关标签