Skip to content

Commit

Permalink
add missing full RHS call for rootfinding with fixed steps
Browse files Browse the repository at this point in the history
  • Loading branch information
gardner48 committed Dec 8, 2024
1 parent f7208a4 commit 239a55c
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 9 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,11 @@ provided.

Fixed the loading of ARKStep's default first order explicit method.

Fixed a bug in ARKODE when enabling rootfinding with fixed step sizes and the
initial value of the rootfinding function is zero. In this case, uninitialized
right-hand side data was used to compute a state value near the initial
condition to determine if any rootfinding functions are initially active.

Fixed a CMake bug regarding usage of missing "print_warning" macro
that was only triggered when the deprecated `CUDA_ARCH` option was used.

Expand Down
5 changes: 5 additions & 0 deletions doc/shared/RecentChanges.rst
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,11 @@ of ``0`` was provided.

Fixed the loading of ARKStep's default first order explicit method.

Fixed a bug in ARKODE when enabling rootfinding with fixed step sizes and the
initial value of the rootfinding function is zero. In this case, uninitialized
right-hand side data was used to compute a state value near the initial
condition to determine if any rootfinding functions are initially active.

Fixed a CMake bug regarding usage of missing "print_warning" macro
that was only triggered when the deprecated ``CUDA_ARCH`` option was used.

Expand Down
8 changes: 1 addition & 7 deletions src/arkode/arkode.c
Original file line number Diff line number Diff line change
Expand Up @@ -2138,13 +2138,7 @@ int arkInitialSetup(ARKodeMem ark_mem, sunrealtype tout)
if (ark_mem->root_mem->nrtfn > 0)
{
retval = arkRootCheck1((void*)ark_mem);

if (retval == ARK_RTFUNC_FAIL)
{
arkProcessError(ark_mem, ARK_RTFUNC_FAIL, __LINE__, __func__, __FILE__,
MSG_ARK_RTFUNC_FAILED, ark_mem->tcur);
return (ARK_RTFUNC_FAIL);
}
if (retval != ARK_SUCCESS) { return retval; }
}
}

Expand Down
28 changes: 26 additions & 2 deletions src/arkode/arkode_root.c
Original file line number Diff line number Diff line change
Expand Up @@ -434,7 +434,12 @@ int arkRootCheck1(void* arkode_mem)
retval = rootmem->gfun(rootmem->tlo, ark_mem->yn, rootmem->glo,
rootmem->root_data);
rootmem->nge = 1;
if (retval != 0) { return (ARK_RTFUNC_FAIL); }
if (retval != 0)
{
arkProcessError(ark_mem, ARK_RTFUNC_FAIL, __LINE__, __func__, __FILE__,
MSG_ARK_RTFUNC_FAILED, ark_mem->tcur);
return (ARK_RTFUNC_FAIL);
}

zroot = SUNFALSE;
for (i = 0; i < rootmem->nrtfn; i++)
Expand All @@ -447,14 +452,33 @@ int arkRootCheck1(void* arkode_mem)
}
if (!zroot) { return (ARK_SUCCESS); }

/* call full RHS if needed */
if (!(ark_mem->fn_is_current))
{
retval = ark_mem->step_fullrhs(ark_mem, ark_mem->tn, ark_mem->yn,
ark_mem->fn, ARK_FULLRHS_START);
if (retval)
{
arkProcessError(ark_mem, ARK_RHSFUNC_FAIL, __LINE__, __func__,
__FILE__, MSG_ARK_RHSFUNC_FAILED, ark_mem->tcur);
return ARK_RHSFUNC_FAIL;
}
ark_mem->fn_is_current = SUNTRUE;
}

/* Some g_i is zero at t0; look at g at t0+(small increment). */
hratio = SUNMAX(rootmem->ttol / SUNRabs(ark_mem->h), TENTH);
smallh = hratio * ark_mem->h;
tplus = rootmem->tlo + smallh;
N_VLinearSum(ONE, ark_mem->yn, smallh, ark_mem->fn, ark_mem->ycur);
retval = rootmem->gfun(tplus, ark_mem->ycur, rootmem->ghi, rootmem->root_data);
rootmem->nge++;
if (retval != 0) { return (ARK_RTFUNC_FAIL); }
if (retval != 0)
{
arkProcessError(ark_mem, ARK_RTFUNC_FAIL, __LINE__, __func__, __FILE__,
MSG_ARK_RTFUNC_FAILED, ark_mem->tcur);
return (ARK_RTFUNC_FAIL);
}

/* We check now only the components of g which were exactly 0.0 at t0
* to see if we can 'activate' them. */
Expand Down

0 comments on commit 239a55c

Please sign in to comment.