[Pomp-commits] r1216 - pkg/pomp pkg/pomp/R pkg/pomp/demo pkg/pomp/inst pkg/pomp/man pkg/pomp/tests www/content www/vignettes

noreply at r-forge.r-project.org noreply at r-forge.r-project.org
Thu Jun 18 01:26:33 CEST 2015


Author: kingaa
Date: 2015-06-18 01:26:32 +0200 (Thu, 18 Jun 2015)
New Revision: 1216

Modified:
   pkg/pomp/DESCRIPTION
   pkg/pomp/R/nlf.R
   pkg/pomp/R/pomp.R
   pkg/pomp/R/spect.R
   pkg/pomp/demo/sir.R
   pkg/pomp/inst/NEWS
   pkg/pomp/inst/NEWS.Rd
   pkg/pomp/man/LondonYorke.Rd
   pkg/pomp/man/csnippet.Rd
   pkg/pomp/tests/ou2-spect.R
   pkg/pomp/tests/ou2-spect.Rout.save
   www/content/NEWS.html
   www/vignettes/getting_started.Rmd
   www/vignettes/getting_started.html
   www/vignettes/pomp.pdf
Log:
- new global option for location of .c and .so files generated by 'pomp'
- minor fixes in 'nlf' and 'spect' to eliminate warnings by using '.lm.fit' in place of 'lm'
- update man pages
- use new 'pomp.file.dir' option in 'getting started' vignette

Modified: pkg/pomp/DESCRIPTION
===================================================================
--- pkg/pomp/DESCRIPTION	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/DESCRIPTION	2015-06-17 23:26:32 UTC (rev 1216)
@@ -1,7 +1,7 @@
 Package: pomp
 Type: Package
 Title: Statistical Inference for Partially Observed Markov Processes
-Version: 0.67-5
+Version: 0.68-1
 Date: 2015-06-17
 Authors at R: c(person(given=c("Aaron","A."),family="King",
 		role=c("aut","cre"),email="kingaa at umich.edu"),

Modified: pkg/pomp/R/nlf.R
===================================================================
--- pkg/pomp/R/nlf.R	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/R/nlf.R	2015-06-17 23:26:32 UTC (rev 1216)
@@ -193,8 +193,7 @@
 
     ## find a good epsilon 
     h <- se.par.frac
-    if (verbose)
-      cat("h in NLF = ", h, "\n")
+    if (verbose) cat("h in NLF = ", h, "\n")
     eps <- rep(h,nfitted)
 
     for (i in seq_len(nfitted)) {
@@ -250,13 +249,12 @@
                        )
       FAILED <- -999999
       Fvals[Fvals < FAILED+10] <- NA
-      xvals <- c(sqrt(2),1,0,1,sqrt(2))*h*fitted[i]
-      c2 <- lm(Fvals~I(xvals^2))$coef[2]
+      xvals <- cbind(1,(c(sqrt(2),1,0,1,sqrt(2))*h*fitted[i])^2)
+      c2 <- .lm.fit(xvals,Fvals)$coefficients[2]
       eps[i] <- sqrt(abs(lql.frac/c2))
     }
 
-    if (verbose)
-      cat("epsilon in NLF =",t(eps), "\n")
+    if (verbose) cat("epsilon in NLF =",t(eps), "\n")
 
     Imat <- matrix(0,npts,nfitted)
     for (i in seq_len(nfitted)) {
@@ -279,8 +277,7 @@
                        verbose=FALSE
                        )
 
-      if (verbose)
-        cat("Fitted param ", i, F.up, mean(f.up2,na.rm=T)," up in ",sQuote("nlf"),"\n")
+      if (verbose) cat("Fitted param ", i, F.up, mean(f.up2,na.rm=T)," up in ",sQuote("nlf"),"\n")
 
       guess.down <- fitted
       guess.down[i] <- guess.down[i]-eps[i]
@@ -293,8 +290,7 @@
                         )
       F.down <- mean(f.down,na.rm=T)
 
-      if (verbose)
-        cat("Fitted param ",i, F.down," down in ",sQuote("NLF"),"\n")
+      if (verbose) cat("Fitted param ",i, F.down," down in ",sQuote("NLF"),"\n")
 
       Jhat[i,i] <- (F.up + F.down-2*F0)/(eps[i]*eps[i])
       Imat[,i] <- (f.up-f.down)/(2*eps[i])

Modified: pkg/pomp/R/pomp.R
===================================================================
--- pkg/pomp/R/pomp.R	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/R/pomp.R	2015-06-17 23:26:32 UTC (rev 1216)
@@ -11,7 +11,9 @@
                               fromEstimationScale, toEstimationScale,
                               parameter.transform = NULL, parameter.inv.transform = NULL,
                               globals, userdata, ...,
-                              .solibfile, .filename, .filedir,
+                              .solibfile = list(),
+                              .filename = NULL,
+                              .filedir = getOption("pomp.file.dir",NULL),
                               verbose = getOption("verbose",FALSE)) {
 
   ## preliminary error checking
@@ -19,9 +21,6 @@
   if (missing(times)) stop(sQuote("times")," is a required argument")
   if (missing(t0)) stop(sQuote("t0")," is a required argument")
   if (missing(params)) params <- numeric(0)
-  if (missing(.solibfile)) .solibfile <- list()
-  if (missing(.filename)) .filename <- NULL
-  if (missing(.filedir)) .filedir <- NULL
   
   if (missing(userdata)) userdata <- list()
   added.userdata <- list(...)

Modified: pkg/pomp/R/spect.R
===================================================================
--- pkg/pomp/R/spect.R	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/R/spect.R	2015-06-17 23:26:32 UTC (rev 1216)
@@ -36,12 +36,13 @@
          type,
          mean=tseries-mean(tseries),
          linear={
-           x <- seq_along(tseries)
-           lm(tseries~x)$residuals
+           m <- cbind(1,seq_along(tseries))
+           .lm.fit(m,tseries)$residuals
          },
          quadratic={
            x <- seq_along(tseries)
-           lm(tseries~x+I(x^2))$residuals
+           m <- cbind(1,x,x*x)
+           .lm.fit(m,tseries)$residuals
          },
          tseries
          )

Modified: pkg/pomp/demo/sir.R
===================================================================
--- pkg/pomp/demo/sir.R	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/demo/sir.R	2015-06-17 23:26:32 UTC (rev 1216)
@@ -114,8 +114,6 @@
   to_log_barycentric(&TS_0,&S_0,3);
 "
 
-data(LondonYorke)
-
 cbind(
       time=seq(from=1928,to=1934,by=0.01),
       as.data.frame(

Modified: pkg/pomp/inst/NEWS
===================================================================
--- pkg/pomp/inst/NEWS	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/inst/NEWS	2015-06-17 23:26:32 UTC (rev 1216)
@@ -1,5 +1,12 @@
 _N_e_w_s _f_o_r _p_a_c_k_a_g_e '_p_o_m_p'
 
+_C_h_a_n_g_e_s _i_n '_p_o_m_p' _v_e_r_s_i_o_n _0._6_8-_1:
+
+        • When using ‘Csnippet’s, by default, the C codes and
+          shared-object files are stored in the R session's temporary
+          directory.  One can override this behavior by setting the
+          global ‘pomp.file.dir’ option.
+
 _C_h_a_n_g_e_s _i_n '_p_o_m_p' _v_e_r_s_i_o_n _0._6_7-_1:
 
         • A 'pomp' object's initializer can now be specified as a

Modified: pkg/pomp/inst/NEWS.Rd
===================================================================
--- pkg/pomp/inst/NEWS.Rd	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/inst/NEWS.Rd	2015-06-17 23:26:32 UTC (rev 1216)
@@ -1,5 +1,11 @@
 \name{NEWS}
 \title{News for package `pomp'}
+\section{Changes in \pkg{pomp} version 0.68-1}{
+  \itemize{
+    \item When using \code{Csnippet}s, by default, the C codes and shared-object files are stored in the R session's temporary directory.
+    One can override this behavior by setting the global \code{pomp.file.dir} option.
+  }
+}
 \section{Changes in \pkg{pomp} version 0.67-1}{
   \itemize{
     \item A 'pomp' object's initializer can now be specified as a Csnippet.

Modified: pkg/pomp/man/LondonYorke.Rd
===================================================================
--- pkg/pomp/man/LondonYorke.Rd	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/man/LondonYorke.Rd	2015-06-17 23:26:32 UTC (rev 1216)
@@ -6,11 +6,9 @@
   \code{LondonYorke} is a data-frame containing the monthly number of reported cases of chickenpox, measles, and mumps from two American cities (Baltimore and New York) in the mid-20th century (1928--1972).
 }
 \usage{
-data(LondonYorke)
+LondonYorke
 }
 \examples{
-data(LondonYorke)
-
 plot(cases~time,data=LondonYorke,subset=disease=="measles",type='n',main="measles",bty='l')
 lines(cases~time,data=LondonYorke,subset=disease=="measles"&town=="Baltimore",col="red")
 lines(cases~time,data=LondonYorke,subset=disease=="measles"&town=="New York",col="blue")

Modified: pkg/pomp/man/csnippet.Rd
===================================================================
--- pkg/pomp/man/csnippet.Rd	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/man/csnippet.Rd	2015-06-17 23:26:32 UTC (rev 1216)
@@ -21,6 +21,8 @@
   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.
 
+  One can choose to store these files in a different directory by setting the global option \code{pomp.file.dir}, e.g.: \preformatted{options(pomp.file.dir=getwd())}.
+
   \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.

Modified: pkg/pomp/tests/ou2-spect.R
===================================================================
--- pkg/pomp/tests/ou2-spect.R	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/tests/ou2-spect.R	2015-06-17 23:26:32 UTC (rev 1216)
@@ -1,12 +1,18 @@
 library(pomp)
 pompExample(ou2)
 
+set.seed(362083261L)
+
+pdf(file="ou2-spect.pdf")
+
 gm1 <- spect.match(ou2,
                   kernel.width=3,
                   detrend="mean",
                   nsim=50,
                   est=c("alpha.1","alpha.4"),
                   method="Nelder-Mead")
+gm1 at value
+plot(gm1)
 
 gm2 <- spect.match(ou2,
                    kernel.width=3,
@@ -14,3 +20,25 @@
                    nsim=49,
                    est=c("alpha.1","alpha.4"),
                    method="Nelder-Mead")
+gm2 at value
+plot(gm2)
+
+gm3 <- spect.match(ou2,
+                   kernel.width=3,
+                   detrend="linear",
+                   nsim=50,
+                   est=c("alpha.1","alpha.4"),
+                   method="Nelder-Mead")
+gm3 at value
+plot(gm3)
+
+gm4 <- spect.match(ou2,
+                   kernel.width=3,
+                   detrend="quadratic",
+                   nsim=50,
+                   est=c("alpha.1","alpha.4"),
+                   method="Nelder-Mead")
+gm4 at value
+plot(gm4)
+
+dev.off()

Modified: pkg/pomp/tests/ou2-spect.Rout.save
===================================================================
--- pkg/pomp/tests/ou2-spect.Rout.save	2015-06-17 20:15:19 UTC (rev 1215)
+++ pkg/pomp/tests/ou2-spect.Rout.save	2015-06-17 23:26:32 UTC (rev 1216)
@@ -20,12 +20,19 @@
 newly created object(s):
  ou2 
 > 
+> set.seed(362083261L)
+> 
+> pdf(file="ou2-spect.pdf")
+> 
 > gm1 <- spect.match(ou2,
 +                   kernel.width=3,
 +                   detrend="mean",
 +                   nsim=50,
 +                   est=c("alpha.1","alpha.4"),
 +                   method="Nelder-Mead")
+> gm1 at value
+[1] 64.89552
+> plot(gm1)
 > 
 > gm2 <- spect.match(ou2,
 +                    kernel.width=3,
@@ -33,7 +40,34 @@
 +                    nsim=49,
 +                    est=c("alpha.1","alpha.4"),
 +                    method="Nelder-Mead")
+> gm2 at value
+[1] 73.42989
+> plot(gm2)
 > 
+> gm3 <- spect.match(ou2,
++                    kernel.width=3,
++                    detrend="linear",
++                    nsim=50,
++                    est=c("alpha.1","alpha.4"),
++                    method="Nelder-Mead")
+> gm3 at value
+[1] 60.4426
+> plot(gm3)
+> 
+> gm4 <- spect.match(ou2,
++                    kernel.width=3,
++                    detrend="quadratic",
++                    nsim=50,
++                    est=c("alpha.1","alpha.4"),
++                    method="Nelder-Mead")
+> gm4 at value
+[1] 66.11778
+> plot(gm4)
+> 
+> dev.off()
+null device 
+          1 
+> 
 > proc.time()
    user  system elapsed 
- 16.957   0.040  17.048 
+ 40.234   0.068  40.591 

Modified: www/content/NEWS.html
===================================================================
--- www/content/NEWS.html	2015-06-17 20:15:19 UTC (rev 1215)
+++ www/content/NEWS.html	2015-06-17 23:26:32 UTC (rev 1216)
@@ -7,6 +7,17 @@
 
 <h2>News for package ‘pomp’</h2>
 
+<h3>Changes in <span class="pkg">pomp</span> version 0.68-1</h3>
+
+
+<ul>
+<li><p> When using <code>Csnippet</code>s, by default, the C codes and shared-object files are stored in the R session's temporary directory.
+One can override this behavior by setting the global <code>pomp.file.dir</code> option.
+</p>
+</li></ul>
+
+
+
 <h3>Changes in <span class="pkg">pomp</span> version 0.67-1</h3>
 
 

Modified: www/vignettes/getting_started.Rmd
===================================================================
--- www/vignettes/getting_started.Rmd	2015-06-17 20:15:19 UTC (rev 1215)
+++ www/vignettes/getting_started.Rmd	2015-06-17 23:26:32 UTC (rev 1216)
@@ -40,6 +40,7 @@
   dev='png',
   dev.args=list(bg='transparent')
   )
+options(pomp.file.dir="cache/")
 ```
 
 

Modified: www/vignettes/getting_started.html
===================================================================
--- www/vignettes/getting_started.html	2015-06-17 20:15:19 UTC (rev 1215)
+++ www/vignettes/getting_started.html	2015-06-17 23:26:32 UTC (rev 1216)
@@ -90,7 +90,7 @@
 </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 was produced using <code>pomp</code> version 0.66.6.</p>
+<p>This document was produced using <code>pomp</code> version 0.68.1.</p>
 <div id="introduction" class="section level2">
 <h2>Introduction</h2>
 <p>This tutorial aims to help you get started using <code>pomp</code> as a suite of tools for analysis of time series data based on dynamical systems models. First, we give some conceptual background regarding the class of models—partially observed Markov processes—that <code>pomp</code> handles. We then discuss some preliminaries: installing the package and so on. Next, using a basic question about ecological population regulation as an example, we load some data and implement some models as <code>R</code> objects of class <code>pomp</code>. Finally, we illustrate some of the package’s capabilities by using its algorithms to fit and compare the models using various inference methods.</p>
@@ -174,7 +174,7 @@
   geom_line()+geom_point()+
   expand_limits(y=0)+
   theme_classic()</code></pre>
[TRUNCATED]

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


More information about the pomp-commits mailing list