From abdee14c6dc183eae31cb44b60359ebf2d5fc46e Mon Sep 17 00:00:00 2001 From: Qianqian Fang Date: Wed, 13 Mar 2024 00:12:16 -0400 Subject: [PATCH] [bug] fix multi-source replay bug, close #215 --- src/mcx_core.cu | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) diff --git a/src/mcx_core.cu b/src/mcx_core.cu index 17f8cc8f..aa52ca87 100644 --- a/src/mcx_core.cu +++ b/src/mcx_core.cu @@ -1049,17 +1049,6 @@ __device__ inline int launchnewphoton(MCXpos* p, MCXdir* v, Stokes* s, MCXtime* MCXSrc* launchsrc = &(gcfg->src); ppath[gcfg->w0offset - 1] = 0.f; - if (gcfg->extrasrclen && gcfg->srcid != 1) { - if (gcfg->srcid > 1) { - launchsrc = (MCXSrc*)(gproperty + gcfg->maxmedia + 1 + gcfg->detnum + ((gcfg->srcid - 2) * 4)); - } else { // gcfg->srcid = 0 or -1: simulate all sources; = 0 merge all solutions; = -1 separately store each source - ppath[gcfg->w0offset - 1] = (int)(rand_uniform01(t) * JUST_BELOW_ONE * (gcfg->extrasrclen + 1)) + 1; // borrow initial weight section of photon-sharing for storing launch src id - - if ((int)ppath[gcfg->w0offset - 1] > 1) { - launchsrc = (MCXSrc*)(gproperty + gcfg->maxmedia + 1 + gcfg->detnum + ((int)(ppath[gcfg->w0offset - 1] - 2) * 4)); - } - } - } /** * Early termination of simulation when the detphoton buffer is filled if issavedet is set to 3 @@ -1153,8 +1142,6 @@ __device__ inline int launchnewphoton(MCXpos* p, MCXdir* v, Stokes* s, MCXtime* return 1; // all photos complete } - ppath += gcfg->partialdata; - /** * If this is a replay of a detected photon, initilize the RNG with the stored seed here. */ @@ -1166,6 +1153,20 @@ __device__ inline int launchnewphoton(MCXpos* p, MCXdir* v, Stokes* s, MCXtime* } } + if (gcfg->extrasrclen && gcfg->srcid != 1) { + if (gcfg->srcid > 1) { + launchsrc = (MCXSrc*)(gproperty + gcfg->maxmedia + 1 + gcfg->detnum + ((gcfg->srcid - 2) * 4)); + } else { // gcfg->srcid = 0 or -1: simulate all sources; = 0 merge all solutions; = -1 separately store each source + ppath[gcfg->w0offset - 1] = (int)(rand_uniform01(t) * JUST_BELOW_ONE * (gcfg->extrasrclen + 1)) + 1; // borrow initial weight section of photon-sharing for storing launch src id + + if ((int)ppath[gcfg->w0offset - 1] > 1) { + launchsrc = (MCXSrc*)(gproperty + gcfg->maxmedia + 1 + gcfg->detnum + ((int)(ppath[gcfg->w0offset - 1] - 2) * 4)); + } + } + } + + ppath += gcfg->partialdata; + /** * Attempt to launch a new photon until success */