about summary refs log blame commit diff
path: root/src/stage.py
blob: e1f6b04ff5575f032e2784a4e393b0c1fb146814 (plain) (tree)
1
2
3
4
5
6
7
8
9
10

           



                         
                                                                                                                                                                                                                                                                                         
                        

                                    
                                           

                                  



                                                            
        
                                                                    
                                                                                            





                                                 
                                                                       
                                                   
                                                                                    



                                                                                     
                                       
             
                         





                                                                                    
 


                                                                       




                                                   
import math

from engine import Engine
from fuel import Fuel

class Stage():
    def __init__(self, name: str, stage_mass: int, engine: type[Engine], engine_number: int, max_engine_gimbaling_angle: int, fuel_type: type[Fuel], fuel_mass: int, x_drag_coefficient: float, x_cross_sectional_area: float, y_drag_coefficient: float, y_cross_sectional_area: float):
        self.name = name
        self.stage_mass = stage_mass
        self.engine = engine
        self.engine_number = engine_number 
        self.fuel_type = fuel_type
        self.fuel_mass = fuel_mass
        self.x_drag_coefficient = x_drag_coefficient
        self.x_cross_sectional_area = x_cross_sectional_area
        self.y_drag_coefficient = y_drag_coefficient
        self.y_cross_sectional_area = y_cross_sectional_area
        
        self.max_engine_gimbaling_angle = max_engine_gimbaling_angle
        self.gimbal = 0 #one thing is gimbal another is rocket angle (TODO TOODODODODODODOD)
        self.throttle = 100
        self.engines_on = False

    def total_mass(self):
        return (self.stage_mass + self.fuel_mass)

    def current_thrust(self, g: float, heading: int) -> (float, float):
        if(self.engines_on and self.fuel_mass > 0):
            total_thrust = self.engine.thrust(self.throttle, g) * self.engine_number
            #gimbal and heading components
            thrust_x = (math.sin(math.radians(self.gimbal + heading)) * total_thrust)
            thrust_y = (math.cos(math.radians(self.gimbal + heading)) * total_thrust)

            return (thrust_x, thrust_y)
        else:
            return (0, 0)

    def total_fuel_used(self, delta: int):
        if(self.engines_on):
            return self.engine.flow_rate(self.throttle) * self.engine_number * delta
        else:
            return 0

    def convert_y_component_to_total_with_gimbal(self, y_value):
        return math.fabs(y_value / math.cos(math.radians(self.gimbal)))

    #total drag coefficient is just the upper stage
    #engines on is just the lower stage
    #thrust is just the lower stage
    #fuel used is just lower stage
    #when stage separation lower stage jetissoned