ADMB

{{Infobox programming language

| name = ADMB

| logo = ADMB logo.jpg

| paradigm =

| designer = David Fournier

| developer = ADMB Core Team{{Cite web|url=https://www.admb-project.org/developers/core-team.html|title=ADMB Core Team}}

| typing =

| implementations =

| dialects = C++

| influenced =

| license = BSD

| website = {{URL|http://www.admb-project.org/}}

| year =

| latest_release_version = 13.1{{Cite web|url=http://www.admb-project.org/downloads/|title=ADMB Releases}}

| latest_release_date = {{Start date and age|2022|12|23|df=yes}}

| latest_test_version =

| latest_test_date =

| influenced_by =

| operating_system = Cross-platform

}}

ADMB or AD Model Builder is a free and open source software suite for non-linear statistical modeling.{{cite web | title = admb-project | publisher = ADMB Project | url = https://code.google.com/p/admb-project/ | access-date = 2009-04-01| archive-url= https://web.archive.org/web/20090303132743/https://code.google.com/p/admb-project/| archive-date= 3 March 2009 | url-status= live}}Fournier, D.A., H.J. Skaug, J. Ancheta, J. Ianelli, A. Magnusson, M.N. Maunder, A. Nielsen, and J. Sibert. 2012. AD Model Builder: using automatic differentiation for statistical inference of highly parameterized complex nonlinear models. Optim. Methods Softw. 27:233-249 It was created by David Fournier and now being developed by the ADMB Project, a creation of the non-profit ADMB Foundation. The "AD" in AD Model Builder refers to the automatic differentiation capabilities that come from the AUTODIF Library, a C++ language extension also created by David Fournier, which implements reverse mode automatic differentiation.{{cite web | title = AUTODIF: A C++ Array Language Extension with Automatic Differentiation For Use in Nonlinear Modeling and Statistics | publisher = ADMB Project | url = http://admb-project.googlecode.com/files/autodif.pdf | access-date = 2008-12-03 | archive-url = https://web.archive.org/web/20110711111457/http://admb-project.googlecode.com/files/autodif.pdf | archive-date = 2011-07-11 | url-status = dead }} A related software package, ADMB-RE, provides additional support for modeling random effects.{{cite web | title = Random effects in AD Model Builder: ADMB-RE user guide | publisher = ADMB Project | url = http://admb-project.googlecode.com/files/admb-re.pdf | access-date = 2008-12-03 | archive-url = https://web.archive.org/web/20110711111618/http://admb-project.googlecode.com/files/admb-re.pdf | archive-date = 2011-07-11 | url-status = dead }}

Features and use

Markov chain Monte Carlo methods are integrated into the ADMB software, making it useful for Bayesian modeling.{{cite web | title = An Introduction to AD Model Builder Version 9.0.0 | publisher = ADMB Project | url = http://admb-project.googlecode.com/files/admb.pdf | access-date = 2008-12-03 | archive-url = https://web.archive.org/web/20110104180301/http://admb-project.googlecode.com/files/admb.pdf | archive-date = 2011-01-04 | url-status = dead }} In addition to Bayesian hierarchical models, ADMB provides support for modeling random effects in a frequentist framework using Laplace approximation and importance sampling.

ADMB is widely used by scientists in academic institutions, government agencies, and international commissions,{{cite web

|url = http://admb-project.org/community/user-base

|publisher = ADMB Project

|title = ADMB User Base and Major Applications

|access-date = 2008-12-02

|archive-url = https://web.archive.org/web/20110724224347/http://admb-project.org/community/user-base

|archive-date = 2011-07-24

|url-status = dead

}} most commonly for ecological modeling. In particular, many fisheries stock assessment models have been built using this software.{{cite web

|url = http://admb-project.org/community/bibliography/stock-assessments

|publisher = ADMB Project

|title = Bibliography: Stock assessments

|access-date = 2008-12-03

|archive-url = https://archive.today/20130226034837/http://admb-project.org/community/bibliography/stock-assessments

|archive-date = 2013-02-26

|url-status = dead

}} ADMB is freely available under the New BSD License,{{cite web

| url=http://admb-project.org/downloads

| publisher=ADMB Project

| title=ADMB Downloads

| access-date=2010-07-28

}}

with versions available for Windows, Linux, Mac OS X, and OpenSolaris operating systems. Source code for ADMB was made publicly available in March 2009.{{cite web

| url=http://www.ia.ucsb.edu/pa/display.aspx?pkey=1896

| publisher=University of California, Santa Barbara

| title=UCSB Press Release: "Fisheries Stock Assessment Software Now Publicly Accessible"

| access-date=2008-12-09

}}

{{cite web

|url = http://admb-project.org/news/admb-source-code-available

|publisher = ADMB Project

|title = ADMB Source Code Available

|access-date = 2009-05-14

|archive-url = https://web.archive.org/web/20100418194627/http://admb-project.org/news/admb-source-code-available

|archive-date = 2010-04-18

|url-status = dead

}}

History and background

= Implementation =

Work by David Fournier in the 1970s on development of highly parameterized

integrated statistical models in fisheries motivated the

development of the AUTODIF Library, and ultimately ADMB.

The likelihood equations

in these models are typically non-linear and estimates of the

parameters are

obtained by numerical methods.

Early in Fournier's work, it became clear that general numerical

solutions to these likelihood problems could only be reliably

achieved using function minimization algorithms that

incorporate accurate information about the gradients of the likelihood

surface. Computing the gradients (i.e. partial derivatives

of the likelihood with respect to all model variables) must also be done with

the same accuracy as the likelihood computation itself.

Fournier developed a protocol for writing code to compute the required

derivatives based on the chain rule of differential calculus. This

protocol is very similar to the suite of methods that came to be known

as reverse mode automatic differentiation

.A. Griewank and G. F.Corliss (eds).

Automatic differentiation of algorithms: theory, implementation, and application.`

Society of Industrial and Applied Mathematics. 1992.

The statistical models using these methods

D. Fournier and I. Doonan.

A length-based stock assessment method utilizing a generalized delay-difference model.

Canadian Journal of Fisheries and Aquatic Sciences, 44(2):422--437, 1987.

D. Fournier and A. Warburton.

Evaluating fisheries management models by simulated adaptive control-introducing the composite model.

Canadian Journal of Fisheries and Aquatic Sciences.

46(6):1002--1012, 1989.

D. Fournier, J. Sibert, J. Majkowski, and J. Hampton.

MULTIFAN a likelihood-based method for estimating growth parameters and age composition from multiple length frequency data sets illustrated using data for southern bluefin tuna (Thunnus maccoyii).

Canadian Journal of Fisheries and Aquatic Sciences, 47(2):301--317, 1990.

J. Sibert, J. Hampton, D. Fournier, and P. Bills.

An advection-diffusion-reaction model for the estimation of fishmovement parameters from tagging data, with application to skipjack tuna (Katsuwonus pelamis).

Canadian Journal of Fisheries and Aquatic Sciences, 56(6):925--938, 1999.

typically included eight constituent code segments:

  1. the objective function;
  2. adjoint code to compute the partial derivatives of the objective function with respect to the parameters to be estimated;
  3. dedicated memory to contain intermediate data for derivative computations, known as the "gradient stack", and the software to manage it;
  4. a function minimizer;
  5. an algorithm to check that the derivatives are correct with respect to finite difference approximations;
  6. an algorithm to insert model parameters into a vector that can be manipulated by the function minimizer and the corresponding derivative code;
  7. an algorithm to return the parameter values to the likelihood computation and the corresponding derivative code; and
  8. an algorithm to compute the second partial derivatives of the objective function with respect to the parameters to be estimated, the Hessian matrix.

Model developers are usually only interested in the first of these

constituents. Any programming tools that can reduce the overhead of

developing and maintaining the other seven will greatly increase their

productivity.

Bjarne Stroustrup began development of C++ in the 1970s at Bell Labs as an

enhancement to the C programming language. C++ spread widely, and by

1989, C++ compilers were available for personal computers.

The polymorphism of C++ makes it possible to envisage a programming

system in which all mathematical operators and functions can be

overloaded to automatically compute the derivative contributions of

every differentiable numerical operation in any computer program.

= Otter Research =

Fournier formed Otter Research Ltd. in 1989, and

by 1990 the AUTODIF Library included special classes for derivative computation and

the requisite overloaded functions for all C++ operators and

all functions in the standard C++ math library.

The AUTODIF Library automatically computes the derivatives of the objective function

with the same accuracy as the objective function itself and thereby

frees the developer from the onerous task of writing

and maintaining derivative code for statistical models.

Equally important from the standpoint of model development,

the AUTODIF Library includes a "gradient stack",

a quasi-Newton function minimizer, a derivative checker, and

container classes for vectors and matrices.

The first application of the AUTODIF Library was published in 1992

K. N. Holland, R. Brill, R. Chang, J. Sibert, and D. Fournier.

Physiological and behavioural thermogregulation in bigeye tuna (Thunnus obesus). Nature, 358:410--412, 1992.

The AUTODIF Library does not, however, completely liberate the developer from

writing all of the model constituents listed above. In 1993, Fournier further

abstracted the writing of statistical models by creating ADMB, a special

"template" language to simplify model specification by

creating the tools to

transform models written using the templates into the AUTODIF Library

applications. ADMB produces code to manage the exchange of model

parameters between the model and the function minimizer,

automatically computes the Hessian matrix and inverts it to provide

an estimate the covariance of the estimated parameters. ADMB thus

completes the liberation of the model developer from all of the tedious

overhead of managing non-linear optimization, thereby freeing him or her to

focus on the more interesting aspects of the statistical model.

By the mid-1990s, ADMB had earned acceptance by researchers working on

all aspects of resource management. Population models based on the

ADMB are used to monitor a range of both endangered

species and commercially valuable fish populations including

whales, dolphins,

sea lions, penguins, albatross, abalone, lobsters, tunas, marlins,

sharks, rays, anchovy, and pollock. ADMB has also been

used to reconstruct movements of many species of animals tracked with

electronic tags.

In 2002, Fournier teamed up with Hans Skaug to introduce random

effects into ADMB. This

development included automatic computation of second and third

derivatives and the use of forward mode automatic differentiation followed by

two sweeps of reverse model AD in certain cases.

= ADMB Project =

In 2007, a group of ADMB users that included John Sibert, Mark

Maunder and Anders Nielsen became concerned about ADMB's long-term

development and maintenance. An agreement was reached with

Otter Research to sell the copyright to ADMB for the purpose of

making ADMB an open-source project and distributing it without

charge. The non-profit ADMB Foundation was created

to coordinate development and promote use of ADMB.

The ADMB Foundation drafted a proposal to the Gordon and Betty Moore

Foundation for the funds to purchase ADMB from Otter Research.

The Moore Foundation provided a grant to

the National Center of Ecological Analysis and Synthesis

at the University of California at Santa Barbara

in late 2007 so that the Regents of the University of California could

purchase the rights to ADMB.

The purchase was completed in mid-2008, and the complete ADMB libraries were posted

on the ADMB Project website in December 2008. By May 2009, more

than 3000 downloads of the libraries had occurred. The

source code was made available in December 2009. In mid-2010,

ADMB was supported on all common operating systems (Windows,

Linux, MacOS and Sun/SPARC), for all common C++ compilers

(GCC, Visual Studio, Borland), and for both 32 and 64 bit

architectures.

ADMB Foundation efforts during the first two years of the ADMB

Project have focused on

automating the building of ADMB for different platforms,

streamlining installation, and creation of

a user-friendly working environments. Planned technical

developments

include parallelization of internal computations,

implementation of hybrid MCMC, and improvement of the large sparse matrix

for use in random effects models.

See also

References

{{Reflist|2}}