Skip to content
This repository has been archived by the owner on Jul 17, 2024. It is now read-only.

Commit

Permalink
Merge pull request #26 from nlmixr2/25-simulation-with-iov-not-accept…
Browse files Browse the repository at this point in the history
…ing-lotri-matrix-for-omega

Fix for cvPost
  • Loading branch information
mattfidler authored Jun 7, 2024
2 parents 282b76a + d48d510 commit e67d249
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 16 deletions.
6 changes: 3 additions & 3 deletions CRAN-SUBMISSION
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
Version: 2.1.0
Date: 2024-05-25 23:39:06 UTC
SHA: 2d3961f6300b8e585c8d859e3cfba49dcbe12d96
Version: 2.1.1
Date: 2024-05-25 23:54:54 UTC
SHA: 4119733f949e30b97c6a83fe737cdcc45235e9b9
2 changes: 1 addition & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
Package: rxode2random
Title: Random Number Generation Functions for 'rxode2'
Version: 2.1.1
Version: 2.1.1.9000
Authors@R: c(
person("Matthew L.", "Fidler", , "[email protected]", role = c("aut", "cre"),
comment = c(ORCID = "0000-0001-8538-6691")),
Expand Down
4 changes: 4 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
# rxode2random (development version)

- Fix a bug when simulating nested variables (#25)

# rxode2random 2.1.0

- **Breaking Change** changed distributions from the standard C++
Expand Down
36 changes: 24 additions & 12 deletions src/cvPost.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -873,7 +873,7 @@ SEXP expandPars_(SEXP objectS, SEXP paramsS, SEXP eventsS, SEXP controlS) {
ni = nestingInfo_(omegaLotri, eventsL);
IntegerVector idIV = as<IntegerVector>(ni["id"]);//length(levels(.ni$id))
nid = Rf_length(Rf_getAttrib(idIV, R_LevelsSymbol));
if (nid <= 1){
if (nid <= 1) {
} else if (nSub <= 1) {
// control[Rxc_nSub] = nid;
nSub = nid;
Expand Down Expand Up @@ -934,11 +934,20 @@ SEXP expandPars_(SEXP objectS, SEXP paramsS, SEXP eventsS, SEXP controlS) {
methodStr = as<std::string>(control[Rxc_omegaSeparation]);
methodInt = getMethodInt(methodStr, allNames, et);

if (Rf_isNull(lotriAbove)) {
aboveSEXP = R_NilValue;
rxModelsAssign(".nestEvents", events);
rxModelsAssign(".nestEta", R_NilValue);
rxModelsAssign(".nestTheta", R_NilValue);
}

if (!Rf_isNull(aboveSEXP)) {
// Create an extra theta matrix list
//
// Note this is for between study variability and the
// method/specification comes from omega, so methodInt comes from omegaSeparation
// method/specification comes from omega, so methodInt comes from
// omegaSeparation

SEXP thetaList = PROTECT(cvPost_(et, lotriAbove,
nStudS,
LogicalVector::create(false),
Expand All @@ -955,16 +964,16 @@ SEXP expandPars_(SEXP objectS, SEXP paramsS, SEXP eventsS, SEXP controlS) {
NumericVector upper = bounds[0];
NumericVector lower = bounds[1];
// With
NumericMatrix aboveMat = rxRmvnSEXP(IntegerVector::create(1),
R_NilValue, thetaList,
upper, lower, // lower upper
control[Rxc_nCoresRV],
LogicalVector::create(false), // isChol
LogicalVector::create(true), // keepNames
NumericVector::create(0.4), // a
NumericVector::create(2.05), // tol
NumericVector::create(1e-10), // nlTol
IntegerVector::create(100)); // nlMaxiter
NumericMatrix aboveMat = rxRmvnSEXP(IntegerVector::create(1),
R_NilValue, thetaList,
upper, lower, // lower upper
control[Rxc_nCoresRV],
LogicalVector::create(false), // isChol
LogicalVector::create(true), // keepNames
NumericVector::create(0.4), // a
NumericVector::create(2.05), // tol
NumericVector::create(1e-10), // nlTol
IntegerVector::create(100)); // nlMaxiter
DataFrame newLst = as<DataFrame>(aboveMat);
if (!Rf_isNull(et) && Rf_length(et) != 0){
CharacterVector etListNames = asCv(Rf_getAttrib(et, R_NamesSymbol), "names(et)");
Expand All @@ -990,6 +999,9 @@ SEXP expandPars_(SEXP objectS, SEXP paramsS, SEXP eventsS, SEXP controlS) {
} else {
rxModelsAssign(".thetaL", R_NilValue);
}
if (Rf_isNull(lotriBelow)) {
belowSEXP = R_NilValue;
}
if (!Rf_isNull(belowSEXP)) {
// below to sample matrix
SEXP omegaList = PROTECT(cvPost_(et, // In case needed
Expand Down

0 comments on commit e67d249

Please sign in to comment.