forked from johnrsibert/ADMB_XML
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpella-xml.tpl
233 lines (214 loc) · 6.67 KB
/
pella-xml.tpl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
//======================================================================================================================
// File: pella-xml.tpl
// Model: Pella-Tomlinson model, with Binit=k*a
// Parameters: r, k, a, p, q, sigma
// Fitted data: Abundance index
// Likelihood: Log-transformed normal
// References: Polacheck et al. (1993)
// Notes: q and sigma are free parameters, to allow full uncertainty in MCMC analysis
// History: January 2014 John Sibert added some ADMB_XMLDoc examples.
// 6 Jan 2011 Arni Magnusson improved vector extraction
// 7 Oct 2010 Arni Magnusson improved string handling and comments
// 9 Mar 2010 Arni Magnusson created, to benchmark against R optimizers
//======================================================================================================================
// Implementation notes
// Abundance index may not exist for all years
// Vectors that include all years: B, C
// Vectors that include abundance index years: I, Ifit, X
// X links long and short vectors
//======================================================================================================================
GLOBALS_SECTION
#include "admodel.h"
#include "ADMB_XMLDoc.h"
#include <string>
using std::string;
const double pi = 3.141592654;
int mcmc_iteration = 0;
int phz; // phase
double lb; // lower bound
double ub; // upper bound
ofstream mcmc_par("mcmc_par.csv");
ofstream mcmc_bio("mcmc_bio.csv");
DATA_SECTION
// Read data file
init_int nc
init_matrix Cdata(1,nc,1,2) // Year | C
init_int ni
init_matrix Idata(1,ni,1,2) // Year | I
// Vectors
ivector Cyear(1,nc)
ivector Iyear(1,ni)
vector C(1,nc)
vector I(1,ni)
ivector X(1,ni) // years with abundance index: 1995 | 1998 | ...
// Constants
number halfnlog2pi
vector logI(1,ni)
// Switch to control file
!! string run_name = string(adprogram_name);
!! if(option_match(argc,argv,"-ind") > -1)
!! {
!! run_name = argv[option_match(argc,argv,"-ind") + 1];
!! run_name = run_name.substr(0, run_name.rfind("."));
!! }
!! change_datafile_name((adstring)run_name.c_str() + ".ctl");
// Read control file (phase, lower, upper, init)
init_vector logr_plui(1,4)
init_vector logk_plui(1,4)
init_vector loga_plui(1,4)
init_vector logp_plui(1,4)
init_vector logq_plui(1,4)
init_vector logsigma_plui(1,4)
PARAMETER_SECTION
// Estimated
!! phz = (int) logr_plui(1);
!! lb = logr_plui(2);
!! ub = logr_plui(3);
init_bounded_number logr(lb,ub,phz)
!! phz = (int) logk_plui(1);
!! lb = logk_plui(2);
!! ub = logk_plui(3);
init_bounded_number logk(lb,ub,phz)
!! phz = (int) loga_plui(1);
!! lb = loga_plui(2);
!! ub = loga_plui(3);
init_bounded_number loga(lb,ub,phz)
!! phz = (int) logp_plui(1);
!! lb = logp_plui(2);
!! ub = logp_plui(3);
init_bounded_number logp(lb,ub,phz)
!! phz = (int) logq_plui(1);
!! lb = logq_plui(2);
!! ub = logq_plui(3);
init_bounded_number logq(lb,ub,phz)
!! phz = (int) logsigma_plui(1);
!! lb = logsigma_plui(2);
!! ub = logsigma_plui(3);
init_bounded_number logsigma(lb,ub,phz)
// Derived
number r
number k
number a
number p
sdreport_number q
number sigma
// Updated
vector B(1,nc)
vector Bfit(1,ni)
vector Ifit(1,ni)
number RSS
// Report
matrix summary(1,nc,1,5) // Year | B | C | I | Ifit
// Objfun
objective_function_value neglogL
PRELIMINARY_CALCS_SECTION
// Data
Cyear = (ivector) column(Cdata,1);
C = column(Cdata,2);
Iyear = (ivector) column(Idata,1);
I = column(Idata,2);
X = Iyear - Cyear(1) + 1;
halfnlog2pi = 0.5*ni*log(2*pi);
logI = log(I);
// Parameters
logr = logr_plui(4);
logk = logk_plui(4);
loga = loga_plui(4);
logp = logp_plui(4);
logq = logq_plui(4);
logsigma = logsigma_plui(4);
neglogL = 0.0;
// save data and initial parameter values in xml file .x00
saveXMLFile();
PROCEDURE_SECTION
get_fit();
get_neglogL();
if(mceval_phase())
write_mcmc();
REPORT_SECTION
summary.initialize();
get_summary();
// save data and parameter estimates in xml file .x01
saveXMLFile();
report<<setprecision(12)
<<"# r" <<endl<<r <<endl
<<"# k" <<endl<<k <<endl
<<"# a" <<endl<<a <<endl
<<"# p" <<endl<<p <<endl
<<"# q" <<endl<<q <<endl
<<"# sigma" <<endl<<sigma <<endl
<<"# RSS" <<endl<<RSS <<endl
<<"# neglogL"<<endl<<neglogL<<endl<<endl;
report<<setprecision(4)
<<"# Model summary"<<endl
<<" Year Biomass Catch Index IndexFit"<<endl
<<summary<<endl;
FUNCTION saveXMLFile
ADMB_XMLDoc xml;
int ret = 0;
if (fabs(neglogL) <= 0.0)
xml.allocate("FIT","pella-xml","Starting Values", "pella-xml.x00");
else
{
xml.allocate("FIT","pella-xml","Final Estimates", "pella-xml.x01");
ret = xml.createXMLcomment("fit statistics");
ret = xml.createXMLelement(neglogL);
}
ret = xml.createXMLelement(nc,"Catch Data Years");
ret = xml.createXMLelement(Cdata,"Catch Data");
ret = xml.createXMLelement(ni,"Survey Data Years");
ret = xml.createXMLelement(Idata,"Survey Data");
ret = xml.createXMLelement(logr,"log growth rate");
ret = xml.createXMLelement(logk,"log carrying capacity");
ret = xml.createXMLelement(loga,"log a");
ret = xml.createXMLelement(logp,"log p");
ret = xml.createXMLelement(logq,"log q");
ret = xml.createXMLelement(logsigma,"log sigma");
ret = xml.write();
FUNCTION get_fit
r = mfexp(logr);
k = mfexp(logk);
a = mfexp(loga);
p = mfexp(logp);
q = mfexp(logq);
sigma = mfexp(logsigma);
B(1) = k * a;
for(int t=1; t<=nc-1; t++)
B(t+1) = sfabs(B(t) + r/p*B(t)*(1-pow(B(t)/k,p)) - C(t));
Ifit = q*B(X);
FUNCTION get_neglogL
RSS = norm2(logI-log(Ifit));
neglogL = halfnlog2pi + ni*log(sigma) + RSS/(2*sigma*sigma);
FUNCTION get_summary
summary.colfill(1,(dvector)Cyear);
summary.colfill(2,B);
summary.colfill(3,C);
for(int i=1; i<=ni; i++) // allow missing years in abundance index
{
summary(X(i),4) = I(i);
summary(X(i),5) = Ifit(i);
}
FUNCTION write_mcmc
mcmc_iteration++;
// Parameters
if(mcmc_iteration == 1)
mcmc_par<<"neglogL,r,k,a,p,q,sigma"<<endl;
mcmc_par<<neglogL<<","
<<r <<","
<<k <<","
<<a <<","
<<p <<","
<<q <<","
<<sigma <<endl;
// Biomass
if(mcmc_iteration == 1)
{
mcmc_bio<<Cyear(1);
for(int t=2; t<=nc; t++)
mcmc_bio<<","<<Cyear(t);
mcmc_bio<<endl;
}
mcmc_bio<<B(1);
for(int t=2; t<=nc; t++)
mcmc_bio<<","<<B(t);
mcmc_bio<<endl;