[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