Skip to content

Commit

Permalink
Merge pull request #290 from VirtualPlanetaryLaboratory/memcheck
Browse files Browse the repository at this point in the history
Memcheck
  • Loading branch information
RoryBarnes authored Apr 18, 2024
2 parents b418c48 + e592635 commit c2756c0
Show file tree
Hide file tree
Showing 38 changed files with 3,461 additions and 4,127 deletions.
4 changes: 2 additions & 2 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -65,11 +65,11 @@ sanitize:

test:
-gcc -o bin/vplanet src/*.c -lm -O3 -DGITVERSION=\"$(GITVERSION)\"
-pytest
-pytest --tb=short

coverage:
-mkdir -p gcov && cd gcov && gcc -coverage -o ../bin/vplanet ../src/*.c -lm
-python -m pytest -v tests --junitxml=junit/test-results.xml
-python -m pytest --tb=short tests --junitxml=junit/test-results.xml
-lcov --capture --directory gcov --output-file .coverage && genhtml .coverage --output-directory gcov/html

docs:
Expand Down
134 changes: 43 additions & 91 deletions src/atmesc.c
Original file line number Diff line number Diff line change
Expand Up @@ -1446,39 +1446,37 @@ double fdAtmEscXi(BODY *body, int iBody) {
return dXi;
}

double fdKTide(BODY *body, IO *io, int iBody) {
double fdKTide(BODY *body, IO *io, int iNumBodies, int iBody) {
double dKTide;

// For stars and circumbinary planets, assume no Ktide enhancement
if (body[iBody].bBinary && body[iBody].iBodyType == 0) {
dKTide = 1.0;
} else {
if (body[iBody].dAtmEscXi > 1) {
dKTide = (1 - 3 / (2 * body[iBody].dAtmEscXi) +
1 / (2 * pow(body[iBody].dAtmEscXi, 3)));
/*
fprintf(stderr,"%.5e: ",evolve->dTime/YEARSEC);
fprintf(stderr,"%.5e ",xi);
fprintf(stderr,"%.5e\n",body[iBody].dKTide);
*/
if (dKTide < body[iBody].dMinKTide) {
dKTide = body[iBody].dMinKTide;
if (iNumBodies > 1) {
if (body[iBody].dAtmEscXi > 1) {
dKTide = (1 - 3 / (2 * body[iBody].dAtmEscXi) +
1 / (2 * pow(body[iBody].dAtmEscXi, 3)));
if (dKTide < body[iBody].dMinKTide) {
dKTide = body[iBody].dMinKTide;
}
} else {
if (!io->baRocheMessage[iBody] && io->iVerbose >= VERBINPUT &&
(!body[iBody].bUseBondiLimited && !body[iBody].bAtmEscAuto)) {
fprintf(stderr,
"WARNING: Roche lobe radius is larger than %s's XUV radius. "
"Evolution may not be accurate.\n",
body[iBody].cName);
fprintf(stderr, "Consider setting bUseBondiLimited = 1 or bAtmEscAuto "
"= 1 to limit envelope mass loss.\n");
io->baRocheMessage[iBody] = 1;
}
// Fix dKTide to prevent infs when in Roche Lobe overflow
dKTide = 1.0;
}
} else {
if (!io->baRocheMessage[iBody] && io->iVerbose >= VERBINPUT &&
(!body[iBody].bUseBondiLimited && !body[iBody].bAtmEscAuto)) {
fprintf(stderr,
"WARNING: Roche lobe radius is larger than %s's XUV radius. "
"Evolution may not be accurate.\n",
body[iBody].cName);
fprintf(stderr, "Consider setting bUseBondiLimited = 1 or bAtmEscAuto "
"= 1 to limit envelope mass loss.\n");
io->baRocheMessage[iBody] = 1;
}
// Fix dKTide to prevent infs when in Roche Lobe overflow
dKTide = 1.0;
}
// body[iBody].dKTide = 1.0;
}

return dKTide;
Expand Down Expand Up @@ -1694,7 +1692,7 @@ void fnForceBehaviorAtmEsc(BODY *body, MODULE *module, EVOLVE *evolve, IO *io,
}
}

void AuxPropsLehmer17(BODY *body, int iBody) {
void AuxPropsLehmer17(BODY *body, EVOLVE *evolve, int iBody) {
if (body[iBody].bAutoThermTemp) {
body[iBody].dThermTemp = fdThermalTemp(body, iBody);
}
Expand All @@ -1706,7 +1704,7 @@ void AuxPropsLehmer17(BODY *body, int iBody) {
body[iBody].dPresSurf =
fdLehmerPres(body[iBody].dEnvelopeMass, body[iBody].dGravAccel,
body[iBody].dRadSolid);
body[iBody].dRadXUV = fdLehmerRadius(body, iBody);
body[iBody].dRadXUV = fdLehmerRadius(body, evolve->iNumBodies, iBody);
body[iBody].dRadius = body[iBody].dRadXUV / body[iBody].dXFrac;
}

Expand All @@ -1726,14 +1724,14 @@ void fnPropsAuxAtmEsc(BODY *body, EVOLVE *evolve, IO *io, UPDATE *update,
int iBody) {

if (body[iBody].iPlanetRadiusModel == ATMESC_LEHMER17) {
AuxPropsLehmer17(body, iBody);
AuxPropsLehmer17(body, evolve, iBody);
}

// Compute various radii of interest
body[iBody].dBondiRadius = fdBondiRadius(body, iBody);
body[iBody].dRocheRadius = fdRocheRadius(body, iBody);
body[iBody].dRocheRadius = fdRocheRadius(body, evolve->iNumBodies, iBody);
body[iBody].dAtmEscXi = fdAtmEscXi(body, iBody);
body[iBody].dKTide = fdKTide(body, io, iBody);
body[iBody].dKTide = fdKTide(body, io, evolve->iNumBodies, iBody);

// The XUV flux
if (body[iBody].bCalcFXUV) {
Expand Down Expand Up @@ -2133,7 +2131,7 @@ void VerifyAtmEsc(BODY *body, CONTROL *control, FILES *files, OPTIONS *options,

// Calculate auxiliary properties
body[iBody].dRadSolid = fdMassToRad_LehmerCatling17(body[iBody].dMass - body[iBody].dEnvelopeMass);
AuxPropsLehmer17(body,iBody);
AuxPropsLehmer17(body,&(control->Evolve), iBody);
} else {
fprintf(stderr,
"ERROR: The Lehmer & Catling (2017) model requires a star.\n");
Expand Down Expand Up @@ -2312,7 +2310,7 @@ void VerifyAtmEsc(BODY *body, CONTROL *control, FILES *files, OPTIONS *options,
// Setup radius and other radii of interest
VerifyRadiusAtmEsc(body, control, options, update, body[iBody].dAge, iBody);
body[iBody].dBondiRadius = fdBondiRadius(body, iBody);
body[iBody].dRocheRadius = fdRocheRadius(body, iBody);
body[iBody].dRocheRadius = fdRocheRadius(body, control->Evolve.iNumBodies, iBody);

control->fnForceBehavior[iBody][iModule] = &fnForceBehaviorAtmEsc;
control->fnPropsAux[iBody][iModule] = &fnPropsAuxAtmEsc;
Expand Down Expand Up @@ -3429,11 +3427,15 @@ Modifier for H Ref Flux to include oxygen drag at a snapshot in time
void WriteHRefODragMod(BODY *body, CONTROL *control, OUTPUT *output,
SYSTEM *system, UNITS *units, UPDATE *update, int iBody,
double *dTmp, char cUnit[]) {
double rat = (body[iBody].dCrossoverMass / ATOMMASS - QOH) /
(body[iBody].dCrossoverMass / ATOMMASS - 1.);
double XO = fdAtomicOxygenMixingRatio(body[iBody].dSurfaceWaterMass,
body[iBody].dOxygenMass);
*dTmp = pow(1. + (XO / (1. - XO)) * QOH * rat, -1);
if (body[iBody].dCrossoverMass / ATOMMASS - 1. != 0) {
double rat = (body[iBody].dCrossoverMass / ATOMMASS - QOH) /
(body[iBody].dCrossoverMass / ATOMMASS - 1.);
double XO = fdAtomicOxygenMixingRatio(body[iBody].dSurfaceWaterMass,
body[iBody].dOxygenMass);
*dTmp = pow(1. + (XO / (1. - XO)) * QOH * rat, -1);
} else {
*dTmp = -1;
}
strcpy(cUnit, "");
}

Expand Down Expand Up @@ -4082,7 +4084,7 @@ double fdPlanetRadius(BODY *body, SYSTEM *system, int *iaBody) {
body[iaBody[0]].dPresSurf =
fdLehmerPres(body[iaBody[0]].dEnvelopeMass,
body[iaBody[0]].dGravAccel, body[iaBody[0]].dRadSolid);
body[iaBody[0]].dRadXUV = fdLehmerRadius(body, iaBody[0]);
body[iaBody[0]].dRadXUV = fdLehmerRadius(body, system->iNumBodies, iaBody[0]);
}

double foo;
Expand Down Expand Up @@ -4134,6 +4136,11 @@ int fbDoesWaterEscape(BODY *body, EVOLVE *evolve, IO *io, int iBody) {
return 0;
}

/* If the central body is not a star, then allow water to escape */
if (!body[0].bStellar) {
return 1;
}

// 2. Check if planet is beyond RG limit; if user requested water loss to stop
// (the cold trap prevents water loss) then water does not escape.
// NOTE: The RG flux limit below is calculated based on body zero's
Expand Down Expand Up @@ -4363,62 +4370,7 @@ void fvLinearFit(double *x, double *y, int iLen, double *daCoeffs) {
daCoeffs[1] = yavg - daCoeffs[0] * xavg; // Intercept
}

/**
Calculate sound speed of a diatomic H (H2) isothermal gaseous atmosphere in
which the temperature is set by the local equilibrium temperature.

@param dTemp double stellar effective temperature
@param dRad double stellar radius
@param dSemi double planetary semi-major axis
@return sound speed
*/
double fdEqH2AtmosphereSoundSpeed(double dTemp, double dRad, double dSemi) {

double dCS = 2300.0 * sqrt(dTemp / 5800.0) * pow(dRad / RSUN, 0.25) *
pow(dSemi / (0.1 * AUM), 0.25);
return dCS;
}

/**
Calculate the Roche radius assuming body 0 is the host star using Eqn. 8 from
Luger et al. (2015)
@param body BODY struct
@param iBody int body indentifier
@return Body's Roche radius
*/
double fdRocheRadius(BODY *body, int iBody) {
double dRoche = pow(body[iBody].dMass / (3.0 * body[0].dMass), 1. / 3.) *
body[iBody].dSemi;
return dRoche;
}

/**
Calculate the Bondi radius assuming body 0 is the host star and that the
planetary atmosphere at the Bondi radius is diatomic H2 at the blackbody
equilibrium temperature set by thermal emission from the host star adapting
equation. Adapted from equations 2 and 4 from Owen & Wu (2016)
@param body BODY struct
@param iBody int body indentifier
@return Body's Bondi radius
*/
double fdBondiRadius(BODY *body, int iBody) {
double dBondiRadius;
// Compute sound speed in planet's atmosphere assuming a diatomic H atmosphere
// assuming body 0 is the star
if (body[0].bStellar) {
double dSoundSpeed = fdEqH2AtmosphereSoundSpeed(body[0].dTemperature, body[0].dRadius,
body[iBody].dSemi);
dBondiRadius = BIGG * body[iBody].dMass / (2.0 * dSoundSpeed * dSoundSpeed);
} else {
dBondiRadius = -1;
}
return dBondiRadius;
}

/**
Calculate the whether or not incident XUV flux exceeds critical flux between
Expand Down
2 changes: 0 additions & 2 deletions src/atmesc.h
Original file line number Diff line number Diff line change
Expand Up @@ -227,8 +227,6 @@ double fdInsolation(BODY *, int, int);
int fbDoesWaterEscape(BODY *, EVOLVE *, IO *, int);
double fdPlanetRadius(BODY *, SYSTEM *, int *);
double fdXUVEfficiencyBolmont2016(double);
double fdBondiRadius(BODY *, int);
double fdRocheRadius(BODY *, int);
double fdBondiLimitedDmDt(BODY *, int);
int fbRRCriticalFlux(BODY *, int);
int fbBondiCriticalDmDt(BODY *, int);
Expand Down
22 changes: 20 additions & 2 deletions src/body.c
Original file line number Diff line number Diff line change
Expand Up @@ -577,7 +577,7 @@ double CalcDynEllipEq(BODY *body, int iBody) {
@param dRadXUV radius from center of planet where optical depth of XUV is
unity
*/
double fdLehmerRadius(BODY *body, int iBody) {
double fdLehmerRadius(BODY *body, int iNumBodies, int iBody) {
double dRadXUV, dRoche;

// Set floor for surface pressure to prevent overflow error
Expand All @@ -589,7 +589,7 @@ double fdLehmerRadius(BODY *body, int iBody) {
} else {
dRadXUV = body[iBody].dRadSolid;
}
dRoche = fdRocheRadius(body, iBody);
dRoche = fdRocheRadius(body, iNumBodies, iBody);
// printf("%lf %lf %lf %lf
// %lf\n",body[iBody].dPresXUV,body[iBody].dPresSurf,body[iBody].dGravAccel,body[iBody].dEnvelopeMass,dRadXUV);
if (dRadXUV <= 0) {
Expand All @@ -607,6 +607,24 @@ double fdLehmerRadius(BODY *body, int iBody) {
return dRadXUV;
}

/**
Calculate sound speed of a diatomic H (H2) isothermal gaseous atmosphere in
which the temperature is set by the local equilibrium temperature.
@param dTemp double stellar effective temperature
@param dRad double stellar radius
@param dSemi double planetary semi-major axis
@return sound speed
*/
double fdEqH2AtmosphereSoundSpeed(double dTemp, double dRad, double dSemi) {

double dCS = 2300.0 * sqrt(dTemp / 5800.0) * pow(dRad / RSUN, 0.25) *
pow(dSemi / (0.1 * AUM), 0.25);
return dCS;
}


/**
Lehmer+ (2017)'s model for the pressure of a planet where it's losing its
atmopshere due to XUV radiation.
Expand Down
3 changes: 2 additions & 1 deletion src/body.h
Original file line number Diff line number Diff line change
Expand Up @@ -89,9 +89,10 @@ double fdRadToMass_GordaSvech99(double);
double fdRadToMass_ReidHawley(double);
double fdRadToMass_Sotin07(double);
double fdMassToRad_LehmerCatling17(double);
double fdLehmerRadius(BODY *, int);
double fdLehmerRadius(BODY *, int, int);
double fdLehmerPres(double, double, double);
double fdThermalTemp(BODY *, int);
double fdEqH2AtmosphereSoundSpeed(double, double, double);

double fdImK2Total(BODY *, int);
double fdImK2Man(BODY *, int);
Expand Down
Loading

0 comments on commit c2756c0

Please sign in to comment.