forked from N-BodyShop/gasoline
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpkd.h
985 lines (884 loc) · 30.4 KB
/
pkd.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
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
#ifndef PKD_HINCLUDED
#define PKD_HINCLUDED
#include <sys/time.h>
#include <sys/resource.h>
#include "mode.h"
#include "mdl.h"
#include "floattype.h"
#include "treezip.h"
#ifdef GASOLINE
#include "cooling.h"
#endif
#include "rotbar.h"
#ifdef SLIDING_PATCH
#include "patch.h"
#endif
/* Allow for creation of this many new gas particles */
#if defined(INFLOWOUTFLOW) || defined(FBPARTICLE) || defined(PARTICLESPLIT)
#define NIORDERGASBUFFER 1000000000
#else
#define NIORDERGASBUFFER 0
#endif
/*
** The following sort of definition should really be in a global
** configuration header file -- someday...
*/
#if defined(GASOLINE) || defined(ROT_FRAME) || defined(SIMPLE_GAS_DRAG) || defined(GR_DRAG)
#define NEED_VPRED
#endif
//There are a handful of TYPE bits we never want leaving a local thread or a smooth call.
#define TYPE_MASK (~TYPE_RESMOOTHINNER & ~TYPE_MARK)
/* SPH variable ALPHA */
#define ALPHAMIN 0.01
#define ALPHAMAX 1
#ifdef SUPERBUBBLE
#define PROMOTE
#define THERMALCOND
#define TWOPHASE
#define TOPHATFEEDBACK
#endif
#if defined(TWOPHASE) && !defined(UNONCOOL)
#define UNONCOOL
#endif
#if defined(FEEDBACKDIFFLIMIT) && !defined(DIFFUSIONHARMONIC)
#define DIFFUSIONHARMONIC
#endif
#define DIFFRATE(p_) ((p_)->diff)
/* Note: UDOT_HYDRO is only correct if there is only thermal pressure (no UNONCOOL or Jeans Floor) */
#define UDOT_HYDRO(p_) ((p_)->uDotPdV+(p_)->uDotAV+(p_)->uDotDiff)
#define PONRHOFLOOR 0
#define StarClusterFormfBall2Save(p) (p->curlv[0])
#define StarClusterFormiOrder(p) (p->curlv[1])
/* (note bVWarnings still applies) */
#define CID_TOP 0
#define CID_PARTICLE 0
#define CID_CELL 1
#define ROOT 1
#define LOWER(i) (i<<1)
#define UPPER(i) ((i<<1)+1)
#define PARENT(i) (i>>1)
#define SIBLING(i) ((i&1)?i-1:i+1)
#define SETNEXT(i) \
{ \
while (i&1) i=i>>1; \
++i; \
}
#define MAX_TIMERS 10
typedef struct particle {
int iOrder;
unsigned int iActive;
int iRung;
int cpStart;
FLOAT fWeight;
FLOAT fMass;
FLOAT fSoft;
FLOAT fSoft0;
FLOAT r[3];
FLOAT v[3];
FLOAT a[3];
FLOAT fPot;
FLOAT fBall2;
FLOAT fDensity;
FLOAT dt; /* a time step suggestion */
FLOAT dtNew; /* SPH new dt estimate */
FLOAT dtOld; /* SPH Old dt */
FLOAT dtGrav; /* suggested 1/dt^2 from gravity */
#ifdef SLIDING_PATCH
FLOAT dPy; /* Canonical momentum for Hill eqn. */
#endif
FLOAT fBallMax; /* SPH 2h Max value */
#ifdef GASOLINE
FLOAT c; /* sound speed */
FLOAT PoverRho2; /* P/rho^2 */
FLOAT mumax; /* sound speed like viscosity term (OBSOLETE) */
FLOAT u; /* thermal energy */
FLOAT uPred; /* predicted thermal energy, */
FLOAT uDotPdV; /* PdV heating [Sink Lx] */
FLOAT uDotAV; /* Shock Heating (Artificial Viscosity) [Sink Ly] */
FLOAT uDotDiff; /* Thermal Energy diffusion [Sink Lz] */
#ifndef NOCOOLING
FLOAT uDot; /* Rate of change of u -- for predicting u */
COOLPARTICLE CoolParticle; /* Abundances and any other cooling internal variables */
#endif
#ifdef TWOPHASE
FLOAT fMassHot;
COOLPARTICLE CoolParticleHot; /* Abundances and any other cooling internal variables */
#endif
#ifdef UNONCOOL
FLOAT uHot;
FLOAT uHotPred;
FLOAT uHotDot;
FLOAT uHotDotDiff; /* Hot Energy diffusion */
#endif
FLOAT divv;
FLOAT dvds;
#ifdef VARALPHA
FLOAT alpha;
FLOAT alphaPred;
#endif
#ifdef CULLENDEHNEN
FLOAT alpha;
FLOAT dTime_divv;
FLOAT divv_old; // stored old value for checking that nbrs also all compressing
#endif
FLOAT curlv[3]; /* Note this is used as workspace and value is not preserved */
FLOAT BalsaraSwitch; /* Balsara viscosity reduction */
#ifdef THERMALCOND
FLOAT fThermalCond;
FLOAT fThermalLength;
#endif
FLOAT diff;
FLOAT fMetalsDot;
FLOAT fMetalsPred;
FLOAT fDivv_t;
FLOAT fDivv_Corrector;
#ifdef SURFACEAREA
FLOAT fArea;
#ifdef NORMAL
FLOAT normal[3];
#endif
#endif
/* FLOAT fDensSave;*/ /* Used by diagnostic DensCheck funcs */
FLOAT fMetals; /* mass fraction in metals, a.k.a, Z */
FLOAT fTimeForm;
#ifdef STARFORM
FLOAT uDotFB;
FLOAT uDotESF;
FLOAT fMSN;
FLOAT fNSN;
FLOAT fMOxygenOut;
FLOAT fMIronOut;
FLOAT fMFracOxygen;
FLOAT fMFracIron;
FLOAT fMFracOxygenDot;
FLOAT fMFracIronDot;
FLOAT fMFracOxygenPred;
FLOAT fMFracIronPred;
FLOAT fSNMetals;
FLOAT fNSNtot;
FLOAT fTimeCoolIsOffUntil;
FLOAT fMassForm; /* record original mass of star */
int iGasOrder; /* gas from which star formed */
#endif
#endif /* GASOLINE */
#ifdef COLLISIONS
int iOrgIdx; /* for tracking of mergers, aggregates etc. */
FLOAT w[3]; /* spin vector */
int iColor; /* handy color tag */
int iDriftType; /* either NORMAL or KEPLER */
double dtCol; /* time to next encounter or collision */
int iOrderCol; /* neighbour or collider iOrder */
double dtPrevCol; /* time of previous collision */
int iPrevCol; /* iOrder of previous collider */
int bTinyStep; /* flag for imminent collapse */
FLOAT mindist2; /* record min dist for all encounters */
int bGhostExclude; /* particle not included in ghost cells */
#endif /* COLLISIONS */
#ifdef SLIDING_PATCH
int bAzWrap; /* flag set on azimuthal boundary wrap */
#endif
#ifdef SAND_PILE
int bStuck;
#endif
#ifdef NEED_VPRED
FLOAT vPred[3]; /* predicted velocity (time centered) */
#endif
#ifdef AGGS
/*
** Position of particle in principal frame of the aggregate
** (normally). We temporarily store the COM frame position
** here during the process of computing the aggregate
** parameters.
*/
FLOAT r_agg[3];
#endif
#ifdef RUBBLE_ZML
double dDustMass; /* predicted mass increase from dust */
int iBin; /* dust bin that planetesimal is in */
int bMayCollide; /* true if planetesimal is predicted to
collide with another planetesimal during
the top step interval */
#endif
} PARTICLE;
#define GAMMA_JEANS (2.0)
#define GAMMA_NONCOOL (5./3.)
#ifdef GLASS
struct GlassData {
/* Glass */
double dGlassPoverRhoL;
double dGlassPoverRhoR;
double dGlassxL;
double dGlassxR;
double dxBoundL;
double dxBoundR;
double dGamma;
};
#endif
struct GasPressureContext {
int iGasModel;
/* Adiabatic */
double gamma;
double gammam1;
double dResolveJeans;
double dCosmoFac;
double dtFacCourant;
/* Isothermal */
/* Ion evolving */
#ifdef GLASS
struct GlassData g;
#endif
#if defined(THERMALCOND) || defined(TWOPHASE)
double dThermalCondCoeffCode;
double dThermalCondSatCoeff;
double dThermalCond2CoeffCode;
double dThermalCond2SatCoeff;
#endif
#if defined(PROMOTE) || defined(TWOPHASE)
double dEvapCoeffCode;
double dEvapMinTemp;
#endif
};
typedef struct uHotContext {
double dHotConvRate;
double dHotConvRateMul;
double dHotConvRateMax;
double dHotConvUMin;
struct GasPressureContext gpc;
#ifdef TWOPHASE
double dMultiPhaseMinTemp;
double dMultiPhaseMaxFrac;
double dMultiPhaseMaxTime;
#endif
} UHC;
#define SINK_Lx(_a) (((PARTICLE *) (_a))->uDotPdV)
#define SINK_Ly(_a) (((PARTICLE *) (_a))->uDotAV)
#define SINK_Lz(_a) (((PARTICLE *) (_a))->uDotDiff)
/* Active Type Masks */
/* Active: -- eg. Calculate new acceleration, PdV, etc... for this particle */
#define TYPE_ACTIVE (1<<0)
/* In the Tree: */
#define TYPE_TREEACTIVE (1<<1)
/* Gather to/Scatter from this particle with in smooths: */
#define TYPE_SMOOTHACTIVE (1<<2)
/* Smooth has processed this particle */
#define TYPE_SMOOTHDONE (1<<3)
/* Types used for Fast Density only (so far) */
/* Sum Fast Density on this particle */
#define TYPE_DensACTIVE (1<<4)
/* Neighbour of ACTIVE (incl. ACTIVE): */
#define TYPE_NbrOfACTIVE (1<<5)
/* Potential Scatter Neighbour */
#define TYPE_Scatter (1<<6)
/* Density set to zero already */
#define TYPE_DensZeroed (1<<7)
/* Particle Type Masks */
#define TYPE_GAS (1<<8)
#define TYPE_DARK (1<<9)
#define TYPE_STAR (1<<10)
#define TYPE_SUPERCOOL (1<<11)
/* Particle marked for deletion. Will be deleted in next
msrAddDelParticles(); */
#define TYPE_DELETED (1<<12)
#define TYPE_PHOTOGENIC (1<<13)
#define TYPE_SINK (1<<14)
#define TYPE_SINKING (1<<15)
#define TYPE_NEWSINKING (1<<16)
#define TYPE_INFLOW (1<<17)
#define TYPE_OUTFLOW (1<<18)
#define TYPE_FEEDBACK (1<<19)
#define TYPE_PROMOTED (1<<20)
#define TYPE_DENMAX (1<<21)
#define TYPE_STARFORM (1<<22)
#define TYPE_MARK (1<<23)
#define TYPE_RESMOOTHINNER (1<<24)
#define TYPE_TWOPHASE (1<<25)
/* Combination Masks */
#define TYPE_ALLACTIVE (TYPE_ACTIVE|TYPE_TREEACTIVE|TYPE_SMOOTHACTIVE)
#define TYPE_ALL (TYPE_GAS|TYPE_DARK|TYPE_STAR)
/* Type Macros */
int TYPEQueryACTIVE ( PARTICLE *a );
int TYPEQueryTREEACTIVE ( PARTICLE *a );
int TYPEQuerySMOOTHACTIVE( PARTICLE *a );
int TYPETest ( PARTICLE *a, unsigned int mask );
int TYPEFilter( PARTICLE *a, unsigned int filter, unsigned int mask );
int TYPESet ( PARTICLE *a, unsigned int mask );
int TYPEReset ( PARTICLE *a, unsigned int mask );
/* This retains Particle Type and clears all flags: */
int TYPEClearACTIVE( PARTICLE *a );
/* Warning: This erases Particle Type */
int TYPEClear( PARTICLE *a );
#define TYPEQueryACTIVE(a) ((a)->iActive & TYPE_ACTIVE)
#define TYPEQueryTREEACTIVE(a) ((a)->iActive & TYPE_TREEACTIVE)
#define TYPEQuerySMOOTHACTIVE(a) ((a)->iActive & TYPE_SMOOTHACTIVE)
#define TYPETest(a,b) ((a)->iActive & (b))
#define TYPEFilter(a,b,c) (((a)->iActive & (b))==(c))
#define TYPESet(a,b) ((a)->iActive |= (b))
#define TYPEReset(a,b) ((a)->iActive &= (~(b)))
#define TYPEClearACTIVE(a) ((a)->iActive &= (TYPE_ALL|TYPE_SUPERCOOL))
#define TYPEClear(a) ((a)->iActive = 0)
enum CheckSanityProblem {
PROBLEM_IORDER,
PROBLEM_MASS,
PROBLEM_SOFT,
PROBLEM_POSITION,
PROBLEM_VELOCITY,
PROBLEM_U,
PROBLEM_METALS,
PROBLEM_ENDLIST
};
/* Alternate if no detailed sanity check is done */
#define CHECKSANEALT(xxx_) xxx_
#define CHECKSANE(w_,x_,y_,z_)
#define CHECKSANEFIX(nProb_,iVar_,iTest_)
#ifdef RUBBLE_ZML
/* RUBBLE_ZML puts extra stuff in the checkpoint file, changes version to indicate this ZML 01.08.04 */
#define CHECKPOINT_VERSION 81
#else
#define CHECKPOINT_VERSION 8
#endif
typedef struct chkParticle {
int iOrder;
int iActive;
FLOAT fMass;
FLOAT fSoft;
FLOAT r[3];
FLOAT v[3];
#ifdef GASOLINE
FLOAT u;
#ifdef TWOPHASE
FLOAT fMassHot;
COOLPARTICLE CoolParticleHot; /* Abundances and any other cooling internal variables */
#endif
#ifdef UNONCOOL
FLOAT uHot;
#endif
#ifdef VARALPHA
FLOAT alpha;
#endif
FLOAT fMetals;
#ifndef NOCOOLING
COOLPARTICLE CoolParticle;
#endif
FLOAT fTimeForm;
#ifdef STARFORM
FLOAT fTimeCoolIsOffUntil;
FLOAT fMassForm; /* record original mass of star */
FLOAT fNSN;
FLOAT fMFracOxygen;
FLOAT fMFracIron;
int iGasOrder;
#endif
#endif
#ifdef COLLISIONS
int iOrgIdx; /* added for version 7 */
FLOAT w[3];
int iColor;
#endif /* COLLISIONS */
} CHKPART;
typedef struct bndBound {
FLOAT fMin[3];
FLOAT fMax[3];
} BND;
/* Used by bLongRangeStep, and -D ONGRANGESTEP */
typedef struct bndDt {
FLOAT vMin[3],vMax[3];
FLOAT cMax,drMax2;
} BNDDT;
#define DIAGDIST2(fDist2,rMin,rMax) { \
FLOAT DD_dx,DD_dy,DD_dz; \
DD_dx = (rMax)[0] - (rMin)[0]; \
DD_dy = (rMax)[1] - (rMin)[1]; \
DD_dz = (rMax)[2] - (rMin)[2]; \
fDist2 = DD_dx*DD_dx+DD_dy*DD_dy+DD_dz*DD_dz; }
struct pkdCalcCellStruct {
double Qxx,Qyy,Qzz,Qxy,Qxz,Qyz;
/*
** Reduced multipole moments for l>2 !!!
*/
double Oxxx,Oxyy,Oxxy,Oyyy,Oxxz,Oyyz,Oxyz;
double Oxzz, Oyzz, Ozzz;
double Hxxxx,Hxyyy,Hxxxy,Hyyyy,Hxxxz,Hyyyz,Hxxyy,Hxxyz,Hxyyz;
double Hxxzz, Hxyzz, Hxzzz, Hyyzz, Hyzzz, Hzzzz;
double Bmax,B2,B3,B4,B5,B6;
};
typedef struct kdNode {
int iDim;
double fSplit;
BND bnd;
BND bndBall; /* Bound including fBall*(1+changemax) */
BNDDT bndDt;
int pLower; /* also doubles as thread id for the LTT */
int pUpper; /* pUpper < 0 indicates no particles in tree! */
int iLower;
int iUpper;
double fMass;
double fSoft;
FLOAT r[3];
struct pkdCalcCellStruct mom;
double fOpen2;
} KDN;
typedef struct ilPart {
double m,h;
double x,y,z;
} ILP;
typedef struct ilCellSoft {
double m,h;
double x,y,z;
double xx,yy,zz,xy,xz,yz;
} ILCS;
/*
** moment tensor components.
*/
typedef struct ilCellNewt {
double m;
double x,y,z;
double xx,yy,xy,xz,yz;
double zz;
double xxx,xyy,xxy,yyy,xxz,yyz,xyz;
double xzz,yzz,zzz;
double xxxx,xyyy,xxxy,yyyy,xxxz,yyyz,xxyy,xxyz,xyyz;
double xxzz,xyzz,xzzz,yyzz,yzzz,zzzz;
} ILCN;
/* IBM brain damage */
#undef hz
typedef struct ewaldTable {
double hx,hy,hz;
double hCfac,hSfac;
} EWT;
typedef struct sfEvent /* Holds statistics of the star
formation event */
{
int iOrdStar;
int iOrdGas;
double timeForm;
double rForm[3];
double vForm[3];
double massForm;
double rhoForm;
double TForm;
#ifdef COOLING_MOLECULARH
double H2fracForm;
#endif
} SFEVENT;
typedef struct starLog
{
int nLog; /* number of events in buffer */
int nMaxLog; /* max size of buffer; increase when needed */
int nOrdered; /* The number of events that have been
globally ordered, incremented by
pkdNewOrder() */
SFEVENT *seTab; /* The actual table */
} STARLOG;
enum SinkEventType {
SINK_EVENT_NULL,
SINK_EVENT_ACCRETE_AT_FORMATION,
SINK_EVENT_FORM,
SINK_EVENT_ACCRETE,
SINK_EVENT_ACCRETE_UPDATE,
SINK_EVENT_MERGER
};
typedef struct sinkEvent /* Holds statistics of the sink/accretion/merger
formation event */
{
int iOrdSink;
int iOrdVictim;
double time;
double mass;
double r[3];
double v[3];
double L[3];
} SINKEVENT;
typedef struct sinkLog
{
int nLog; /* number of events in buffer */
int nMaxLog; /* max size of buffer; increase when needed */
int nLogOrdered; /* The number of events that have been
globally ordered, incremented by
pkdNewOrder() prior to flush */
int nFormOrdered; /* Number of formation events ordered ... */
int nForm; /* Number of new sink formation events in table */
int nAccrete; /* Gas Accrete events */
int nMerge; /* Sink Merger events */
SINKEVENT *SinkEventTab; /* The actual table */
} SINKLOG;
typedef struct pkdContext {
MDL mdl;
int idSelf;
int nThreads;
int nStore;
int nRejects;
int nLocal;
int nActive;
int nTreeActive;
int nSmoothActive;
int nDark;
int nGas;
int nStar;
int nMaxOrderDark;
int nMaxOrderGas;
int nMaxOrder;
int nBucket;
int nLevels;
int nSplit;
int nNodes;
int iExtraBucket;
int iOrder;
int iFreeCell;
int iRoot;
FLOAT fPeriod[3];
FLOAT dxInflow, dxOutflow;
int *piLeaf;
KDN *kdTop;
KDN *kdNodes;
PARTICLE *pStore;
double duTFac;
double dvFac;
/*
** gravitational interaction lists
*/
int nMaxPart;
int nMaxCellSoft;
int nMaxCellNewt;
int nPart;
int nCellSoft;
int nCellNewt;
int nSqrtTmp;
ILP *ilp;
ILCS *ilcs;
ILCN *ilcn;
double *sqrttmp;
double *d2a;
/*
** Ewald summation setup.
*/
ILCN ilcnRoot;
int nMaxEwhLoop;
int nEwhLoop;
EWT *ewt;
/*
** Timers stuff.
*/
struct timer {
double sec;
double stamp;
double system_sec;
double system_stamp;
double wallclock_sec;
double wallclock_stamp;
int iActive;
} ti[MAX_TIMERS];
#ifdef GASOLINE
/*
** Cooling
*/
#ifndef NOCOOLING
COOL *Cool;
#endif
#ifdef OUTURBDRIVER
void *outurb;
#endif
STARLOG starLog;
#endif
SINKLOG sinkLog;
#ifdef SLIDING_PATCH
/*
** Info needed for sliding patch model...
*/
double dTime;
PATCH_PARAMS *PP;
#endif
ROTBAR rotbar;
} * PKD;
int pkdIsGas(PKD,PARTICLE *);
#define pkdIsGas( pkd, pTMP) TYPETest( (pTMP), TYPE_GAS )
int pkdIsDark(PKD,PARTICLE *);
#define pkdIsDark( pkd, pTMP) TYPETest( (pTMP), TYPE_DARK )
int pkdIsStar(PKD,PARTICLE *);
#define pkdIsStar( pkd, pTMP) TYPETest( (pTMP), TYPE_STAR )
int pkdIsGasByOrder(PKD pkd,PARTICLE *p);
int pkdIsDarkByOrder(PKD pkd,PARTICLE *p);
int pkdIsStarByOrder(PKD pkd,PARTICLE *p);
typedef struct CacheStatistics {
double dpNumAccess;
double dpMissRatio;
double dpCollRatio;
double dpMinRatio;
double dcNumAccess;
double dcMissRatio;
double dcCollRatio;
double dcMinRatio;
} CASTAT;
/* JW: */
#define GASMODEL_UNSET -1
enum GasModel {
GASMODEL_ADIABATIC,
GASMODEL_ISOTHERMAL,
GASMODEL_COOLING,
GASMODEL_GLASS
};
#define PKD_ORDERTEMP 256
#define pkdRoot(iCell,id) \
{ \
id = -1; \
iCell = ROOT; \
}
#define pkdIsRoot(iCell,id) ((id==-1)?((iCell==ROOT)?1:0):0)
/*
* There is now a slight inefficency here when going from the top tree to
* a node tree in that we visit the root cell twice (once as the leaf of the
* top tree and once as the root of the node tree). This is necessary to
* check if the root cell is a bucket.
*/
#define pkdLower(pkd,iCell,id) \
{ \
if (id == -1) { \
id = pkd->kdTop[iCell].pLower; \
if (id != -1) iCell = ROOT; \
else iCell = LOWER(iCell); \
} \
else iCell = LOWER(iCell); \
}
#define pkdUpper(pkd,iCell,id) \
{ \
if (id == -1) { \
id = pkd->kdTop[iCell].pLower; \
if (id != -1) iCell = ROOT; \
else iCell = UPPER(iCell); \
} \
else iCell = UPPER(iCell); \
}
#define pkdParent(pkd,iCell,id) \
{ \
iCell = PARENT(iCell); \
if (iCell == ROOT) { \
if (id != -1) { \
iCell = pkd->piLeaf[id]; \
id = -1; \
} \
} \
}
#define pkdNext(pkd,iCell,id) \
{ \
SETNEXT(iCell); \
if (iCell == ROOT) { \
if (id != -1) { \
iCell = pkd->piLeaf[id]; \
id = -1; \
SETNEXT(iCell); \
} \
} \
}
double pkdGetTimer(PKD,int);
double pkdGetSystemTimer(PKD,int);
double pkdGetWallClockTimer(PKD,int);
void pkdClearTimer(PKD,int);
void pkdStartTimer(PKD,int);
void pkdStopTimer(PKD,int);
void pkdInitialize(PKD *,MDL,int,int,int,FLOAT *,FLOAT,FLOAT,int,int,int);
void pkdFinish(PKD);
void pkdReadTipsy(PKD,char *,int,int,int,int,double,double);
void pkdOutputBlackHoles(PKD pkd,char *pszFileName, double dvFac);
void pkdSetSoft(PKD pkd,double dSoft);
void pkdPhysicalSoft(PKD pkd,double, double, int);
void pkdPreVariableSoft(PKD pkd,int iVariableSoftType);
void pkdPostVariableSoft(PKD pkd,double dSoftMax,int bSoftMaxMul,int iVariableSoftType);
void pkdCalcBound(PKD,BND *,BND *,BND *,BND *, BNDDT *);
void pkdGasWeight(PKD);
void pkdRungDDWeight(PKD, int, double);
int pkdWeight(PKD,int,FLOAT,int,int,int,int *,int *,FLOAT *,FLOAT *);
int pkdLowerPart(PKD,int,FLOAT,int,int);
int pkdUpperPart(PKD,int,FLOAT,int,int);
int pkdWeightWrap(PKD,int,FLOAT,FLOAT,int,int,int,int *,int *,FLOAT *,FLOAT *);
int pkdLowerPartWrap(PKD,int,FLOAT,FLOAT,int,int);
int pkdUpperPartWrap(PKD,int,FLOAT,FLOAT,int,int);
int pkdLowerOrdPart(PKD,int,int,int);
int pkdUpperOrdPart(PKD,int,int,int);
int pkdActiveTypeOrder(PKD, unsigned int);
int pkdActiveOrder(PKD);
int pkdColRejects(PKD,int,FLOAT,FLOAT,int);
int pkdSwapRejects(PKD,int);
int pkdSwapSpace(PKD);
int pkdFreeStore(PKD);
int pkdLocal(PKD);
void pkdTotals(PKD pkd, int *nDark, int *nGas, int *nStar);
int pkdActive(PKD);
int pkdTreeActive(PKD);
int pkdInactive(PKD);
int pkdTreeInactive(PKD);
int pkdNodes(PKD);
void pkdDomainColor(PKD);
int pkdColOrdRejects(PKD,int,int);
void pkdLocalOrder(PKD);
void pkdWriteTipsy(PKD,char *,int,int,double,double,int);
void pkdTreeZip(PKD pkd,char *pszFileName, double *dmin, double *dmax);
void pkdCombine(KDN *,KDN *,KDN *);
void pkdCalcCell(PKD,KDN *,FLOAT *,int,struct pkdCalcCellStruct *);
double pkdCalcOpen(KDN *,int,double,int);
void pkdBuildLocal(PKD,int,int,double,int,int,int,KDN *);
void pkdBuildBinary(PKD,int,int,double,int,int,int,KDN *);
void pkdThreadTree(PKD pkd,int iCell,int iNext);
void pkdGravAll(PKD pkd,int nReps,int bPeriodic,int iOrder, int bEwald,int iEwOrder,
double fEwCut,double fEwhCut, int bComove, double dRhoFac,
int bDoSun,double dSunSoft, double *aSun,int *nActive,
double *pdPartSum,double *pdCellSum,double *pdSoftSum,CASTAT *pcs,
double *pdFlop);
void pkdCalcEandL(PKD,double *,double *,double *,double []);
void pkdCalcEandLExt(PKD,double *,double[],double [],double *);
void pkdDrift(PKD,double,FLOAT *,int,int,int,FLOAT,double);
double pkduHotConvRate(PKD pkd, UHC uhc, FLOAT fBall2, double uHotPred, double uPred);
void pkdUpdateuDot(PKD pkd, double duDelta, double dTime, double z, UHC uhc, int iGasModel, int bUpdateState );
void pkdKick(PKD pkd, double dvFacOne, double dvFacTwo, double dvPredFacOne,
double dvPredFacTwo, double duDelta, double duPredDelta, int iGasModel,
double z, double duDotLimit, double dTimeEnd, UHC uhc );
void pkdEmergencyAdjust(PKD pkd, int iRung, int iMaxRung, double dDelta, double dDeltaThresh, int *pnUn, int *piMaxRungIdeal, int *pnMaxRung, int *piMaxRungOut);
void pkdKickPatch(PKD pkd, double dvFacOne, double dvFacTwo,
double dOrbFreq, int bOpen);
void pkdGravInflow(PKD pkd, double r);
void pkdCreateInflow(PKD pkd, int Ny, int iGasModel, double dTuFac, double pmass, double x, double vx, double density, double temp, double metals, double eps, double dt, int iRung);
void pkdReadCheck(PKD,char *,int,int,int,int);
void pkdWriteCheck(PKD,char *,int,int);
void pkdDistribCells(PKD,int,KDN *);
void pkdCalcRoot(PKD,struct ilCellNewt *);
void pkdDistribRoot(PKD,struct ilCellNewt *);
void pkdSwapAll(PKD pkd, int idSwap);
double pkdMassCheck(PKD pkd);
void pkdMassMetalsEnergyCheck(PKD pkd, double *dTotMass, double *dTotMetals,
double *dTotOx, double *dTotFe, double *dTotEnergy);
void pkdSetRung(PKD pkd, int iRung);
void pkdBallMax(PKD pkd, int iRung, int bGreater, double ddHonHLimit);
int pkdActiveRung(PKD pkd, int iRung, int bGreater);
int pkdCurrRung(PKD pkd, int iRung);
void pkdGravStep(PKD pkd, double dEta);
void pkdAccelStep(PKD pkd, double dEta, double dVelFac, double
dAccFac, int bDoGravity, int bEpsAcc, int bSqrtPhi, double dhMinOverSoft);
void pkdDensityStep(PKD pkd, double dEta, double dRhoFac);
int pkdOneParticleDtToRung( int iRung,double dDelta,double dt);
int pkdDtToRung(PKD pkd, int iRung, double dDelta, int iMaxRung, int bAll, int bDiagExceed,
int *pnMaxRung, int *piMaxRungIdeal );
void pkdInitDt(PKD pkd, double dDelta);
int pkdRungParticles(PKD,int);
void pkdCoolVelocity(PKD,int,double,double,double);
void pkdGrowMass(PKD pkd,int nGrowMass, int iGrowType, double dDeltaM, double dMinM, double dMaxM);
void pkdInitAccel(PKD);
void pkdModifyAccel(PKD pkd, double);
int pkdOrdWeight(PKD,int,int,int,int,int *,int *);
void pkdUnDeleteParticle(PKD pkd, PARTICLE *p);
void pkdDeleteParticle(PKD pkd, PARTICLE *p);
void pkdNewParticle(PKD pkd, PARTICLE p);
int pkdResetTouchRung(PKD pkd, unsigned int iTestMask, unsigned int iSetMask);
int pkdActiveExactType(PKD pkd, unsigned int iFilterMask, unsigned int iTestMask, unsigned int iSetMask);
int pkdActiveType(PKD pkd, unsigned int iTestMask, unsigned int iSetMask);
int pkdSetType(PKD pkd, unsigned int iTestMask, unsigned int iSetMask);
int pkdResetType(PKD pkd, unsigned int iTestMask, unsigned int iSetMask);
int pkdCountType(PKD pkd, unsigned int iFilterMask, unsigned int iTestMask);
int pkdActiveMaskRung(PKD pkd, unsigned int iSetMask, int iRung, int bGreater );
int pkdActiveTypeRung(PKD pkd, unsigned int iTestMask, unsigned int iSetMask, int iRung, int bGreater);
int pkdSetTypeFromFile(PKD pkd, int iSetMask, int biGasOrder, char *file, int *pniOrder, int *pnSet, int *pnSetiGasOrder);
void pkdSetParticleTypes(PKD pkd, int nSuperCool);
struct SoughtParticle {
int iOrder;
int iActive;
double x,y,z,m;
};
int pkdSoughtParticleList(PKD pkd, int iTypeSought, int nMax, int *n, struct SoughtParticle *sp);
void pkdCoolUsingParticleList(PKD pkd, int nList, struct SoughtParticle *sp);
void pkdColNParts(PKD pkd, int *pnNew, int *nAddGas, int *nAddDark,
int *nAddStar, int *nDelGas, int *nDelDark, int *nDelStar);
void pkdNewOrder(PKD pkd, int nStartGas, int nStarDark, int nStartStar);
void pkdMoveParticle(PKD pkd, double *xcenter,double *xoffset,int iOrder);
struct outGetNParts {
int n;
int nGas;
int nDark;
int nStar;
int iMaxOrderGas;
int iMaxOrderDark;
int iMaxOrderStar;
};
void pkdGetNParts(PKD pkd, struct outGetNParts *out );
void pkdSetNParts(PKD pkd, int nGas, int nDark, int nStar, int, int nMaxOrderGas,
int nMaxOrderDark);
void pkdSunIndirect(PKD,double *,int,double,double);
void pkdLogHalo(PKD, double, double, double, double);
void pkdHernquistSpheroid(PKD pkd);
void pkdNFWSpheroid(PKD pkd, double M_200, double r_200, double c, double dSoft);
void pkdElliptical(PKD pkd, int bEllipticalDarkNFW);
void pkdHomogSpheroid(PKD pkd, double M_s, double R_s);
void pkdBodyForce(PKD pkd, double dConst);
void pkdGalaxyDiskVerticalPotentialForce(PKD pkd, double Vc, double R, double StarSigma, double StarH, double GasSigma, double GasH, double Gasa, double Gasb, double Gasc);
void pkdMiyamotoDisk(PKD pkd);
void pkdTimeVarying(PKD pkd,double dTime);
double pkdDtFacCourant( double dEtaCourant, double dCosmoFac );
#ifdef ROT_FRAME
void pkdRotFrame(PKD pkd, double dOmega, double dOmegaDot);
#endif
#ifdef GASOLINE
void pkdUpdateuDot(PKD pkd, double duDelta, double dTime, double z, UHC uhc, int iGasModel, int bUpdateState );
void pkdUpdateShockTracker(PKD,double, double, double);
double pkdPoverRhoFloorJeansParticle(PKD pkd, double dResolveJeans, PARTICLE *p);
void pkdSetThermalCond(PKD pkd, struct GasPressureContext *pgpc, PARTICLE *p);
void pkdGasPressureParticle(PKD pkd, struct GasPressureContext *pgpc, PARTICLE *p,
double *pPoverRhoFloorJeans, double *pPoverRhoHot, double *pPoverRhoGas, double *pcGas );
void pkdGasPressure(PKD, struct GasPressureContext *pgpc);
void pkdGetDensityU(PKD, double);
void pkdLowerSoundSpeed(PKD, double);
void pkdInitEnergy(PKD pkd, double dTuFac, double z, double dTime );
void pkdKickRhopred(PKD pkd, double dHubbFac, double dDelta);
int pkdSphCurrRung(PKD pkd, int iRung, int bGreater);
void pkdSphStep(PKD pkd, double dCosmoFac, double dEtaCourant, double dEtauDot, double duMindt, double dDiffCoeff, double dEtaDiffusion, double dResolveJeans, int bViscosityLimitdt, double *pdtMinGas);
void pkdSinkStep(PKD pkd, double dtMax );
void pkdSetSphStep(PKD pkd, double dt );
void pkdSphViscosityLimiter(PKD pkd, int bOn, int bShockTracker);
void pkdDensCheck(PKD pkd, int iRung, int bGreater, int iMeasure, void *data);
#endif /* GASOLINE */
#ifdef GLASS
void pkdGlassGasPressure(PKD, void *in);
void pkdRandomVelocities(PKD pkd, double dMaxVL, double dMaxVR);
#endif
#ifdef SLIDING_PATCH
double SHEAR(int,double,PATCH_PARAMS *);
#define SHEAR(ix,t,pp) \
((ix) < 0 ? fmod(0.5*(pp)->dLength - 1.5*(ix)*(pp)->dOrbFreq*(pp)->dWidth*(t),(pp)->dLength) - 0.5*(pp)->dLength: \
(ix) > 0 ? 0.5*(pp)->dLength - fmod(0.5*(pp)->dLength + 1.5*(ix)*(pp)->dOrbFreq*(pp)->dWidth*(t),(pp)->dLength): 0.0)
void pkdPatch(PKD pkd);
int pkdRandAzWrap(PKD pkd);
#endif
#ifdef COLLISIONS
int pkdNumRejects(PKD pkd);
void pkdReadSS(PKD pkd, char *pszFileName, int nStart, int nLocal);
void pkdWriteSS(PKD pkd, char *pszFileName, int nStart);
void pkdKickUnifGrav(PKD pkd, double dvx, double dvy, double dvz);
void pkdNextEncounter(PKD pkd, double *dt);
void pkdMarkEncounters(PKD pkd, double dt);
#ifdef SIMPLE_GAS_DRAG
void pkdSimpleGasDrag(PKD pkd,int iFlowOpt,int bEpstein,double dGamma,
double dTime);
#endif
#endif /* COLLISIONS */
void pkdMassInR(PKD pkd, double R, double *pdMass, FLOAT *com);
#ifdef NEED_VPRED
#ifdef GASOLINE
void pkdKickVpred(PKD pkd,double dvFacOne,double dvFacTwo,double duDelta,
int iGasModel,double z,double duDotLimit, double dTimeEnd,UHC uhc);
#else
void pkdKickVpred(PKD pkd, double dvFacOne, double dvFacTwo);
#endif
#endif
void pkdInitRotBar(PKD pkd, ROTBAR rotbar);
void pkdRotatingBar(PKD pkd, double amp, /* relative amplitude of bar */
double posang, /* position angle of bar */
double b5, /* radial scale length (^5) */
FLOAT *aCom, /* Center of mass */
double *accCom, /* acceleration (returned) */
double *dTorque); /* acceleration (returned) */
void pkdCOM(PKD pkd, double *com);
void pkdCOMByType(PKD pkd, int type, double *com);
void pkdOldestStar(PKD pkd, double *com);
int pkdSetSink(PKD pkd, double dSinkMassMin);
void pkdFormSinks(PKD pkd, int bJeans, double dJConst2, int bDensity, double dDensityCut, double dTime, int iKickRung, int bSimple, int *nCandidates, double *Jvalmin);
void pkdSinkLogInit(PKD pkd);
void pkdSinkLogFlush(PKD pkd, char *pszFileName);
#ifdef PARTICLESPLIT
void pkdSplitGas(PKD pkd, double dInitGasMass);
#endif
#endif /* PKD_HINCLUDED */