forked from baldrech/MizerEvo
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsummaryFunction.r
512 lines (489 loc) · 23.6 KB
/
summaryFunction.r
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
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
# Summary methods for mizer package
# Here lies : SSB, Biomass, N, Yield gear, Yield, Proporion of large fish, mean weight, mean max weight and community slope
#' Calculate the SSB of species
#'
#' Calculates the spawning stock biomass (SSB) through time of the species in the \code{MizerSim} class.
#' SSB is calculated as the total mass of all mature individuals.
#'
#' @param object An object of class \code{MizerSim}.
#'
#' @return An array containing the SSB (time x species)
#' @export
#' @docType methods
#' @rdname getSSB-methods
#' @aliases getSSB-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' # With constant fishing effort for all gears for 20 time steps
#' sim <- project(params, t_max = 20, effort = 0.5)
#' getSSB(sim)
#' }
setGeneric('getSSB', function(object, ...)
standardGeneric('getSSB'))
#' @rdname getSSB-methods
#' @aliases getSSB,MizerSim-method
setMethod('getSSB', signature(object='MizerSim'),
function(object, ...){
ssb <- apply(sweep(sweep(object@n, c(2,3), object@params@psi,"*"), 3, object@params@w * object@params@dw, "*"),c(1,2),sum)
return(ssb)
})
#' Calculate the total biomass of each species within a size range at each time step.
#'
#' Calculates the total biomass through time of the species in the \code{MizerSim} class within user defined size limits.
#' The default option is to use the whole size range.
#' You can specify minimum and maximum weight or length range for the species. Lengths take precedence over weights (i.e. if both min_l and min_w are supplied, only min_l will be used).
#'
#' @param object An object of class \code{MizerSim}.
#' @param min_w minimum weight of species to be used in the calculation.
#' @param max_w maximum weight of species to be used in the calculation.
#' @param min_l minimum length of species to be used in the calculation.
#' @param max_l maximum length of species to be used in the calculation.
#'
#' @return An array containing the biomass (time x species)
#' @export
#' @docType methods
#' @rdname getBiomass-methods
#' @aliases getBiomass-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' # With constant fishing effort for all gears for 20 time steps
#' sim <- project(params, t_max = 20, effort = 0.5)
#' getBiomass(sim)
#' getBiomass(sim, min_w = 10, max_w = 1000)
#' }
setGeneric('getBiomass', function(object, ...)
standardGeneric('getBiomass'))
#' @rdname getBiomass-methods
#' @aliases getBiomass,MizerSim-method
setMethod('getBiomass', signature(object='MizerSim'),
function(object, ...){
size_range <- get_size_range_array(object@params,...)
biomass <- apply(sweep(sweep(object@n,c(2,3),size_range,"*"),3,object@params@w * object@params@dw, "*"),c(1,2),sum)
return(biomass)
})
#' Calculate the total abundance in terms of numbers of species within a size range
#'
#' Calculates the total numbers through time of the species in the \code{MizerSim} class within user defined size limits.
#' The default option is to use the whole size range
#' You can specify minimum and maximum weight or lengths for the species. Lengths take precedence over weights (i.e. if both min_l and min_w are supplied, only min_l will be used)
#'
#' @param object An object of class \code{MizerSim}.
#' @param min_w minimum weight of species to be used in the calculation.
#' @param max_w maximum weight of species to be used in the calculation.
#' @param min_l minimum length of species to be used in the calculation.
#' @param max_l maximum length of species to be used in the calculation.
#'
#' @return An array containing the total numbers (time x species)
#' @export
#' @docType methods
#' @rdname getN-methods
#' @aliases getN-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' # With constant fishing effort for all gears for 20 time steps
#' sim <- project(params, t_max = 20, effort = 0.5)
#' getN(sim)
#' getN(sim, min_w = 10, max_w = 1000)
#' }
setGeneric('getN', function(object, ...)
standardGeneric('getN'))
#' @rdname getN-methods
#' @aliases getN,MizerSim-method
setMethod('getN', signature(object='MizerSim'),
function(object, ...){
size_range <- get_size_range_array(object@params,...)
n <- apply(sweep(sweep(object@n,c(2,3),size_range,"*"),3,object@params@dw, "*"),c(1,2),sum)
return(n)
})
#' Calculate the total yield per gear and species
#'
#' Calculates the total yield per gear and species at each simulation
#' time step.
#'
#' @param object An object of class \code{MizerSim}.
#'
#' @return An array containing the total yield (time x gear x species)
#' @export
#' @docType methods
#' @rdname getYieldGear-methods
#' @aliases getYieldGear-method
#' @seealso \code{\link{getYield}}
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' # With constant fishing effort for all gears for 20 time steps
#' sim <- project(params, t_max = 20, effort = 0.5)
#' getYieldGear(sim)
#' }
setGeneric('getYieldGear', function(object,...)
standardGeneric('getYieldGear'))
#' @rdname getYieldGear-methods
#' @aliases getYieldGear,MizerSim-method
setMethod('getYieldGear', signature(object='MizerSim'),
function(object,...){
# biomass less the first time step
biomass <- sweep(object@n,3,object@params@w * object@params@dw, "*")[-1,,,drop=FALSE]
f_gear <- getFMortGear(object)
yield_species_gear <- apply(sweep(f_gear,c(1,3,4),biomass,"*"),c(1,2,3),sum)
return(yield_species_gear)
})
#' Calculate the total yield of each species
#'
#' Calculates the total yield of each species across all gears at each
#' simulation time step.
#'
#' @param object An object of class \code{MizerSim}.
#'
#' @return An array containing the total yield (time x species)
#' @export
#' @docType methods
#' @rdname getYield-methods
#' @aliases getYield-method
#' @seealso \code{\link{getYieldGear}}
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' sim <- project(params, effort=1, t_max=10)
#' y <- getYield(sim)
#' }
setGeneric('getYield', function(object,...)
standardGeneric('getYield'))
#' @rdname getYield-methods
#' @aliases getYield,MizerSim-method
setMethod('getYield', signature(object='MizerSim'),
function(object,...){
# biomass less the first time step
yield_gear_species <- getYieldGear(object)
return(apply(yield_gear_species,c(1,3),sum))
})
# Helper function that returns an array (no_sp x no_w) of boolean values indicating whether that size bin is within
# the size limits specified by the arguments
# If min_l or max_l are supplied they take precendence over the min_w and max_w
# But you can mix min_l and max_w etc
# Not exported
get_size_range_array <- function(params, min_w = min(params@w), max_w = max(params@w), min_l = NULL, max_l = NULL, ...){
no_sp <- nrow(params@species_params)
if(!is.null(min_l) | !is.null(max_l))
if (any(!c("a","b") %in% names(params@species_params)))
stop("species_params slot must have columns 'a' and 'b' for length-weight conversion")
if(!is.null(min_l))
min_w <- params@species_params$a * min_l ^ params@species_params$b
else min_w <- rep(min_w,no_sp)
if(!is.null(max_l))
max_w <- params@species_params$a * max_l ^ params@species_params$b
else max_w <- rep(max_w,no_sp)
if (!all(min_w < max_w))
stop("min_w must be less than max_w")
min_n <- aaply(min_w, 1, function(x) params@w >= x, .drop=FALSE)
max_n <- aaply(max_w, 1, function(x) params@w <= x, .drop=FALSE)
size_n <- min_n & max_n
# Add dimnames?
dimnames(size_n) <- list(sp = params@species_params$species, w = signif(params@w,3))
return(size_n)
}
#' Summary method
#'
#' Outputs a general summary of the structure and content of the object
#'
#' @export
#' @docType methods
#' @rdname summary-methods
#' @aliases summary,MizerParams-method
#'
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears,inter)
#' summary(params)
#' }
setMethod("summary", signature(object="MizerParams"),
function(object, ...){
#cat("An object of class \"", as.character(class(object)), "\" with:\n", sep="")
cat("An object of class \"", as.character(class(object)), "\" \n", sep="")
cat("Community size spectrum:\n")
cat("\tminimum size:\t", signif(min(object@w)), "\n", sep="")
cat("\tmaximum size:\t", signif(max(object@w)), "\n", sep="")
cat("\tno. size bins:\t", length(object@w), "\n", sep="")
# Length of background?
cat("Background size spectrum:\n")
cat("\tminimum size:\t", signif(min(object@w_full)), "\n", sep="")
cat("\tmaximum size:\t", signif(max(object@w_full)), "\n", sep="")
cat("\tno. size bins:\t", length(object@w_full), "\n", sep="")
# w range - min, max, number of w
# w background min max
# no species and names and wInf, - not all these wMat, beta, sigma
# no gears, gear names catching what
cat("Species details:\n")
#cat("\tSpecies\t\tw_inf\n")
# for (i in 1:nrow(object@species_params))
# cat("\t",as.character(object@species_params$species)[i], "\t\t ",signif(object@species_params$w_inf[i],3), "\n", sep="")
print(object@species_params[,c("species","w_inf","w_mat","beta","sigma")])
cat("Fishing gear details:\n")
cat("\tGear\t\t\tTarget species\n")
for (i in 1:dim(object@catchability)[1]){
cat("\t",dimnames(object@catchability)$gear[i], "\t\t",dimnames(object@catchability)$sp[object@catchability[i,]>0], "\n", sep=" ")
}
})
#' @rdname summary-methods
#' @aliases summary,MizerSim-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears,inter)
#' sim <- project(params, effort=1, t_max=5)
#' summary(sim)
#' }
setMethod("summary", signature(object="MizerSim"),
function(object, ...){
#cat("An object of class \"", as.character(class(object)), "\" with:\n", sep="")
cat("An object of class \"", as.character(class(object)), "\" \n", sep="")
cat("Parameters:\n")
summary(object@params)
cat("Simulation parameters:\n")
# Need to store t_max and dt in a description slot? Or just in simulation time parameters? Like a list?
cat("\tFinal time step: ", max(as.numeric(dimnames(object@n)$time)), "\n", sep="")
cat("\tOutput stored every ", as.numeric(dimnames(object@n)$time)[2] - as.numeric(dimnames(object@n)$time)[1], " time units\n", sep="")
})
#' Calculate the proportion of large fish
#'
#' Calculates the proportion of large fish through time in the \code{MizerSim} class within user defined size limits.
#' The default option is to use the whole size range.
#' You can specify minimum and maximum size ranges for the species and also the threshold size for large fish.
#' Sizes can be expressed as weight or size. Lengths take precedence over weights (i.e. if both min_l and min_w are supplied, only min_l will be used).
#' You can also specify the species to be used in the calculation.
#' This method can be used to calculate the Large Fish Index.
#' The proportion is based on either abundance or biomass.
#'
#' @param object An object of class \code{MizerSim}.
#' @param species numeric or character vector of species to include in the calculation.
#' @param min_w minimum weight of species to be used in the calculation.
#' @param max_w maximum weight of species to be used in the calculation.
#' @param min_l minimum length of species to be used in the calculation.
#' @param max_l maximum length of species to be used in the calculation.
#' @param threshold_w the size used as the cutoff between large and small fish. Default value is 100.
#' @param threshold_l the size used as the cutoff between large and small fish.
#' @param biomass_proportion a boolean value. If TRUE the proportion calculated is based on biomass, if FALSE it is based on numbers of individuals. Default is TRUE.
#'
#' @return An array containing the proportion of large fish through time
#' @export
#' @docType methods
#' @rdname getProportionOfLargeFish-methods
#' @aliases getProportionOfLargeFish-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' sim <- project(params, effort=1, t_max=10)
#' getProportionOfLargeFish(sim)
#' getProportionOfLargeFish(sim, species=c("Herring","Sprat","N.pout"))
#' getProportionOfLargeFish(sim, min_w = 10, max_w = 5000)
#' getProportionOfLargeFish(sim, min_w = 10, max_w = 5000, threshold_w = 500)
#' getProportionOfLargeFish(sim, min_w = 10, max_w = 5000,
#' threshold_w = 500, biomass_proportion=FALSE)
#' }
setGeneric('getProportionOfLargeFish', function(object, ...)
standardGeneric('getProportionOfLargeFish'))
#' @rdname getProportionOfLargeFish-methods
#' @aliases getProportionOfLargeFish,MizerSim-method
setMethod('getProportionOfLargeFish', signature(object='MizerSim'),
function(object, species = 1:nrow(object@params@species_params), threshold_w = 100, threshold_l = NULL, biomass_proportion=TRUE, ...){
check_species(object,species)
# This args stuff is pretty ugly - couldn't work out another way of using ...
args <- list(...)
args[["params"]] <- object@params
total_size_range <- do.call("get_size_range_array",args=args)
args[["max_w"]] <- threshold_w
args[["max_l"]] <- threshold_l
large_size_range <- do.call("get_size_range_array",args=args)
w <- object@params@w
if(!biomass_proportion) # based on abundance numbers
w[] <- 1
total_measure <- apply(sweep(sweep(object@n[,species,,drop=FALSE],c(2,3),total_size_range[species,,drop=FALSE],"*"),3,w * object@params@dw, "*"),1,sum)
upto_threshold_measure <- apply(sweep(sweep(object@n[,species,,drop=FALSE],c(2,3),large_size_range[species,,drop=FALSE],"*"),3,w * object@params@dw, "*"),1,sum)
#lfi = data.frame(time = as.numeric(dimnames(object@n)$time), proportion = 1-(upto_threshold_measure / total_measure))
#return(lfi)
return(1-(upto_threshold_measure / total_measure))
})
#' Calculate the mean weight of the community
#'
#' Calculates the mean weight of the community through time.
#' This is simply the total biomass of the community divided by the abundance in numbers.
#' You can specify minimum and maximum weight or length range for the species. Lengths take precedence over weights (i.e. if both min_l and min_w are supplied, only min_l will be used).
#' You can also specify the species to be used in the calculation.
#'
#' @param object An object of class \code{MizerSim}
#' @param min_w minimum weight of species to be used in the calculation
#' @param max_w maximum weight of species to be used in the calculation
#' @param min_l minimum length of species to be used in the calculation
#' @param max_l maximum length of species to be used in the calculation
#' @param species numeric or character vector of species to include in the calculation
#'
#' @return A vector containing the mean weight of the community through time
#' @export
#' @docType methods
#' @rdname getMeanWeight-methods
#' @aliases getMeanWeight-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' sim <- project(params, effort=1, t_max=10)
#' getMeanWeight(sim)
#' getMeanWeight(sim, species=c("Herring","Sprat","N.pout"))
#' getMeanWeight(sim, min_w = 10, max_w = 5000)
#' }
setGeneric('getMeanWeight', function(object, ...)
standardGeneric('getMeanWeight'))
#' @rdname getMeanWeight-methods
#' @aliases getMeanWeight,MizerSim-method
setMethod('getMeanWeight', signature(object='MizerSim'),
function(object, species = 1:nrow(object@params@species_params),...){
check_species(object,species)
n_species <- getN(object,...)
biomass_species <- getBiomass(object,...)
n_total <- apply(n_species[,species,drop=FALSE],1,sum)
biomass_total <- apply(biomass_species[,species,drop=FALSE],1,sum)
return(biomass_total / n_total)
})
#' Calculate the mean maximum weight of the community
#'
#' Calculates the mean maximum weight of the community through time.
#' This can be calculated by numbers or biomass.
#' The calculation is the sum of the w_inf * abundance of each species, divided by the total abundance community, where abundance is either in biomass or numbers.
#' You can specify minimum and maximum weight or length range for the species. Lengths take precedence over weights (i.e. if both min_l and min_w are supplied, only min_l will be used).
#' You can also specify the species to be used in the calculation.
#'
#' @param object An object of class \code{MizerSim}.
#' @param min_w minimum weight of species to be used in the calculation.
#' @param max_w maximum weight of species to be used in the calculation.
#' @param min_l minimum length of species to be used in the calculation.
#' @param max_l maximum length of species to be used in the calculation.
#' @param species numeric or character vector of species to include in the calculation.
#' @param measure The measure to return. Can be 'numbers', 'biomass' or 'both'
#'
#' @return A matrix or vector containing the mean maximum weight of the community through time
#' @export
#' @docType methods
#' @rdname getMeanMaxWeight-methods
#' @aliases getMeanMaxWeight-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' sim <- project(params, effort=1, t_max=10)
#' getMeanMaxWeight(sim)
#' getMeanMaxWeight(sim, species=c("Herring","Sprat","N.pout"))
#' getMeanMaxWeight(sim, min_w = 10, max_w = 5000)
#' }
setGeneric('getMeanMaxWeight', function(object, ...)
standardGeneric('getMeanMaxWeight'))
#' @rdname getMeanMaxWeight-methods
#' @aliases getMeanMaxWeight,MizerSim-method
setMethod('getMeanMaxWeight', signature(object='MizerSim'),
function(object, species = 1:nrow(object@params@species_params), measure = "both",...){
if (!(measure %in% c("both","numbers","biomass")))
stop("measure must be one of 'both', 'numbers' or 'biomass'")
check_species(object,species)
n_species <- getN(object,...)
biomass_species <- getBiomass(object,...)
n_winf <- apply(sweep(n_species, 2, object@params@species_params$w_inf,"*")[,species,drop=FALSE], 1, sum)
biomass_winf <- apply(sweep(biomass_species, 2, object@params@species_params$w_inf,"*")[,species,drop=FALSE], 1, sum)
mmw_numbers <- n_winf / apply(n_species, 1, sum)
mmw_biomass <- biomass_winf / apply(biomass_species, 1, sum)
if (measure == "numbers")
return(mmw_numbers)
if (measure == "biomass")
return(mmw_biomass)
if (measure == "both")
return(cbind(mmw_numbers, mmw_biomass))
})
#' Calculate the slope of the community abundance
#'
#' Calculates the slope of the community abundance through time by performing a linear regression on the logged total numerical abundance at weight and logged weights (natural logs, not log to base 10, are used).
#' You can specify minimum and maximum weight or length range for the species. Lengths take precedence over weights (i.e. if both min_l and min_w are supplied, only min_l will be used).
#' You can also specify the species to be used in the calculation.
#'
#' @param object An object of class \code{MizerSim}.
#' @param species Numeric or character vector of species to include in the calculation.
#' @param biomass Boolean. If TRUE (default), the abundance is based on biomass, if FALSE the abundance is based on numbers.
#' @param min_w Minimum weight of species to be used in the calculation.
#' @param max_w Maximum weight of species to be used in the calculation.
#' @param min_l Minimum length of species to be used in the calculation.
#' @param max_l Maximum length of species to be used in the calculation.
#'
#' @return A data frame with slope, intercept and R2 values.
#' @export
#' @docType methods
#' @rdname getCommunitySlope-methods
#' @aliases getCommunitySlope-method
#' @examples
#' \dontrun{
#' data(NS_species_params_gears)
#' data(inter)
#' params <- MizerParams(NS_species_params_gears, inter)
#' sim <- project(params, effort=1, t_max=40, dt = 1, t_save = 1)
#' # Slope based on biomass, using all species and sizes
#' slope_biomass <- getCommunitySlope(sim)
#' # Slope based on numbers, using all species and sizes
#' slope_numbers <- getCommunitySlope(sim, biomass=FALSE)
#' # Slope based on biomass, using all species and sizes between 10g and 1000g
#' slope_biomass <- getCommunitySlope(sim, min_w = 10, max_w = 1000)
#' # Slope based on biomass, using only demersal species and sizes between 10g and 1000g
#' dem_species <- c("Dab","Whiting","Sole","Gurnard","Plaice","Haddock", "Cod","Saithe")
#' slope_biomass <- getCommunitySlope(sim, species = dem_species, min_w = 10, max_w = 1000)
#' }
setGeneric('getCommunitySlope', function(object, ...)
standardGeneric('getCommunitySlope'))
#' @rdname getCommunitySlope-methods
#' @aliases getCommunitySlope,MizerSim-method
setMethod('getCommunitySlope', signature(object='MizerSim'),
function(object, species = 1:nrow(object@params@species_params),
biomass = TRUE, ...){
check_species(object,species)
size_range <- get_size_range_array(object@params,...)
total_n <- apply(sweep(object@n,c(2,3),size_range,"*")[,species,,drop=FALSE],c(1,3),sum)
# numbers or biomass?
if (biomass)
total_n <- sweep(total_n,2,object@params@w,"*")
total_n[total_n<=0] <- NA
slope <- adply(total_n,1,function(x,w){
summary_fit <- summary(lm(log(x) ~ log(w)))
out_df <- data.frame(
slope = summary_fit$coefficients[2,1],
intercept = summary_fit$coefficients[1,1],
r2 = summary_fit$r.squared)
}, w = object@params@w)
dimnames(slope)[[1]] <- slope[,1]
slope <- slope[,-1]
return(slope)
})
# internal
check_species <- function(object,species){
if (!(is(species,"character") | is(species,"numeric")))
stop("species argument must be either a numeric or character vector")
if (is(species,"character"))
check <- all(species %in% dimnames(object@n)$sp)
if (is(species,"numeric"))
check <- all(species %in% 1:dim(object@n)[2])
if(!check)
stop("species argument not in the model species. species must be a character vector of names in the model, or a numeric vector referencing the species")
return(check)
}