procyon.py 2.1 KB
Newer Older
三月三net's avatar
三月三net 已提交
1 2 3 4 5 6 7 8
# -*- coding:utf-8 -*-
# title           :北河三
# description     :北河三
# author          :Python超人
# date            :2023-02-11
# link            :https://gitcode.net/pythoncr/
# python_version  :3.8
# ==============================================================================
三月三net's avatar
三月三net 已提交
9
from bodies import FixedStar, Sun
三月三net's avatar
三月三net 已提交
10 11 12 13 14
from common.consts import MO


class Procyon(FixedStar):
    """
三月三net's avatar
三月三net 已提交
15
    TODO: 南河三(Procyon)
三月三net's avatar
三月三net 已提交
16 17 18 19
    质量:1.5太阳质量
    密度:1.8 g/cm³
    颜色值:#F5E8D5
    直径:1.84倍太阳直径
三月三net's avatar
三月三net 已提交
20 21

    中文名南河三外文名Procyon别    名小犬座α分    类恒星发现者未知发现时间史前视星等约0.34绝对星等约2.67赤    经7时39分18.1秒赤    纬+5°13′29″距地距离约 11.46 光年半长轴1.18"离心率0.36轨道倾角31.9 度年    龄约1.7×1000000000年星表编号HIP 37279光谱类型F5 IV-V星    座小犬座星    官南河(井宿,朱雀)
三月三net's avatar
三月三net 已提交
22 23 24 25 26 27 28
    ------------------------
    == 太阳参数 ==
    自转周期: 24.47 地球日,自转角速度约为 0.6130 度/小时 = 360/(24.47*24)
    天体质量: 1.9891×10³⁰ kg
    平均密度: 1.408×10³ kg/m³
    """

三月三net's avatar
三月三net 已提交
29
    def __init__(self, name="南河三", mass=1.5 * MO,
三月三net's avatar
三月三net 已提交
30 31 32 33 34 35 36 37 38 39
                 init_position=[0, 0, 0],
                 init_velocity=[0, 0, 0],
                 color=(0xF5, 0xE8, 0xD5),
                 texture="fixed_star.png", size_scale=1.0, distance_scale=1.0,
                 rotation_speed=0.1, ignore_mass=False):
        params = {
            "name": name,
            "mass": mass,
            "init_position": init_position,
            "init_velocity": init_velocity,
三月三net's avatar
三月三net 已提交
40
            "density": 0.5e3,
三月三net's avatar
三月三net 已提交
41 42 43 44 45 46 47 48 49 50 51
            "color": color,
            "texture": texture,
            "size_scale": size_scale,
            "distance_scale": distance_scale,
            "rotation_speed": rotation_speed,
            "ignore_mass": ignore_mass
        }
        super().__init__(**params)


if __name__ == '__main__':
三月三net's avatar
三月三net 已提交
52 53 54 55 56
    fixed_star = Procyon()
    sun = Sun()
    print(fixed_star)
    print("质量倍数", fixed_star.mass / sun.mass)
    print("半径倍数", fixed_star.raduis / sun.raduis)