Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Python_超人
宇宙模拟器
提交
34a84a14
宇宙模拟器
项目概览
Python_超人
/
宇宙模拟器
通知
19
Star
2
Fork
0
代码
文件
提交
分支
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看板
提交
34a84a14
编写于
7月 06, 2023
作者:
三月三net
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Python超人-宇宙模拟器
上级
e5ae9d23
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
60 addition
and
0 deletion
+60
-0
sim_lab/bodies_gravity_sim.py
sim_lab/bodies_gravity_sim.py
+60
-0
未找到文件。
sim_lab/bodies_gravity_sim.py
0 → 100644
浏览文件 @
34a84a14
# -*- coding:utf-8 -*-
# title :验证万有引力(为什么旋转的球体会导致被吸引天体轨道偏转)
# description :太验证万有引力(为什么旋转的球体会导致被吸引天体轨道偏转)
# author :Python超人
# date :2023-07-06
# link :https://gitcode.net/pythoncr/
# python_version :3.8
# ==============================================================================
from
bodies
import
Sun
,
Moon
from
common.consts
import
SECONDS_PER_WEEK
,
SECONDS_PER_DAY
,
AU
from
sim_scenes.func
import
mayavi_run
,
ursina_run
import
numpy
as
np
def
ignore_gravity_with
(
body
):
if
isinstance
(
body
,
Sun
):
return
True
return
False
def
create_circle_bodies
(
radius
):
bodies
=
[]
for
i
in
range
(
0
,
360
,
30
):
# 当前天数的角度(弧度)
angle
=
i
*
np
.
pi
/
180
# 计算月亮的坐标(这里没有用到万有引力)
px
=
radius
*
np
.
cos
(
angle
)
pz
=
radius
*
np
.
sin
(
angle
)
body
=
Sun
(
size_scale
=
1e-3
,
init_velocity
=
[
0
,
0
,
0
],
init_position
=
[
px
,
0
,
pz
],
# ignore_mass=True,
rotation_speed
=
0
)
body
.
ignore_gravity_with
=
ignore_gravity_with
bodies
.
append
(
body
)
return
bodies
if
__name__
==
'__main__'
:
"""
太阳、地球
"""
bodies
=
create_circle_bodies
(
100000
)
bodies
.
append
(
Moon
(
size_scale
=
100
,
init_position
=
[
0
,
0
,
500000000
],
init_velocity
=
[
0
,
0
,
0
],
# ignore_mass=True,
))
# bodies = [
# Sun(size_scale=5e1), # 太阳放大 50 倍
# Earth(size_scale=2e3, distance_scale=1), # 地球放大 2000 倍,距离保持不变
# ]
# 使用 mayavi 查看的运行效果
# mayavi_run(bodies, SECONDS_PER_WEEK, view_azimuth=-45)
# 使用 ursina 查看的运行效果
# 常用快捷键: P:运行和暂停 O:重新开始 I:显示天体轨迹
# position = 左-右+、上+下-、前+后-
ursina_run
(
bodies
,
SECONDS_PER_DAY
,
position
=
(
0
,
0
,
0
),
show_trail
=
True
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录