-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathmaster.h
404 lines (375 loc) · 13.1 KB
/
master.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
#ifndef MASTER_HINCLUDED
#define MASTER_HINCLUDED
#include "pst.h"
#include "param.h"
#include "mdl.h"
#include "parameters.h"
#include "floattype.h"
#ifndef LOG_HINCLUDED
#include "log.h"
#endif
#ifdef RUBBLE_ZML
#include "rubble.h"
#endif
#define MSR_INIT_E 1
#define MSR_STEP_E 0
/*
** An integer marking the type of tree currently in use.
** MSR_TREE_NONE: undefined tree type
** MSR_TREE_SPATIAL: spatial binary tree
** MSR_TREE_DENSITY: density binary tree (the old style KD-tree!)
** MSR_TREE_QQ: perihelion-aphelion tree for planets.
*/
#define MSR_TREE_NONE 0
#define MSR_TREE_SPATIAL 1
#define MSR_TREE_DENSITY 2
enum TimingType {
TIMING_Total,
TIMING_DD, TIMING_SPHTree, TIMING_GravTree, TIMING_Gravity,
TIMING_Smooth, TIMING_ReSmooth, TIMING_MarkSmooth,
TIMING_Drift, TIMING_Kick,
TIMING_Cool, TIMING_Sink, TIMING_StarForm, TIMING_Feedback, TIMING_DumpFrame,
TIMING_N
};
struct RungData {
long long nPart, nPartMin, nPartMax, nUses;
long long nPartTot, nPartMinTot, nPartMaxTot, nUsesTot;
long long nCall[TIMING_N]; /* consistency check */
double t[TIMING_N], tTot[TIMING_N];
};
typedef struct msrContext {
PRM prm;
PST pst;
MDL mdl;
LCL lcl;
FLOAT fCenter[3];
/*
** Parameters.
*/
struct parameters param;
/*
** Other stuff...
*/
int nThreads;
int N;
int nDark;
int nGas;
int nStar;
int nSink;
int nMaxOrder; /* Order number of last particle */
int nMaxOrderGas;
int nMaxOrderDark;
int iCurrMaxRung;
int bOpenSpec; /* was an opening parameter specified (used by +restart) */
int iOpenType;
double dCrit;
/*
** Comoving coordinate variables.
*/
double dEcosmo;
double dUOld;
double dTimeOld;
#ifdef COLLISIONS
double dTcoll;
#endif
#ifdef AGGS
/* Aggregates info currently stored only on master */
int nAggs;
int iAggNewIdx;
Aggregate *pAggs;
#endif
#ifdef RUBBLE_ZML
/* Event handler for rubble piles */
struct rubEvents re;
/* Data structures for dust */
DustBins aDustBins[DUST_BINS_MAX_NUM]; /* fixed max b/c passed to pst */
double dDustBinsTrash; /* trash bin for dust that travels outside bin range */
#endif
/*
** Redshift output points.
*/
int nMaxOuts;
int nOuts;
double *pdOutTime;
int iOut;
int *OutputListRed,nOutputListRed,bDensitySmoothRed;
int *OutputListInterval,nOutputListInterval,bDensitySmoothInterval;
int *OutputListMinorInterval,nOutputListMinorInterval,bDensitySmoothMinorInterval;
/*
** Processor mapping for one-node-output functions.
*/
int *pMap;
/*
** Tracking for frame dumping function
*/
int bDumpFrame;
int bStepZero; // Are we in initialization?
struct DumpFrameContext *df[10];
/*
** An integer marking the type of tree currently in use.
** MSR_TREE_NONE: undefined tree type
** MSR_TREE_SPATIAL: spatial binary tree
** MSR_TREE_DENSITY: density binary tree (the old style KD-tree!)
*/
int iTreeType;
int bGravityTree;
/*
* Domain Decomposition Done
*/
int *nRung;
int bDoneDomainDecomp;
int iLastRungDomainDecomp;
int nActive;
int nTreeActive;
int nSmoothActive;
int iRungStat;
struct RungData *RungStat;
double dtMinGas;
int iMaxRungGas;
} * MSR;
void msrInitialize(MSR *,MDL,int,char **);
void msrLogDefines(FILE *fp);
void msrLogHeader(MSR msr, FILE *fp);
int msrGetLock(MSR msr);
int msrCheckForStop(MSR msr);
void msrFinish(MSR);
int msrReadASCII(MSR, char *, int, double *);
int msrSetTypeFromFile(MSR msr, char *file, int type);
double msrReadTipsy(MSR);
void msrCreateAllStepZeroOutputList(MSR msr, int *iNumOutputs, int OutputList[]);
void msrCreateGasStepZeroOutputList(MSR msr, int *iNumOutputs, int OutputList[]);
void msrInitOutputLists(MSR msr);
void msrSelectOutputList(MSR msr, int (*nOutputList), int OutputList[], int, int bOutTime, int *pbDensitySmooth);
void msrCreateOutputListFromString(MSR msr,int (*pnOutputList), int OutputList[], char *achGas, char *achDark, char *achStar, int *pbDensitySmooth);
void msrCreateOutputList(MSR msr, int *iNumOutputs, int OutputList[]);
void msrCreateAllOutputList(MSR msr, int *iNumOutputs, int OutputList[]);
void msrCreateGasOutputList(MSR msr, int *iNumOutputs, int OutputList[]);
void msrWriteOutputs(MSR msr, char *achFile, int *OutputList, int iNumOutputs, double dTime);
void msrOneNodeWriteOutputs(MSR msr, int OutputList[], int iNumOutputs,
#ifdef COLLISIONS
struct inWriteSS *in
#else
struct inWriteTipsy *in
#endif
);
void msrWriteTipsy(MSR,char *,double);
void msrWriteTipsyHead(MSR msr,char *achOutFile,double dTime, struct inWriteTipsy *in);
void msrWriteTipsyBody(MSR msr,char *pszFileName,double dTime, struct inWriteTipsy *in);
void msrSetSoft(MSR msr,double);
void msrSetSink(MSR msr,double dTime);
void msrDomainDecomp(MSR,int,int);
void msrBuildTree(MSR,int,double,int);
void msrDomainColor(MSR);
void msrReorder(MSR);
void msrOutArray(MSR,char *,int);
void msrOutVector(MSR,char *,int);
void msrInArray(MSR,char *,int);
void msrGetGasPressure(MSR, double);
void msrGetDensityU(MSR);
void msrLowerSoundSpeed(MSR);
void msrSmoothFcnParam(MSR msr, double dTimem, SMF *psmf);
void msrSmooth(MSR,double,int,int);
void msrReSmooth(MSR,double,int,int);
void msrMarkSmooth(MSR,double,int,int);
void msrDtSmooth(MSR msr,double dTime,int bSymmetric);
void msrUpdateSoft(MSR,double);
void msrGravity(MSR,double,int,int *,double *,double *,double *,int *);
void msrCalcEandL(MSR,int,double,double *,double *,double *,double *,double *);
void msrDrift(MSR,double,double);
void msrKick(MSR,double,double);
int msrFindCheck(MSR);
double msrReadCheck(MSR,int *);
void msrWriteCheck(MSR,double,int);
int msrOutTime(MSR,double);
void msrReadOuts(MSR,double);
double msrTime(void);
double msrMassCheck(MSR,double,char *);
void msrMassMetalsEnergyCheck(MSR,double *, double *, double *, double *, double *,char *);
void msrTopStepDKD(MSR msr, double dStep, double dTime, double dDelta,
double *pdMultiEff);
void msrTopStepKDK(MSR msr,
double dStep, /* Current step */
double dTime, /* Current time */
double dDelta, /* Time step */
int iRung, /* Rung level */
int iKickRung, /* Gravity on all rungs from iRung
to iKickRung */
int iAdjust, /* Do an adjust? */
double *pdActiveSum,
double *pdWMax,
double *pdIMax,
double *pdEMax,
int *piSec);
void msrRungStats(MSR);
int msrCurrMaxRung(MSR);
int msrCurrMaxRungInclDF(MSR);
void msrBallMax(MSR msr, int iRung, int bGreater);
/*------------------*/
/* Active Functions */
/*------------------*/
void msrActiveRung(MSR msr, int iRung, int bGreater);
void msrActiveOrder(MSR msr);
/* Deprecated functions */
/*
void msrSmoothActiveRung(MSR msr, int iRung, int bGreater);
void msrActiveGas(MSR msr);
void msrActiveDark(MSR msr);
void msrActiveStar(MSR msr);
void msrTreeActiveGas(MSR msr);
void msrTreeActiveDark(MSR msr);
void msrTreeActiveStar(MSR msr);
void msrSmoothActiveGas(MSR msr);
void msrSmoothActiveDark(MSR msr);
void msrSmoothActiveStar(MSR msr);
void msrActiveOrder(MSR msr);
void msrTreeActiveOrder(MSR msr);
#ifdef SUPERCOOL
void msrActiveCool(MSR msr);
void msrTreeActiveCool(MSR msr);
void msrSmoothActiveCool(MSR msr);
#endif
*/
/* Replacement functions */
void msrActiveExactType(MSR msr, unsigned int iFilterMask, unsigned int iTestMask, unsigned int iSetMask);
void msrActiveType(MSR msr, unsigned int iTestMask, unsigned int iSetMask);
void msrSetType(MSR msr, unsigned int iTestMask, unsigned int iSetMask);
void msrResetType(MSR msr, unsigned int iTestMask, unsigned int iSetMask);
int msrCountType(MSR msr, unsigned int iFilterMask, unsigned int iTestMask);
void msrActiveMaskRung(MSR msr, unsigned int iSetMask, int iRung, int bGreater);
void msrActiveTypeRung(MSR msr, unsigned int iTestMask, unsigned int iSetMask, int iRung, int bGreater);
void msrActiveTypeOrder(MSR msr, unsigned int iTestMask );
/*------------------*/
/* Active Functions */
/*------------------*/
void msrVelocityRung(MSR msr,int iRung,double dDelta,double dTime,int bAll);
void msrCoolVelocity(MSR,double,double);
void msrGrowMass(MSR msr, double dTime, double dDelta);
void msrCalcWriteStart(MSR);
void msrAddDelParticles(MSR msr);
void msrOutputBlackHoles(MSR msr, double dTime);
void msrDoSinks(MSR msr, double dTime, double dDelta, int iKickRung);
void msrFormSinks(MSR msr, double dTime, double dDelta, int iKickRung);
void msrInitStarLog(MSR msr);
void msrFlushStarLog(MSR msr);
void msrInitSinkLog(MSR msr);
void msrFlushSinkLog(MSR msr);
void msrGravStep(MSR msr, double dTime);
void msrAccelStep(MSR msr, double dTime);
void msrDensityStep(MSR msr, double dTime);
void msrInitDt(MSR msr);
void msrDtToRung(MSR msr, int iRung, double dDelta, int bAll);
void msrInitRotatingBar(MSR msr, double dTime);
void msrUpdateRotBar(MSR msr, double dTime);
/*
** Interface functions.
*/
int msrSteps(MSR);
char *msrOutName(MSR);
double msrDelta(MSR);
int msrLogInterval(MSR);
int msrCheckInterval(MSR);
int msrOutInterval(MSR);
int msrRestart(MSR);
int msrComove(MSR);
int msrKDK(MSR);
int msrDoSun(MSR);
double msrSoft(MSR);
int msrDoDensity(MSR);
int msrDoGravity(MSR msr);
int msrDoGas(MSR msr);
int msrFastGas(MSR msr);
void msrInitStep(MSR msr);
void msrSetRung(MSR msr, int iRung);
void msrInitAccel(MSR msr);
void msrModifyAccel(MSR msr,double);
void msrSwitchTheta(MSR msr,double);
int msrMaxOrder(MSR msr);
int msrMaxRung(MSR msr);
void msrInitTimeSteps(MSR,double,double);
void msrSetuHotContext( MSR msr, UHC *puhc, double a );
#ifdef GASOLINE
void msrUpdateuDot(MSR,double,double,int);
void msrUpdateShockTracker(MSR,double);
void msrInitSph(MSR,double);
int msrSphCurrRung(MSR msr, int iRung, int bGreater);
void msrSphStep(MSR msr, double dTime, int iKickRung);
void msrSphViscosityLimiter(MSR msr, double dTime);
#ifndef NOCOOLING
void msrInitCooling(MSR msr);
#endif
#endif
void msrInitouturb(MSR msr, double dTime);
void msrAccelouturb(MSR msr, double dTime);
void msrSph(MSR msr, double dTime, int iKickRung);
int msrDumpFrameInit(MSR msr, double dTime, double dStep, int bRestart);
void msrDumpFrame(MSR msr, double, double);
void msrTreeZip(MSR msr, int iStep);
#ifdef GLASS
void msrInitGlass(MSR);
#endif
#ifdef COLLISIONS
void msrFindRejects(MSR msr);
double msrReadSS(MSR msr);
void msrWriteSS(MSR msr, char *pszFileName, double dTime);
void msrWriteSSHead(MSR msr,char *achOutFile,double dTime);
void msrPlanetsKDK(MSR msr, double dStep, double dTime, double dDelta,
double *pdWMax, double *pdIMax, double *pdEMax, int *piSec);
void msrPlanetsDrift(MSR msr, double dStep, double dTime, double dDelta);
void msrNextEncounter(MSR msr, double dStart, double dEnd, double *dNext);
void msrMarkEncounters(MSR msr, double dTmax);
void msrLinearKDK(MSR msr, double dStep, double dTime, double dDelta);
void msrDoCollisions(MSR msr, double dTime, double dDelta);
void msrCheckForBinary(MSR msr,double dTime);
void msrDoCollLog(MSR msr,COLLIDER *c1,COLLIDER *c2,struct outDoCollision *outDo,
int option,double dt,double dTime);
#ifdef SLIDING_PATCH
void msrPickNewCoordinates(PARTICLE *p,int n,double *dHill,double dxPeriod,double dyPeriod,double **new,int pick);
void msrRandomizeLargeMasses(MSR msr,int iStep,double dTime);
int msrGetNextRandomTime(int iBaseTime,int iTimeNow);
#endif /* SLIDING_PATCH */
#endif /* COLLISIONS */
#ifdef AGGS
void msrAggsFind(MSR msr);
void msrAggsKick(MSR msr,double dt);
void msrAggsAdvanceOpen(MSR msr);
void msrAggsAdvance(MSR msr,int iAggIdx,Aggregate *agg,double dToTime);
void msrAggsAdvanceClose(MSR msr,double dt);
void msrAggsMerge(MSR msr,COLLIDER *c1,COLLIDER *c2,double dImpactTime,COLLIDER *cOut);
void msrAggsBounce(MSR msr,COLLIDER *c1,COLLIDER *c2,double dImpactTime);
void msrAggsGravity(MSR msr);
#endif
void msrInitStarLog(MSR msr);
void msrFlushStarLog(MSR msr);
void msrFormStars(MSR msr, double dTime, double dDelta);
void msrSimpleStarForm(MSR msr, double dTime, double dDelta);
void _msrGetInflowData(MSR msr, double dTime, double *aflow, double *vflow, double *rflow, double *rhoflow, double *Tflow);
void msrGravInflow(MSR msr,double dTime);
void msrCreateInflow(MSR msr, double dTime, double dDelta);
#ifdef RUBBLE_ZML
void msrDustBinsApply(MSR msr);
void msrRubbleResetColFlag(MSR msr);
void msrRubbleStep(MSR msr);
void msrRubCleanup(MSR msr,double dTime);
#endif
FILE *LogTimingInit( MSR msr, char *fileflag );
void LogTimingZeroCounters( MSR msr );
void LogTimingOutput( MSR msr, FILE *fpLogTiming, double dTime, int bAll );
void LogTimingFinish( MSR msr, FILE *fpLogTiming, double dTime );
void LogTimingSetN( MSR msr, int n );
void LogTimingSetRung ( MSR msr, int iRung );
void LOGTIMINGUPDATE( double, int );
#define LOGTIMINGUPDATE( __dsec, __timingtype) \
if (msr->param.bLogTiming) { \
msr->RungStat[msr->iRungStat].nCall[__timingtype]++; \
msr->RungStat[msr->iRungStat].t[__timingtype]+=__dsec; }
#define LOGTIME( __func, __message, __timingtype ) \
if (msr->param.bVDetails || msr->param.bLogTiming) { \
double __sec, __dsec; \
__sec = msrTime(); \
(__func); \
__dsec = msrTime()-__sec; \
if (msr->param.bVDetails) printf("%s, Wallclock: %f sec\n",__message,__dsec); \
LOGTIMINGUPDATE( __dsec, __timingtype); \
} \
else (__func);
#endif