Skip to content

Commit

Permalink
Merge pull request #1105 from jhmatthews/dev
Browse files Browse the repository at this point in the history
Fix istat logic for bug #1093
  • Loading branch information
jhmatthews authored Oct 18, 2024
2 parents 9a9cf31 + 8cfc8f3 commit 7716844
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 5 deletions.
3 changes: 1 addition & 2 deletions docs/sphinx/source/physics/limitations.rst
Original file line number Diff line number Diff line change
Expand Up @@ -63,5 +63,4 @@ This limitation can be important even if the input radiation field is steady. Fo

At present, Python is (at most) a 2.5-dimensional code. That is, the coordinate grid is restricted to 2D and assumed to be symmetric about the y-axis. However, photon packet transport takes place in 2D and allows for a rotational component of motion around the y-axis. In principle, upgrading Python to "full" 3D is fairly straightforward, but running such models would require significantly more computing resources. Memory requirements, in particular, scale directly with the number of grid cells used in a simulation. This is actually already a limitation for high-resolution models in 2D (or 2.5-D) and the reason we have set an upper limit of 500x500 cells as a default.

It is worth noting that Python's memory requirements for computationally demanding simulations are driven by the approach to parallelization that has been adopted. Currently, parallelization relies exclusively on ``MPI`` and requires the computational grid to be copied in full to each ``MPI`` process (i.e. each core). Memory requirements therefore increase rapidly as the number of processors is increased. This situation could be improved by adopting a hybrid ``OpenMP`` and ``MPI`` approach.

It is worth noting that Python's memory requirements for computationally demanding simulations are driven by the approach to parallelization that has been adopted. Currently, parallelization relies exclusively on ``MPI`` and requires the computational grid to be copied in full to each ``MPI`` process (i.e. each core). Memory requirements therefore increase rapidly as the number of processors is increased. This situation could be improved by adopting a hybrid ``OpenMP`` and ``MPI`` approach.
2 changes: 1 addition & 1 deletion source/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ LDFLAGS+= -L$(LIB) -lm -lgsl -lgslcblas $(CUDA_LIBS)
#Note that version should be a single string without spaces.


VERSION = 88f
VERSION = 88x



Expand Down
18 changes: 16 additions & 2 deletions source/trans_phot.c
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,6 @@ trans_phot (WindPtr w, PhotPtr p, int iextract)
}

trans_phot_single (w, &p[nphot], iextract);

}

Log ("\n");
Expand Down Expand Up @@ -466,6 +465,22 @@ trans_phot_single (WindPtr w, PhotPtr p, int iextract)
}
}

if (pp.w < weight_min)
{
pp.istat = P_ABSORB;
pp.tau = VERY_BIG;
stuff_phot (&pp, p);
break;
}

if (pp.istat == P_ERROR_MATOM || pp.istat == P_LOFREQ_FF || pp.istat == P_ADIABATIC)
{
p->istat = pp.istat;
pp.tau = VERY_BIG;
stuff_phot (&pp, p);
break;
}

/* Now extract photons if we are in detailed the detailed spectrum portion of the program
* N.B. To use the anisotropic scattering option, extract needs to follow scatter.
* This is because the re-weighting which occurs in extract needs the pdf for scattering
Expand Down Expand Up @@ -520,7 +535,6 @@ trans_phot_single (WindPtr w, PhotPtr p, int iextract)

/* This is an insurance policy but it is not obvious that, for example nscat
* and nrscat, need to be updated */

p->istat = istat;
p->nscat = pp.nscat;
p->nrscat = pp.nrscat;
Expand Down

0 comments on commit 7716844

Please sign in to comment.