[Pomp-commits] r1121 - pkg/pomp pkg/pomp/man www/content www/vignettes

noreply at r-forge.r-project.org noreply at r-forge.r-project.org
Sun Mar 1 16:17:09 CET 2015


Author: kingaa
Date: 2015-03-01 16:17:08 +0100 (Sun, 01 Mar 2015)
New Revision: 1121

Modified:
   pkg/pomp/DESCRIPTION
   pkg/pomp/man/csnippet.Rd
   www/content/vignettes.htm
   www/vignettes/getting_started.R
   www/vignettes/getting_started.Rmd
   www/vignettes/getting_started.html
   www/vignettes/pomp.pdf
Log:
- improve Csnippet help page
- simplify the Getting Started vignette
- update the package vignettes webpage (remove intro and advanced topics vignettes)

Modified: pkg/pomp/DESCRIPTION
===================================================================
--- pkg/pomp/DESCRIPTION	2015-03-01 03:41:09 UTC (rev 1120)
+++ pkg/pomp/DESCRIPTION	2015-03-01 15:17:08 UTC (rev 1121)
@@ -1,8 +1,8 @@
 Package: pomp
 Type: Package
 Title: Statistical Inference for Partially Observed Markov Processes
-Version: 0.62-2
-Date: 2015-02-28
+Version: 0.62-3
+Date: 2015-03-01
 Authors at R: c(person(given=c("Aaron","A."),family="King",
 		role=c("aut","cre"),email="kingaa at umich.edu"),
 	  person(given=c("Edward","L."),family="Ionides",role=c("aut")),
@@ -25,18 +25,18 @@
 MailingList: Subscribe to pomp-announce at r-forge.r-project.org for announcements by going to http://lists.r-forge.r-project.org/mailman/listinfo/pomp-announce.
 Collate: aaa.R authors.R generics.R eulermultinom.R
 	 csnippet.R pomp-fun.R plugins.R builder.R
-	 parmat.R logmeanexp.R slice-design.R 
+	 parmat.R logmeanexp.R slice-design.R
 	 profile-design.R sobol.R bsplines.R sannbox.R
-	 pomp-class.R load.R pomp.R pomp-methods.R 
-	 rmeasure-pomp.R rprocess-pomp.R init-state-pomp.R 
-	 dmeasure-pomp.R dprocess-pomp.R skeleton-pomp.R 
+	 pomp-class.R load.R pomp.R pomp-methods.R
+	 rmeasure-pomp.R rprocess-pomp.R init-state-pomp.R
+	 dmeasure-pomp.R dprocess-pomp.R skeleton-pomp.R
 	 dprior-pomp.R rprior-pomp.R
-	 simulate-pomp.R trajectory-pomp.R plot-pomp.R 
-	 pfilter.R pfilter-methods.R minim.R traj-match.R 
+	 simulate-pomp.R trajectory-pomp.R plot-pomp.R
+	 pfilter.R pfilter-methods.R minim.R traj-match.R
 	 bsmc.R bsmc2.R
 	 mif.R mif-methods.R
 	 proposals.R pmcmc.R pmcmc-methods.R
- 	 nlf-funcs.R nlf-guts.R nlf-objfun.R nlf.R 
+ 	 nlf-funcs.R nlf-guts.R nlf-objfun.R nlf.R
 	 probe.R probe-match.R basic-probes.R spect.R spect-match.R
 	 abc.R abc-methods.R
 	 example.R

Modified: pkg/pomp/man/csnippet.Rd
===================================================================
--- pkg/pomp/man/csnippet.Rd	2015-03-01 03:41:09 UTC (rev 1120)
+++ pkg/pomp/man/csnippet.Rd	2015-03-01 15:17:08 UTC (rev 1121)
@@ -6,7 +6,7 @@
   For including snippets of C code in \code{pomp} objects.
 }
 \usage{
-  Csnippet(text);
+  Csnippet(text)
 }
 \arguments{
   \item{text}{
@@ -18,12 +18,68 @@
 }
 \section{Using C snippets to accelerate computations}{
   From version 0.50, \pkg{pomp} provides a facility whereby users can define their model's components using inline C code.
-  The \code{pomp} constructor combines these \code{Csnippet}s into a compilable C file stored in the \R session's temporary directory.
-  They are then compiled (via \code{\link[=SHLIB]{R CMD SHLIB}}) into dynamically loadable shared objects.
-  This is then dynamically loaded as needed.
+  Furnishing one or more \code{Csnippet}s as arguments to the \code{pomp} constructor causes them to be written to a C file stored in the \R session's temporary directory, which is then compiled (via \code{\link[=SHLIB]{R CMD SHLIB}}) into a dynamically loadable shared object file.
+  This is then loaded as needed.
 
-  Instructions for writing models using \code{Csnippet}s, along with examples, are given in the tutorials on the \href{http://pomp.r-forge.r-project.org}{package website}.
+  \strong{Note to Windows and Mac users:}
+  By default, your \R installation may not support \code{\link[=SHLIB]{R CMD SHLIB}}.
+  Have a look at the tutorials on the package website for instructions on enabling this powerful feature of \R.
+
+  In writing a \code{Csnippet} one must bear in mind both the \emph{goal} of the snippet, i.e., what computation it is intended to perform, and the \emph{context} in which it will be executed.
+  Details of both of these are given below in the form of rules governing the use of \code{Csnippet}s.
+  Illustrative examples are given in the tutorials on the \href{http://pomp.r-forge.r-project.org}{package website}.
 }
+\section{General rules for writing C snippets}{
+  \enumerate{
+    \item C snippets must be valid C.  They will embedded verbatim in a template file which will then be compiled by a call to \code{R CMD SHLIB}.  If the resulting file does not compile, an error message wil be generated.  No attempt is made by \pkg{pomp} to interpret this message.  Typically, compilation errors are due to either invalid C syntax or undeclared variables.
+    \item State variables, parameters, observables, and covariates must be left undeclared in the snippet.  State variables and parameters must be declared in either the \code{statenames} or \code{paramnames} argument to \code{pomp}, as appropriate. Compiler errors that complain about undeclared state variables or parameters are usually due to failure to include these parameters in the appropriate vector of names.
+    \item A C snippet can declare local variables.  Be careful not to use names that match those of state variables, observables, or parameters.  The latter must never be declared within a snippet.
+    \item Names of observables are determined by their names in the data.  They must be referred to in measurement model snippets (rmeasure or dmeasure) by those names.
+    \item If the \code{pomp} object contains a table of covariates (see \code{\link{pomp}}), then the variables in the covariate table will be available, by their names, in the context within which the snippet is executed.
+    \item \R variables with names containing dots (\sQuote{.}) are replaced in the C codes by variable names in which all dots have been replaced by underscores (\sQuote{_}).
+    \item The header \file{R.h}, provided with \R, will be included in the generated C file, making all of the \href{http://cran.r-project.org/doc/manuals/r-release/R-exts.html#The-R-API}{\R C API} available for use in the snippet.
+    \item The header \file{pomp.h}, provided with \pkg{pomp}, will also be included, making all of the \pkg{pomp} C API available for use in every snippet.  Do \preformatted{file.show(system.file("include/pomp.h",package="pomp"))} to view this header file.
+    \item Snippets of C code passed to the \code{globals} argument of \code{pomp} will be included at the head of the generated C file.  This can be used to declare global variables, define useful functions, and include arbitrary header files.
+  }
+}
+\section{Rules for writing \code{rmeasure} snippets}{
+  \enumerate{
+    \item The goal of such a snippet is to fill the observables with random values drawn from the measurement model distribution.  Accordingly, each observable should be assigned a new value.
+    \item In addition to the states, parameters, covariates (if any), and observables, the variable \code{t}, containing the time of the observation, will be defined in the context in which the snippet is executed.
+  }
+}
+\section{Rules for writing \code{dmeasure} snippets}{
+  \enumerate{
+    \item The goal of such a snippet is to fill the \code{lik} variable with the likelihood of the data given the state.  Alternatively, if \code{give_log=1}, \code{lik} should be filled with the log likelihood.
+    \item In addition to the states, parameters, covariates (if any), and observables, the variable \code{t}, containing the time of the observation, will be defined in the context in which the snippet is executed.
+  }
+}
+\section{Rules for writing \code{euler.sim} and \code{discrete.time.sim} snippets}{
+  \enumerate{
+    \item The goal of such a snippet is to replace the state variables with their new random values at the end of the time interval.  Accordingly, each state variable should be over-written with its new value.
+    \item In addition to the states, parameters, covariates (if any), and observables, the variables \code{t} and \code{dt}, containing respectively the time at the beginning of the Euler step and the Euler step's duration, will be defined in the context in which the snippet is executed.
+  }
+}
+\section{Rules for writing \code{skeleton} snippets}{
+  \enumerate{
+    \item For each state variable, there is a corresponding component of the deterministic skeleton.  The goal of such a snippet is to compute all the components.
+    \item When the skeleton is a map, the component corresponding to state variable \code{x} is named \code{Dx} and is the new value of \code{x} after one iteration of the map.
+    \item When the skeleton is a vectorfield, the component corresponding to state variable \code{x} is named \code{Dx} and is the value of $dx/dt$.
+    \item As with the other C snippets, all states, parameters and covariates, as well as the current time, \code{t}, will be defined in the context within which the snippet is executed.
+  }
+}
+\section{Rules for writing parameter transformation snippets}{
+  \enumerate{
+    \item The parameter transformation mapping a parameter vector from the scale defined by the model codes to another scale is specified as the \code{parameter.inv.transform} whilst the transformation mapping a parameter vector from the alternative scale to that on which the model is defined is specified as the \code{parameter.transform}.
+    \item The goal of a these snippets is the computation of the values of the transformed parameters.  The value of transformed parameter \code{x} should be assigned to variable \code{Tx}.
+    \item Time-, state-, and covariate-dependent transformations are not allowed.  Therefore, neither the time, nor any state variables, nor any of the covariates will be available in the context within which a parameter transformation snippet is executed.
+  }
+}
+\section{Viewing the generated C code}{
+  It can be useful to view the C code generated by calling \code{pomp} with one or more \code{Csnippet} arguments.
+  To do so, set \code{options(verbose=TRUE)} before calling \code{pomp}.
+  A message giving the name of the generated C file (in the session temporary directory) will be printed.
+}
 \author{Aaron A. King \email{kingaa at umich dot edu}}
 \seealso{
   \code{\link{pomp}}, \code{\link{plugins}}, and the tutorials on the \href{http://pomp.r-forge.r-project.org}{package website}.

Modified: www/content/vignettes.htm
===================================================================
--- www/content/vignettes.htm	2015-03-01 03:41:09 UTC (rev 1120)
+++ www/content/vignettes.htm	2015-03-01 15:17:08 UTC (rev 1121)
@@ -2,16 +2,10 @@
 
 <table>
 <tr>
-<td>Introduction to <strong>pomp</strong></td>
-<td><a target="_blank" href="vignettes/intro_to_pomp.pdf">(PDF)</a></td>
-<td><a target="_blank" href="vignettes/intro_to_pomp.R">(R code)</a></td>
+<td>Getting started with <strong>pomp</strong></td>
+<td><a target="_blank" href="vignettes/getting_started.html">(HTML)</a></td>
+<td><a target="_blank" href="vignettes/getting_started.R">(R code)</a></td>
 </tr>
-<tr>
-<td>Advanced topics in <strong>pomp</strong></td>
-<td><a target="_blank" href="vignettes/advanced_topics_in_pomp.pdf">(PDF)</a></td>
-<td><a target="_blank" href="vignettes/advanced_topics_in_pomp.R">(R code)</a></td>
-</tr>
-<tr>
 <td><strong>pomp</strong> package manual</td>
 <td><a target="_blank" href="vignettes/pomp.pdf">(PDF)</a></td>
 </tr>

Modified: www/vignettes/getting_started.R
===================================================================
--- www/vignettes/getting_started.R	2015-03-01 03:41:09 UTC (rev 1120)
+++ www/vignettes/getting_started.R	2015-03-01 15:17:08 UTC (rev 1121)
@@ -33,7 +33,7 @@
 require(magrittr)
 require(pomp)
 theme_set(theme_bw())
-stopifnot(packageVersion("pomp")>="0.62-1")
+stopifnot(packageVersion("pomp")>="0.62-2")
 options(
   keep.source=TRUE,
   stringsAsFactors=FALSE,
@@ -205,11 +205,3 @@
 coef(parus,transform=TRUE) <- partrans(parus,p,dir="inv")
 stopifnot(all.equal(p,coef(parus)))
 
-## ----tempfile-view,eval=FALSE--------------------------------------------
-## op <- options(verbose=TRUE)
-## 
-## parus <- pomp(data=parus.dat,times="year",t0=1959,rprocess=euler.sim(step.fun,delta.t=1/365),
-##      dmeasure=dmeas,rmeasure=rmeas,statenames="N",paramnames=c("r","phi","K","N.0","sigma"))
-## 
-## options(op)
-

Modified: www/vignettes/getting_started.Rmd
===================================================================
--- www/vignettes/getting_started.Rmd	2015-03-01 03:41:09 UTC (rev 1120)
+++ www/vignettes/getting_started.Rmd	2015-03-01 15:17:08 UTC (rev 1121)
@@ -1,7 +1,6 @@
 ---
 title: "Getting started with pomp"
 author: "Aaron A. King"
-date: "02/28/2015"
 output:
   html_document:
     theme: flatly
@@ -14,6 +13,8 @@
 Please share and remix noncommercially, mentioning its origin.  
 ![CC-BY_NC](http://pomp.r-forge.r-project.org/graphics/cc-by-nc.png)
 
+This document compiled with `pomp` version `r packageVersion("pomp")`.
+
 ```{r opts,include=FALSE}
 library(knitr)
 prefix <- "getting-started"
@@ -51,7 +52,7 @@
 require(magrittr)
 require(pomp)
 theme_set(theme_bw())
-stopifnot(packageVersion("pomp")>="0.62-1")
+stopifnot(packageVersion("pomp")>="0.62-2")
 options(
   keep.source=TRUE,
   stringsAsFactors=FALSE,
@@ -229,7 +230,7 @@
 The `rnorm` function is part of the [`R` API](http://cran.r-project.org/doc/manuals/r-release/R-exts.html#The-R-API): see the [manual on "Writing R Extensions"](http://cran.r-project.org/doc/manuals/r-release/R-exts.html) for a description of this and the other [distribution functions provided as part of the `R` API](http://cran.r-project.org/doc/manuals/r-release/R-exts.html#Distribution-functions).
 Finally, note that the state variable `N` is over-written by this snippet: it's value when the first line is executed is overwritten by the second line.
 
-[A full set of rules for writing `pomp` C snippets is given below][rules].
+A full set of rules for writing `pomp` C snippets is given in the package help `?Csnippet`.
 
 With the process model in place, we can simulate the process model using the `simulate` function and plot several realizations for a given set of parameters.
 
@@ -328,7 +329,7 @@
 parus <- pomp(parus,skeleton=skel,skeleton.type="vectorfield",statenames="N",paramnames=c("r","K"))
 ```
 Note that in this snippet, `DN` is filled with the value of the time-derivative of `N`. 
-[See below for a complete set of rules for writing C snippets for `pomp`][rules].
+See the package help (`?Csnippet`) for a complete set of rules for writing C snippets.
 
 With the deterministic skeleton in place we can generate several trajectories of the skeleton using `trajectory`, as follows, and plot the result.
 ```{r logistic-traj1}
@@ -403,59 +404,4 @@
 stopifnot(all.equal(p,coef(parus)))
 ```
 
-## Rules for writing C snippets
-
-To fully understand how `pomp` makes use of C snippets, it is informative to have a look at the C file created by any call to `pomp` involving one or more C snippets.
-Run the following in an `R` session and view the C file that is created in the session's temporary directory.
-```{r tempfile-view,eval=FALSE}
-op <- options(verbose=TRUE)
-
-parus <- pomp(data=parus.dat,times="year",t0=1959,rprocess=euler.sim(step.fun,delta.t=1/365),
-     dmeasure=dmeas,rmeasure=rmeas,statenames="N",paramnames=c("r","phi","K","N.0","sigma"))
-
-options(op)
-```
-
-### General rules
-
-1. C snippets must be valid C.  They will embedded verbatim in a template file which will then be compiled by a call to `R CMD SHLIB`.  If the resulting file does not compile, an error message wil be generated.  No attempt is made by `pomp` to interpret this message.  Typically, compilation errors are due to either the snippet's being invalid C or one or more undeclared variables.
-1. Each state variable or parameter must be left undeclared in the snippet and declared in the corresponding argument to `pomp`, i.e., in either `statenames` or `paramnames`. Compiler errors that complain about undeclared state variables or parameters are likely due to failure to include these parameters in the appropriate vector of names.
-1. Names of observables are determined by their names in the data.  They must be referred to in measurement model snippets (rmeasure or dmeasure) by those names.
-1. If the `pomp` object contains a table of covariates (see `?pomp`), then the variables in the covariate table will be available by their names in the context within which the snippet is executed.
-1. `R` variables with names containing dots are replaced in the C codes by variable names in which all dots have been replaced by underscores ("_").
-1. A C snippet can declare local variables.  Be careful not to use names that match those of state variables, observables, or parameters.  The latter must never be declared within a snippet.
-1. The header `R.h`, provided with `R`, will be included, making all of the [`R` C API](http://cran.r-project.org/doc/manuals/r-release/R-exts.html#The-R-API) available for use in the snippet.
-1. The header `pomp.h`, provided with `pomp`, will be included, making all of the `pomp` C API available for use in every snippet.  Do `file.show(system.file("include/pomp.h",package="pomp"))` to view this header file.
-1. Snippets of C code passed to the `globals` argument of `pomp` will be included at the head of the generated C file.  This can be used to define global variables, define useful functions, and include header files.
-
-### C snippets implementing Euler steps for use by `euler.sim`
-
-1. The ultimate goal of such a snippet is to replace the state variables with their new random values at the end of the time interval.  Accordingly, each state variable should be over-written with its new value.
-1. In addition to the states, parameters, covariates (if any), and observables, the variables `t` and `dt`, containing respectively the time at the beginning of the Euler step and the Euler step's duration, will be defined in the context in which the snippet is executed.
-
-### C snippets implementing the rmeasure component
-
-1. The ultimate goal of such a snippet is to fill the observables with random values drawn from the measurement model distribution.  Accordingly, each observable should be assigned a new value.
-1. In addition to the states, parameters, covariates (if any), and observables, the variable `t`, containing the time of the observation, will be defined in the context in which the snippet is executed.
-
-### C snippets implementing the dmeasure component
-
-1. The ultimate goal of such a snippet is to fill the `lik` variable with the likelihood of the data given the state.  Alternatively, if `give_log=1`, `lik` should be filled with the log likelihood.
-1. In addition to the states, parameters, covariates (if any), and observables, the variable `t`, containing the time of the observation, will be defined in the context in which the snippet is executed.
-
-### C snippets implementing the deterministic skeleton
-
-1. For each state variable, there is a corresponding component of the deterministic skeleton.  The goal of such a snippet is to compute all the components.  
-1. When the skeleton is a map, the component corresponding to state variable `x` is named `Dx` and is the new value of `x` after one iteration of the map.
-1. When the skeleton is a vectorfield, the component corresponding to state variable `x` is named `Dx` and is the value of $dx/dt$.
-1. As with the other C snippets, all states, parameters and covariates, as well as the current time, `t`, will be defined in the context within which the snippet is executed.
-
-### C snippets implementing parameter transformations
-
-1. The parameter transformation taking a parameter vector from the scale defined by the model codes to another scale is specified as the `parameter.inv.transform` whilst the transformation taking a parameter vector from the alternative scale to that on which the model is defined is specified as the `parameter.transform`.
-1. The goal of a either of these snippets is the computation of the values of the transformed parameters.  The value of transformed parameter `x` should be assigned to variable `Tx`.
-1. Time- and covariate-dependent transformations are not allowed.  Therefore, the variables `t` and any covariates will not be available in the context within which a parameter transformation snippet is executed.
-
 ## References
-
-[rules]:./getting_started.html##rules-for-writing-c-snippets "Rules for writing C snippets"

Modified: www/vignettes/getting_started.html
===================================================================
--- www/vignettes/getting_started.html	2015-03-01 03:41:09 UTC (rev 1120)
+++ www/vignettes/getting_started.html	2015-03-01 15:17:08 UTC (rev 1121)
@@ -10,7 +10,6 @@
 
 <meta name="author" content="Aaron A. King" />
 
-<meta name="date" content="2015-02-28" />
 
 <title>Getting started with pomp</title>
 
@@ -64,7 +63,6 @@
 <div id="header">
 <h1 class="title">Getting started with pomp</h1>
 <h4 class="author"><em>Aaron A. King</em></h4>
-<h4 class="date"><em>02/28/2015</em></h4>
 </div>
 
 <div id="TOC">
@@ -83,18 +81,11 @@
 <li><a href="#a-continuous-time-deterministic-skeleton">A continuous-time deterministic skeleton</a></li>
 <li><a href="#specifying-a-discrete-time-process-model-and-skeleton">Specifying a discrete-time process model and skeleton</a></li>
 <li><a href="#parameter-transformations">Parameter transformations</a></li>
-<li><a href="#rules-for-writing-c-snippets">Rules for writing C snippets</a><ul>
-<li><a href="#general-rules">General rules</a></li>
-<li><a href="#c-snippets-implementing-euler-steps-for-use-by-euler.sim">C snippets implementing Euler steps for use by <code>euler.sim</code></a></li>
-<li><a href="#c-snippets-implementing-the-rmeasure-component">C snippets implementing the rmeasure component</a></li>
-<li><a href="#c-snippets-implementing-the-dmeasure-component">C snippets implementing the dmeasure component</a></li>
-<li><a href="#c-snippets-implementing-the-deterministic-skeleton">C snippets implementing the deterministic skeleton</a></li>
-<li><a href="#c-snippets-implementing-parameter-transformations">C snippets implementing parameter transformations</a></li>
-</ul></li>
 </ul>
 </div>
 
 <p>Licensed under the <a href="http://creativecommons.org/licenses/by-nc/3.0">Creative Commons attribution-noncommercial license</a>. Please share and remix noncommercially, mentioning its origin.<br /><img src="" alt="CC-BY_NC" /></p>
+<p>This document compiled with <code>pomp</code> version 0.62.2.</p>
 <div id="partially-observed-markov-process-pomp-models" class="section level2">
 <h2>Partially observed Markov process (POMP) models</h2>
 <p>As its name implies <code>pomp</code> is focused on partially observed Markov process models. These are also known as state-space model, hidden Markov models, and stochastic dynamical systems models. Such models consist of an unobserved stochastic <em>state process</em>, connected to the data via an explicit model of the observation process. We refer to the former as the <em>process model</em> and the latter as the <em>measurement model</em>. Each model is, in fact, a probability distribution. If we let <span class="math">\(Y_t\)</span> denote the measurement process at time <span class="math">\(t\)</span> and <span class="math">\(X_t\)</span> the state process, then by definition, the process model is determined by the density <span class="math">\(f_{X_t|X_{t-1}}\)</span> and the measurement process by the density <span class="math">\(f_{Y_t|X_t}\)</span>. We think of the data, <span class="math">\(y^*_t\)</span>, <span class="math">\(t=1,\dots,T\)</span> as being a single realization of the <span class="math">\(Y\)</span> process. To implement a POMP model in <code>pomp</code>, we have to specify the measurement and process distributions.</p>
@@ -108,18 +99,20 @@
 <colgroup>
 <col width="48%"></col>
 </colgroup>
+<thead>
+<tr class="header">
[TRUNCATED]

To get the complete diff run:
    svnlook diff /svnroot/pomp -r 1121


More information about the pomp-commits mailing list