+--------------------------------------------------------------------+
 |                                                                    |
 |                          SIMULATION BLOCK                          |
 |                                                                    |
 +--------------------------------------------------------------------+

 MEANING: Abbreviated code for simulation
 CONTEXT: Abbreviated code

 SAMPLE:
 $PK
  IF (ICALL.EQ.4) CL=THETA(1)+ETA(1)

 DISCUSSION:
 A  "simulation block" is a block of abbreviated code that is only exe-
 cuted when ICALL=4 (during simulation).  Such blocks may be present in
 $PK,  $ERROR,  and $PRED, and may be implemented by means of generated
 FORTRAN subroutines.  E.g.,

 IF (ICALL.EQ.4) THEN
  ... simulation block ...
 ENDIF

 Special rules apply to such blocks.

 1)   No eta derivatives are computed in a simulation block.

 2)   Transgeneration is permitted.  NM-TRAN allows a data  item  label
      to appear on the left of an assignment statement.  NM-TRAN gener-
      ates assignment statements changing first the data  item  in  the
      event  or  data  record,  and then the local variable having that
      label.  E.g.,  suppose WT is listed in $INPUT:

      IF (ICALL.EQ.4) WT=70+70*ETA(3)

      The generated code is:
              IF(ICALL.EQ.4.D0)THEN
              EVTREC(NVNT,8 )=70.D0+70.D0*ETA(03)
              WT=EVTREC(NVNT,08)
              ENDIF

      NONMEM and PREDPP reserved data items should not be modified dur- |
      ing  simulation.   Transgeneration  is  permitted with simulation |
      with subproblems.  With all versions of NONMEM, the data set  for |
      each  subproblem after the first is the same data set used by the |
      previous subproblem, and includes any  changes  (transgeneration) |
      made by the previous subproblem.

 3)   Calls to certain NONMEM routines are permitted:

      CALL SIMETA(ETA)
      CALL SIMEPS(EPS)
      CALL RANDOM(n,R)
      where   n  is  an  integer  1-10.   If  CALL RANDOM is present, R
      becomes a reserved variable used for the random number.

      Note that NM-TRAN provides the  necessary  calls  to  SIMETA  and
      SIMEPS  in generated routines.  Explicit calls are used in abbre-
      viated code only to obtain different values of ETA and EPS.

 4)   A RETURN statement may be used.  If in $ERROR or $PRED,  and  the
      RETURN  occurs  in  a  simulation block, then Y may be assigned a
      value prior to the return.  If so, then F is set (F=Y); otherwise
      F is not set.

 5)   Loops are permitted.  The syntax is as follows.

      DO WHILE (condition)
       .. statements ..
      END DO

 Here are two examples.

      IF (ICALL.EQ.4.AND.NEWIND.NE.2) THEN
        DO WHILE (ETA(1).GT..5.OR.ETA(1).LT.-.5)
          CALL SIMETA(ETA)
        ENDDO
      ENDIF
      IF (ICALL.EQ.4) WT=70+70*ETA(1)

 (With  this  first  example,  the first random seed of the $SIMULATION
 record must have the NEW option.  Note also that, because of the  pre-
 vious automatic call to SIMETA, ETA(1) requires no initialization, but
 that R in the next example does.)

      IF (ICALL.EQ.4.AND.NEWIND.NE.2) THEN
        R=1
        DO WHILE (R.GT..5.OR.R.LT.-.5)
          CALL RANDOM(2,R)
        ENDDO
      ENDIF
      IF (ICALL.EQ.4) WT=70+70*R

 The third example illustrates how a categorical variable  with  equal-
 likely  probabilities  can  be  generated from a random number R, uni-
 formly distributed between 0 and 1.  In this example, the  categorical
 variable BIN takes values 1 through 5.

 IF (ICALL.EQ.4) THEN
   CALL RANDOM(2,R)
   BIN=INT(R*5)+1
 ENDIF

 The  number  5  can  be  replaced with any other positive integer n to
 obtain an n-valued categorical variable.  Here  INT  is  the  function
 that  transforms  a nonnegative number x into the greatest integer not
 exceeding x.  The effect of this simulation code  is  to  perform  the
 transformation:

      BIN=1 if R < .2
      BIN=2 if R < .4 and R >= .2
      BIN=3 if R < .6 and R >= .4
      BIN=4 if R < .8 and R >= .6
      BIN=5 if R <  1 and R >= .8

 (See abbreviated).

REFERENCES: Guide IV Section III.B.13, IV.I
REFERENCES: Guide V Section 12.4.8
REFERENCES: Guide VI Section III.E.2, IV.B.2


  
Go to main index.
  
Created by nmhelp2html v. 1.0 written by Niclas Jonsson (Modified by AJB 5/2006,11/2007,10/2012)