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 #17 from nlmixr2/16-use-ettrans-new-interface-for-…
Browse files Browse the repository at this point in the history
…sslag

Match new options for etTrans
  • Loading branch information
mattfidler authored Aug 27, 2023
2 parents 8ee6b1f + cf3a93b commit a513890
Showing 1 changed file with 21 additions and 6 deletions.
27 changes: 21 additions & 6 deletions src/cvPost.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,9 @@ extern "C"{
rxSolveFreeSexp_t rxSolveFree;
typedef void (*setZeroMatrix_t)(int which);
setZeroMatrix_t setZeroMatrix;
typedef SEXP (*etTrans_t)(SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP, SEXP);
typedef SEXP (*etTrans_t)(SEXP, SEXP, SEXP, SEXP, SEXP,
SEXP, SEXP, SEXP, SEXP, SEXP,
SEXP);
etTrans_t etTransSexp;
typedef void (*rxModelsAssignC_t)(const char* str, SEXP assign);
rxModelsAssignC_t rxModelsAssign;
Expand Down Expand Up @@ -87,9 +89,13 @@ extern "C"{
List etTrans(List inData, const RObject &obj, bool addCmt=false,
bool dropUnits=false, bool allTimeVar=false,
bool keepDosingOnly=false, Nullable<LogicalVector> combineDvid=R_NilValue,
CharacterVector keep = CharacterVector(0)) {
CharacterVector keep = CharacterVector(0),
bool addlKeepsCov=false,
bool addlDropSs = true,
bool ssAtDoseTime = true) {
return as<List>(etTransSexp(wrap(inData), wrap(obj), wrap(addCmt), wrap(dropUnits), wrap(allTimeVar),
wrap(keepDosingOnly), wrap(combineDvid),wrap(keep = CharacterVector(0))));
wrap(keepDosingOnly), wrap(combineDvid),wrap(keep),
wrap(addlKeepsCov), wrap(addlDropSs), wrap(ssAtDoseTime)));
}


Expand Down Expand Up @@ -903,7 +909,10 @@ SEXP expandPars_(SEXP objectS, SEXP paramsS, SEXP eventsS, SEXP controlS) {
events = PROTECT(etTrans(as<List>(eventsS), nestObj,
(INTEGER(mv[RxMv_flags])[RxMvFlag_hasCmt] == 1),
false, false, true, R_NilValue,
control[Rxc_keepF])); pro++;
control[Rxc_keepF],
control[Rxc_addlKeepsCov],
control[Rxc_addlDropSs],
control[Rxc_ssAtDoseTime])); pro++;
rxModelsAssign(".nestEvents", events);
RObject cls = Rf_getAttrib(events, R_ClassSymbol);
List rxLst = cls.attr(".rxode2.lst");
Expand Down Expand Up @@ -1070,13 +1079,19 @@ SEXP expandPars_(SEXP objectS, SEXP paramsS, SEXP eventsS, SEXP controlS) {
events = PROTECT(etTrans(as<List>(eventsS), nestObj,
(INTEGER(mv[RxMv_flags])[RxMvFlag_hasCmt] == 1),
false, false, true, R_NilValue,
control[Rxc_keepF])); pro++;
control[Rxc_keepF],
control[Rxc_addlKeepsCov],
control[Rxc_addlDropSs],
control[Rxc_ssAtDoseTime])); pro++;
rxModelsAssign(".nestEvents", events);
} else if (!Rf_inherits(events, "rxEtTrans")){
events = PROTECT(etTrans(as<List>(events), nestObj,
(INTEGER(mv[RxMv_flags])[RxMvFlag_hasCmt] == 1),
false, false, true, R_NilValue,
control[Rxc_keepF])); pro++;
control[Rxc_keepF],
control[Rxc_addlKeepsCov],
control[Rxc_addlDropSs],
control[Rxc_ssAtDoseTime])); pro++;
rxModelsAssign(".nestEvents", events);
}
int nobs = Rf_length(VECTOR_ELT(events, 0));
Expand Down

0 comments on commit a513890

Please sign in to comment.