Revision 8dfaf509de85637f689a696e8d608d1d173068ab authored by Harshitha on 02 March 2015, 21:01:30 UTC, committed by Harshitha on 02 March 2015, 21:01:30 UTC
Change-Id: I6f7773757bc5f4a04e216620d3e4807e0729c9fa
1 parent 731b61c
parameters.h
#ifndef PARAMETERS_HINCLUDED
#define PARAMETERS_HINCLUDED
#include "cosmo.h"
#include "cooling.h"
#include "starform.h"
#include "feedback.h"
/** @brief Hold parameters of the run.
*/
typedef struct parameters {
/*
** Parameters for ParallelGravity.
*/
int bDoDensity;
int bDoGravity;
double dSoft;
int bPhysicalSoft; /* Use physical softening in comoving coords */
int bSoftMaxMul; /* dSoftMax is a multiplier, not an
absolute limit */
double dSoftMax;
int nSteps;
int iStartStep;
int iWallRunTime;
double dDelta;
int bEpsAccStep;
int bGravStep;
double dEta;
int nTruncateRung;
int iMaxRung;
int bCannonical;
int bKDK;
int bPeriodic;
int nReplicas;
double fPeriod;
Vector3D<double> vPeriod;
int bEwald;
double dEwCut;
double dEwhCut;
double dTheta;
double dTheta2;
double daSwitchTheta;
int iOrder;
int bConcurrentSph;
double dFracNoDomainDecomp;
#ifdef PUSH_GRAVITY
double dFracPushParticles;
#endif
CSM csm; /* cosmo parameters */
double dRedTo;
/*
* GrowMass parameters
*/
int bDynGrowMass;
int nGrowMass;
double dGrowDeltaM;
double dGrowStartT;
double dGrowEndT;
/*
* Gas parameters
* Units: set by dMsolUnit and dKpcUnit
*/
int bDoGas;
int bGeometric;
int bBulkViscosity;
int bGasAdiabatic;
int bGasIsothermal;
int bGasCooling;
int nSmooth;
COOLPARAM CoolParam;
double dhMinOverSoft;
double dMsolUnit;
double dKpcUnit;
double ddHonHLimit;
double dGasConst;
double dConstAlpha;
double dConstBeta;
double dConstGamma;
double dMeanMolWeight;
double dErgPerGmUnit;
double dGmPerCcUnit;
double dSecUnit;
double dComovingGmPerCcUnit;
int bSphStep;
int bFastGas;
double dFracFastGas;
int bViscosityLimiter;
int iViscosityLimiter;
int bViscosityLimitdt;
double dEtaCourant;
double dEtauDot;
int bStarForm;
Stfm *stfm;
int bFeedback;
Fdbk *feedback;
int iRandomSeed;
int bStandard;
int bDoublePos;
int bDoubleVel;
int bOverwrite;
int bParaRead;
int bParaWrite;
int nIOProcessor;
char achInFile[256];
char achOutName[256];
int bStaticTest;
int bBenchmark;
int iBinaryOut;
int iOutInterval;
int iCheckInterval;
int iLogInterval;
int bDoIOrderOutput;
int bDoSoftOutput;
int bDohOutput;
int bDoCSound;
int cacheLineDepth;
double dExtraStore;
double dMaxBalance;
double dDumpFrameStep;
double dDumpFrameTime;
int iDirector;
int bLiveViz;
int bUseCkLoopPar;
int iVerbosity;
} Parameters;
inline void operator|(PUP::er &p, Parameters ¶m) {
p|param.bDoDensity;
p|param.bDoGravity;
p|param.dSoft;
p|param.bPhysicalSoft;
p|param.bSoftMaxMul;
p|param.dSoftMax;
p|param.nSteps;
p|param.iStartStep;
p|param.iWallRunTime;
p|param.dDelta;
p|param.bEpsAccStep;
p|param.bGravStep;
p|param.dEta;
p|param.nTruncateRung;
p|param.iMaxRung;
p|param.bCannonical;
p|param.bKDK;
p|param.bPeriodic;
p|param.nReplicas;
p|param.fPeriod;
p|param.vPeriod;
p|param.bEwald;
p|param.dEwCut;
p|param.dEwhCut;
p|param.dTheta;
p|param.dTheta2;
p|param.daSwitchTheta;
p|param.iOrder;
p|param.bConcurrentSph;
p|param.dFracNoDomainDecomp;
#ifdef PUSH_GRAVITY
p|param.dFracPushParticles;
#endif
if(p.isUnpacking())
csmInitialize(¶m.csm);
p|*param.csm;
p|param.dRedTo;
p|param.bDynGrowMass;
p|param.nGrowMass;
p|param.dGrowDeltaM;
p|param.dGrowStartT;
p|param.dGrowEndT;
p|param.bDoGas;
p|param.bGeometric;
p|param.bBulkViscosity;
p|param.bGasAdiabatic;
p|param.bGasIsothermal;
p|param.bGasCooling;
p|param.nSmooth;
p((char *)¶m.CoolParam, sizeof(param.CoolParam));
p|param.bFastGas;
p|param.dFracFastGas;
p|param.bViscosityLimiter;
p|param.iViscosityLimiter;
p|param.dhMinOverSoft;
p|param.dMsolUnit;
p|param.dKpcUnit;
p|param.ddHonHLimit;
p|param.dGasConst;
p|param.dConstAlpha;
p|param.dConstBeta;
p|param.dConstGamma;
p|param.dMeanMolWeight;
p|param.dErgPerGmUnit;
p|param.dGmPerCcUnit;
p|param.dSecUnit;
p|param.dComovingGmPerCcUnit;
p|param.bSphStep;
p|param.bViscosityLimitdt;
p|param.dEtaCourant;
p|param.dEtauDot;
p|param.bStarForm;
if(p.isUnpacking())
param.stfm = new Stfm();
p|*param.stfm;
p|param.bFeedback;
p|param.feedback;
p|param.iRandomSeed;
p|param.bStandard;
p|param.bDoublePos;
p|param.bDoubleVel;
p|param.bOverwrite;
p|param.bParaRead;
p|param.bParaWrite;
p|param.nIOProcessor;
p(param.achInFile, 256);
p(param.achOutName, 256);
p|param.bStaticTest;
p|param.bBenchmark;
p|param.iBinaryOut;
p|param.iOutInterval;
p|param.iCheckInterval;
p|param.iLogInterval;
p|param.bDoIOrderOutput;
p|param.bDoSoftOutput;
p|param.bDohOutput;
p|param.bDoCSound;
p|param.cacheLineDepth;
p|param.dExtraStore;
p|param.dMaxBalance;
p|param.dDumpFrameStep;
p|param.dDumpFrameTime;
p|param.iDirector;
p|param.bLiveViz;
p|param.bUseCkLoopPar;
p|param.iVerbosity;
}
#endif
Computing file changes ...