|
|
- /* Liquid rocket design */
-
-
- #include <stdlib.h>
- #include <stdio.h>
- #include <math.h>
-
- #include "libcpropep/include/print.h"
- #include "libcpropep/include/type.h"
- #include "libthermo/include/thermo.h"
- #include "libcpropep/include/conversion.h"
-
- #include "liblrd/include/lrd.h"
-
- #ifndef M_PI
- #define M_PI 3.14159265358979323846
- #endif
-
- int LRD_compute_caracteristics(equilibrium_t *e, design_param_t *d, motor_t *m,
- liquid_propellant_t *p)
- {
- equilibrium_t *throat, *exit;
-
- throat = e + 1;
- exit = e + 2;
-
- m->mass_flow_rate = d->thrust / exit->performance.Isp;
- m->fu_flow_rate = m->mass_flow_rate / (p->o_f_ratio + 1);
- m->ox_flow_rate = m->mass_flow_rate - m->fu_flow_rate;
-
- m->throat_area = m->mass_flow_rate * throat->performance.a_dotm
- / ATM_TO_PA;
- m->throat_diameter = 2 * sqrt(m->throat_area / M_PI);
- m->throat_radius = m->throat_diameter/2;
-
- m->exit_area = m->throat_area * exit->performance.ae_at;
- m->exit_diameter = 2 * sqrt(m->exit_area / M_PI);
- m->exit_radius = m->exit_diameter/2;
-
- m->Ac_At = pow(d->Dc_Dt, 2);
- m->chamber_volume = d->Lstar * m->throat_area;
- m->chamber_diameter = d->Dc_Dt * m->throat_diameter;
- m->chamber_radius = m->chamber_diameter/2;
- m->chamber_area = M_PI * pow(m->chamber_radius, 2);
-
- m->convergent_length = (m->throat_radius*(sqrt(m->Ac_At) - 1) +
- d->R_Rt*m->throat_radius*
- (pow(cos(d->theta*M_PI/180),-1) -1))
- /tan(d->theta*M_PI/180);
-
- /* m->convergent_volume = (M_PI/3)*m->convergent_length*
- (pow(m->chamber_radius, 2)+pow(m->throat_radius, 2)+
- m->chamber_radius*m->throat_radius); */
-
-
- m->convergent_volume = (1/3) * m->throat_area *sqrt(m->throat_area/M_PI) *
- pow(tan(d->theta*M_PI/180), -1)*(pow(m->Ac_At, 1/3) - 1);
-
- /*
- m->convergent_length = d->R_Rt*m->throat_radius*sin(d->theta*M_PI/180) +
- (m->chamber_radius - d->R_Rt*m->throat_radius*(cos(d->theta*M_PI/180)-1)
- - m->throat_radius)/tan(d->theta*M_PI/180);
- */
-
- m->cylinder_volume = m->chamber_volume - m->convergent_volume;
-
-
- m->cylinder_length = m->cylinder_volume / m->chamber_area;
-
- m->chamber_length = m->cylinder_length + m->convergent_length;
-
- m->walls_area = 2*m->chamber_length*sqrt(M_PI*m->Ac_At*m->throat_area)
- + pow(sin(d->theta), -1)*(m->Ac_At - 1)*m->throat_area;
-
- return 0;
- }
-
- int LRD_print_propellant_info(liquid_propellant_t *p)
- {
- printf("Propellant\n");
- printf("----------\n");
- printf("Fuel : %s\n", PROPELLANT_NAME(p->fuel));
- printf("Oxidant : %s\n", PROPELLANT_NAME(p->oxidant));
- printf("O/F ratio : %.2f\n\n", p->o_f_ratio);
- return 0;
- }
-
- int LRD_print_design_criteria(design_param_t *c)
- {
- printf("Design criteria\n");
- printf("---------------\n");
- printf("Chamber pressure (atm) (psi) : % 11.4f % 11.4f\n",
- c->chamber_pressure, c->chamber_pressure * ATM_TO_PSI);
- printf("Thrust (N) (lbf) : % 11.4e % 11.4e\n",
- c->thrust, c->thrust * N_TO_LBF);
- printf("L* (m) (in) : % 11.4f % 11.4f\n",
- c->Lstar, c->Lstar * M_TO_IN);
- printf("Chamber to throat diameter : % 11.4f\n",
- c->Dc_Dt);
- printf("R/Rt : % 11.4f\n",
- c->R_Rt);
- printf("Convergent half angle (deg) : % 11.4f\n", c->theta);
- printf("\n");
- return 0;
- }
-
- int LRD_print_design_information(motor_t *mf, motor_t *ms)
- {
- printf("\n");
- printf(" "
- "frozen | shifting\n");
- printf("Mass flow rate (kg/s) (lb/s) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->mass_flow_rate, mf->mass_flow_rate * KG_S_TO_LB_S,
- ms->mass_flow_rate, ms->mass_flow_rate * KG_S_TO_LB_S);
- printf("Fuel flow rate (kg/s) (lb/s) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->fu_flow_rate, mf->fu_flow_rate * KG_S_TO_LB_S,
- ms->fu_flow_rate, ms->fu_flow_rate * KG_S_TO_LB_S);
- printf("Oxidant flow rate (kg/s) (lb/s) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->ox_flow_rate, mf->ox_flow_rate * KG_S_TO_LB_S,
- ms->ox_flow_rate, ms->ox_flow_rate * KG_S_TO_LB_S);
- printf("Throat area (m^2) (in^2) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->throat_area, mf->throat_area * M2_TO_IN2,
- ms->throat_area, ms->throat_area * M2_TO_IN2);
- printf("Throat diameter (m) (in) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->throat_diameter, mf->throat_diameter * M_TO_IN,
- ms->throat_diameter, ms->throat_diameter * M_TO_IN);
- printf("Exit area (m^2) (in^2) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->exit_area, mf->exit_area * M2_TO_IN2,
- ms->exit_area, ms->exit_area * M2_TO_IN2);
- printf("Exit diameter (m) (in) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->exit_diameter, mf->exit_diameter * M_TO_IN,
- ms->exit_diameter, ms->exit_diameter * M_TO_IN);
- printf("Chamber volume (m^3) (in^3) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->chamber_volume, mf->chamber_volume * M3_TO_IN3,
- ms->chamber_volume, ms->chamber_volume * M3_TO_IN3);
- printf("Chamber diameter (m) (in) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->chamber_diameter, mf->chamber_diameter * M_TO_IN,
- ms->chamber_diameter, ms->chamber_diameter * M_TO_IN);
- printf("Chamber length (m) (in) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->chamber_length, mf->chamber_length * M_TO_IN,
- ms->chamber_length, ms->chamber_length * M_TO_IN);
- printf("Convergent length (m) (in) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->convergent_length, mf->convergent_length * M_TO_IN,
- ms->convergent_length, ms->convergent_length * M_TO_IN);
- printf("Cylinder length (m) (in) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->cylinder_length, mf->cylinder_length * M_TO_IN,
- ms->cylinder_length, ms->cylinder_length * M_TO_IN);
- printf("Chamber walls area (m^2) (in^2) : %8.4e %8.4e | %8.4e %8.4e\n",
- mf->walls_area, mf->walls_area * M2_TO_IN2,
- ms->walls_area, ms->walls_area * M2_TO_IN2);
-
- return 0;
- }
-
-
-
|