Based on the original Rocket Workbench on SourceForge in CVS at: https://sourceforge.net/projects/rocketworkbench
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

156 lines
6.0 KiB

/* 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;
}