This is a Model Rocket Simulator oriented towards active stabilization. It integrates the Three Degree of Freedom Equations of Motion, allowing to tune controllers used in Model Rockets. There is pre-coded controller in the file src/control.py, one can use it or run the Flight Computer's software through Software in the Loop.
Video.Example.TVC.mp4
The program computes the 3DoF Equations of Motion of the Rocket and integrates their result with the trapezoidal rule. The Aerodynamic Coefficients are calculated using the same Extended Barrowman Equations that Open Rocket uses (plus some modifications). The fins' forces are computed with interpolated wind tunnel data and Diederich's Semi-Empirical Method to accurately model the behaviour for every aspect ratio and angle of attack. The program also allows for fins separated from the body. More information can be found in the technical documentation or inside src/simulation/main_simulation.py, src/aerodynamics/rocket_functions.py or src/aerodynamics/fin_aerodynamics.py
- tkinter
- numpy
- scipy
- matplotlib
- pandas
- vpython
- pyserial
Without the optional dependencies, the Software in the Loop module will not work.
If someone can make an .exe that works with VPython, please let me know.
The setup of the rocket is fairly simple. However, the program is not meant for designing the rocket. Open Rocket is a more comfortable option.
To run the program, run AeroVECTOR.py. The program will open in the file tab.
One can create a new file or open an existing one. Once a file is open, a copy can be created with the Save As button.
In case of using the Python SITL module, it is recommended to save each file in a different folder since the modules can only be loaded from the SITL Modules folder located in the directory of the .txt save file, as in the examples. The SITL Modules and SITL Modules/Complementary Modules folders are created automatically when creating a new file and, in case of using the Save as command, the contents of the original modules are also copied to the new location.
One must fill the required parameters of the rocket. New motors can be added in the motors folder.
- Iy Liftoff/Burnout are the wet and dry pitching moment of inertia.
- Xcg Liftoff/Burnout are the position of the wet and dry Center of Gravity.
- Xt is the position of the TVC mount. If one is using fins, the program automatically calculates the force application point.
- All distances are measured from the tip of the nose cone.
- The Servo Resolution is the minimum angle it can rotate.
- The Max Actuator Angle is the maximum angle the actuator can move (either the TVC mount or the fin).
- The Actuator Reduction is the gear ratio between the servo and the actuator.
- The code multiplies the output of the controller times the Actuator Reduction, and then sends that output to the SERVO (not the mount). Remember that you have to multiply the output of the controller times the Actuator Reduction in you flight computer!
- The Initial Misalignment only modifies the initial angle of the TVC mount or Active Fin.
- The Servo Velocity Compensation slows down the servo according to the load, its value is 1.45 for an SG90 without load, and 2.1 with a TVC mount. The servo class found in servo_lib.py has a test method to modify this value to fit one's servo.
- The wind is positive from right to left, and the gusts follow a Gaussian distribution.
- The effective launch rod length is the length at which the rocket can pitch somewhat freely.
- Angle of the launch rod.
- The Motor Misalignment sets the motor at an angle (mainly for active fin control).
- The roughness applies to all the components of the body and fins; therefore, a little tuning might be required to get the performances right.
Please do not leave blank entries
THE SAVE BUTTON SAVES ONLY THE CURRENT TAB, BE SURE TO CLICK IT ON ALL OF THEM
To draw the rocket, one must insert the point as coordinate from the nose cone tip, diameter in that point. With the Add Point button, one adds the point written in the entry. The Delete Point button deletes the point currently selected in the combo box. To modify a point, one has to select the desired point in the combo box, click the Select Point button, write the new coordinates in the entry, and at last, click the Modify Point button.
To draw the fins, one must insert the position and chord of the root and tip, separated by comma. The wingspan is measured from the root to the tip.
All dimensions are in meters.
The order is the following:
Only trapezoidal fins are modelled.
After the points are written in the entries, one can either update the stabilization or control fin. Clicking the Load "" Fins button will fill the entries with the current data of the fin. The button Reset Fin sets the fin entries to a zero-area fin.
WARNING: THE USE OF CONTROL FINS DISABLES THE TVC STABILIZATION.
Examples of detached fins: Sprint - BPS.space, and our own Roll Control System Testbed
The space between the body and the fin must be considerable, if one is unsure about a fin being attached or detached, the most conservative option is the right option.
The Angle of Attack slider allows to change the AoA at which the CP (red point) is calculated. The blue point represents the CG of the rocket. One can enable and disable the fins to quickly redraw the rocket and ensure that the CG is in the correct position.
The Set Rocket Body tab has four sliders to simulate the forces on the rocket and test changes in the configuration before simulating. For example, if you see in the simulation that your rocket looses control at 10º angle of attack, with an actuator deflection of 20º, at 3 seconds from liftoff, you can put those parameters in the sliders in the Set Rocket Body tab and make changes to make sure you have the net moment that you need (i.e. increase the control fin size to get a restaurative moment).
- Actuator deflection: The current deflection of the actuator
- Force app point: The reduction point of all the forces in the rocket, it changes color to green if the force is applied in the opposite direction.
- Time: Takes the thrust of the motor from the thrust vs time curve for the time indicated in the slider.
One can activate the 3D Graphics by clicking the checkbox. IT REQUIRES VPYTHON
- Camera Shake moves the camera based on the accelerations of the rocket.
- Hide Forces hides the force arrows.
- Variable fov decreases the fov variably, maintaining the rocket of approximately the same size during the flight.
- Hide CG hides a ball that represents the CG.
- Camera type
- "Follow" -> Follows the rocket.
- "Fixed" -> Looks from the ground.
- "Follow Far" -> 2D.
- Slow Motion slows the animation -> 1 = Real time, 5 = five times slower.
- Force Scale Factor scales the forces accordingly, 1 = 1 meter/Newton.
- Fov is the field of view of the camera.
In case of using the Python SITL module, refer to the example. One can create functions, classes, modules, etc., or modify the code at will. The objective was to make it as similar as possible to an Arduino, but there are some differences, especially with the global variables having the prefix self. Only the Python SITL module is compatible with GNSS and sample times.
It was only tested on an Arduino Nano clone, so compatibility is not ensured.
Even on the Arduino, the program did not work properly with program runtimes times smaller than 5 milliseconds.
To use the Software in the Loop function, one must set the Port to the one in which the board is connected, and the Baudrate to the one set in the Arduino program.
One can simulate sensor noise by filling the entries with the Noise Standard Deviation of the specified sensor.
Download and include the library and create the instance with the name you want.
At the end of void setup, start the simulation.
Replace your sensor readings with Sim.getSimData() and the name of your variables.
- The Gyroscope data is in º/s.
- The Accelerometer measures the reaction force applied to it (like the real ones), the data is in g's.
- The Altimeter measures the data in meters.
- The GNSS measures the distance in the horizontal axis from the launch pad, in m.
- The GNSS measures the horizontal velocity, in m/s.
Positive values are positive in the direction of the axes!
(Refer to the Technical Documentation)
Replace your servo.write() for:
Replace servo_command for your servo variable (in º).
The parachute variable is an int, it's normally 0 and one must make it 1 when the parachute would deploy.
REMEMBER THAT THE DATA IS IN DEGREES, G'S AND M, AND YOU HAVE TO SEND THE SERVO COMMAND IN DEGREES AND THE PARACHUTE DEPLOYMENT SIGNAL AS 0 OR 1.
IF ONE IS USING SOFTWARE IN THE LOOP, THE CONTROLLER SETTINGS DO NOTHING
- Kp, Ki, and Kd are self-explanatory.
- K All scales the error before sending it to the PID.
- K Damping feeds the gyro back at the output of the PID and acts as damping.
- To disable the controller, one must set K All and K Damping to zero.
- In case the Control Fins are ahead of the CG, the controller multiplies K All and K Damping by -1.
- Reference Thrust is the Reference Thrust of the Torque Controller, more info in the control.py file.
- Input is the input to the rocket, be it a Step (deg), or a Ramp (deg/s)
- If the selected input is Up, then this entry is bypassed
- Input Time is the instant at which the input is changed from 0 to the selected one.
- Launch Time is the instant at which the motor is ignited.
- Servo Sample Time and Program Sample Time are self-explanatory, note they are in seconds and not Hz.
- Maximum Sim Duration specifies the maximum duration of the simulation.
- The simulation will stop if the Rocket tumbles more than 2 times, hits the ground, or coasts for more than 10 burnout times.
- Sim Delta T is the sample time of the simulation, one can increase it to hasten it.
- Since the Software in the Loop simulation runs in real time, this setting does not affect it.
- Export T is the sample time of the data exports, i.e., the time between exported data points.
- Launch altitude is the height above sea level of the launchpad.
- The next entries deal with the initial state of the rocket, useful for second stages or landings (landing aerodynamics are not well modelled, please do not rely exclusively on them.)
There are ten plots in total, one can choose between a variety of variables to be plotted in two different figures. The Export Plots button creates a .csv file containing all the plotted variables. The name of the .csv is the save file's name with a subscript and is created in the Exports folder. The exports are useful for feeding simulated sensor data from the Python SITL modules to a real flight computer and debug the latter by comparing the outputs. In consequence, there will be faster code prototyping and more complex controllers with less failures.
If the 3D Graphics were enabled, once the simulation finishes a new tab in your default web browser should open.
- One can seek backward/forward 1/5 of the simulation time, 1 or 0.015 seconds using the first row of buttons, the center one pauses and resumes the animation.
- The first slider controls the Slow Motion and the second one the FOV (zoom).
- The menu enables the change of camera angle on the fly.
- One can enable and disable the Forces and the CG & AoA (relative wind) with the buttons on the right.
- To see the plots, one must click the Finish button. This disables the animation.
NOTE: If the animation is paused, some of the features might require you to seek forward/backward to update the frame.
In src/aerodynamics/rocket_functions.py are some experimental features turned off by default, you can enable them by searching "experimental =" and setting them to True. They include dynamic pressure scaling for, theoretically, better damping, and drag calculations based on the component or fin Reynolds instead of the rocket's Re.