Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Python_超人
太阳系三体模拟器
提交
137b4388
太阳系三体模拟器
项目概览
Python_超人
/
太阳系三体模拟器
通知
1139
Star
132
Fork
129
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
太阳系三体模拟器
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
137b4388
编写于
3月 19, 2023
作者:
三月三net
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
太阳系三体模拟器
上级
52574dec
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
223 addition
and
1 deletion
+223
-1
data/tri_bodies_sim_perfect_02.json
data/tri_bodies_sim_perfect_02.json
+81
-0
data/tri_bodies_sim_perfect_03.json
data/tri_bodies_sim_perfect_03.json
+81
-0
scenes/tri_bodies_sim_perfect.py
scenes/tri_bodies_sim_perfect.py
+56
-0
scenes/ursina_json_sim.py
scenes/ursina_json_sim.py
+5
-1
未找到文件。
data/tri_bodies_sim_perfect_02.json
0 → 100644
浏览文件 @
137b4388
{
"bodies"
:
[
{
"name"
:
"红轨太阳A"
,
"mass"
:
2e+30
,
"init_position"
:
[
0.0
,
518222240.0
,
0.0
],
"init_velocity"
:
[
-14.890000343322754
,
0.0
,
0.0
],
"density"
:
1408.0
,
"color"
:
[
255
,
0
,
0
],
"texture"
:
"sun2.jpg"
,
"size_scale"
:
50.0
,
"distance_scale"
:
1.0
},
{
"name"
:
"绿轨太阳B"
,
"mass"
:
2e+30
,
"init_position"
:
[
-299195744.0
,
0.0
,
0.0
],
"init_velocity"
:
[
7.445000171661377
,
-12.895118713378906
,
0.0
],
"density"
:
1408.0
,
"color"
:
[
0
,
255
,
0
],
"texture"
:
"sun2.jpg"
,
"size_scale"
:
50.0
,
"distance_scale"
:
1.0
},
{
"name"
:
"蓝轨太阳C"
,
"mass"
:
2e+30
,
"init_position"
:
[
299195744.0
,
0.0
,
0.0
],
"init_velocity"
:
[
7.445000171661377
,
12.895118713378906
,
0.0
],
"density"
:
1408.0
,
"color"
:
[
0
,
0
,
255
],
"texture"
:
"sun2.jpg"
,
"size_scale"
:
50.0
,
"distance_scale"
:
1.0
}
],
"params"
:
{
"dt"
:
31536000
,
"position"
:
[
0
,
149597870.7
,
-1495978707.0
]
}
}
\ No newline at end of file
data/tri_bodies_sim_perfect_03.json
0 → 100644
浏览文件 @
137b4388
{
"bodies"
:
[
{
"name"
:
"红轨太阳A"
,
"mass"
:
2e+30
,
"init_position"
:
[
0.0
,
518222240.0
,
0.0
],
"init_velocity"
:
[
-14.890000343322754
,
0.0
,
0.0
],
"density"
:
1408.0
,
"color"
:
[
255
,
0
,
0
],
"texture"
:
"sun2.jpg"
,
"size_scale"
:
50.0
,
"distance_scale"
:
1.0
},
{
"name"
:
"绿轨太阳B"
,
"mass"
:
2e+30
,
"init_position"
:
[
-299195744.0
,
0.0
,
0.0
],
"init_velocity"
:
[
7.445000171661377
,
-12.895118713378906
,
0.0
],
"density"
:
1408.0
,
"color"
:
[
0
,
255
,
0
],
"texture"
:
"sun2.jpg"
,
"size_scale"
:
50.0
,
"distance_scale"
:
1.0
},
{
"name"
:
"蓝轨太阳C"
,
"mass"
:
2e+30
,
"init_position"
:
[
299195744.0
,
0.0
,
0.0
],
"init_velocity"
:
[
7.445000171661377
,
12.895118713378906
,
0.0
],
"density"
:
1408.0
,
"color"
:
[
0
,
0
,
255
],
"texture"
:
"sun2.jpg"
,
"size_scale"
:
50.0
,
"distance_scale"
:
1.0
}
],
"params"
:
{
"dt"
:
31536000
,
"position"
:
[
0
,
149597870.7
,
-1495978707.0
]
}
}
\ No newline at end of file
scenes/tri_bodies_sim_perfect.py
0 → 100644
浏览文件 @
137b4388
# -*- coding:utf-8 -*-
# title :三体场景模拟01
# description :三体场景模拟(3个太阳、1个地球)
# author :Python超人
# date :2023-02-11
# link :https://gitcode.net/pythoncr/
# python_version :3.8
# ==============================================================================
from
bodies
import
Sun
,
Earth
from
common.consts
import
SECONDS_PER_WEEK
,
SECONDS_PER_DAY
,
AU
,
SECONDS_PER_MONTH
,
SECONDS_PER_YEAR
from
scenes.func
import
mayavi_run
,
ursina_run
if
__name__
==
'__main__'
:
"""
3个太阳、1个地球(效果1)
可以修改影响效果的参数为:
1、三个方向的初始位置 init_position[x, y, z]
2、三个方向的初始速度 init_velocity[x, y, z]
3、天体质量 mass
"""
import
math
mass
=
2e30
r
=
2
*
AU
# p = 12 # 三体转圆形花
p
=
14.88
# 三体转圈近似圆形
# p = 16 # 三体转圆形花
# p = 18 # 三体转圆形花
# p = 19 # 三体转圆形花
bodies
=
[
Sun
(
name
=
"红轨太阳A"
,
mass
=
mass
,
init_position
=
[
0
,
math
.
sqrt
(
3
)
*
r
,
0
],
init_velocity
=
[
-
p
,
0
,
0
],
color
=
(
255
,
0
,
0
),
size_scale
=
5e1
,
texture
=
"sun2.jpg"
),
# 太阳放大 100 倍
Sun
(
name
=
"绿轨太阳B"
,
mass
=
mass
,
init_position
=
[
-
r
,
0
,
0
],
init_velocity
=
[
1
/
2
*
p
,
-
math
.
sqrt
(
3
)
/
2
*
p
,
0
],
color
=
(
0
,
255
,
0
),
size_scale
=
5e1
,
texture
=
"sun2.jpg"
),
# 太阳放大 100 倍
Sun
(
name
=
"蓝轨太阳C"
,
mass
=
mass
,
init_position
=
[
r
,
0
,
0
],
init_velocity
=
[
1
/
2
*
p
,
math
.
sqrt
(
3
)
/
2
*
p
,
0
],
color
=
(
0
,
0
,
255
),
size_scale
=
5e1
,
texture
=
"sun2.jpg"
),
# 太阳放大 100 倍
# Earth(init_position=[0, -349597870.700, 0],
# init_velocity=[15.50, 0, 0],
# size_scale=4e3, distance_scale=1), # 地球放大 4000 倍,距离保持不变
]
# 使用 mayavi 查看的运行效果
# mayavi_run(bodies, SECONDS_PER_WEEK, view_azimuth=0)
# 使用 ursina 查看的运行效果
# 常用快捷键: P:运行和暂停 O:重新开始 I:显示天体轨迹
# position = 左-右+、上+下-、前+后-
ursina_run
(
bodies
,
SECONDS_PER_YEAR
,
position
=
(
3
*
AU
,
AU
,
-
4
*
AU
))
scenes/ursina_json_sim.py
浏览文件 @
137b4388
...
@@ -18,8 +18,12 @@ if __name__ == '__main__':
...
@@ -18,8 +18,12 @@ if __name__ == '__main__':
# bodies, params = Body.build_bodies_from_json('../data/sun_earth.json')
# bodies, params = Body.build_bodies_from_json('../data/sun_earth.json')
# TODO: 去掉注释,在地球上看月相演示变化过程演示
# TODO: 去掉注释,在地球上看月相演示变化过程演示
# bodies, params = Body.build_bodies_from_json('../data/sun_earth_moon.json')
# bodies, params = Body.build_bodies_from_json('../data/sun_earth_moon.json')
# TODO: 去掉注释,完美数据的三体模型的演示01
# TODO: 去掉注释,完美数据的三体模型的演示01
(等边三角形)
# bodies, params = Body.build_bodies_from_json('../data/tri_bodies_sim_perfect_01.json')
# bodies, params = Body.build_bodies_from_json('../data/tri_bodies_sim_perfect_01.json')
# TODO: 去掉注释,完美数据的三体模型的演示02(等边三角形)
# bodies, params = Body.build_bodies_from_json('../data/tri_bodies_sim_perfect_02.json')
# TODO: 去掉注释,完美数据的三体模型的演示03(等边三角形)
bodies
,
params
=
Body
.
build_bodies_from_json
(
'../data/tri_bodies_sim_perfect_03.json'
)
# TODO: 去掉注释,引力弹弓的演示
# TODO: 去掉注释,引力弹弓的演示
# bodies, params = Body.build_bodies_from_json('../data/gravity_slingshot.json')
# bodies, params = Body.build_bodies_from_json('../data/gravity_slingshot.json')
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录