<!-- Generated by pkgdown: do not edit by hand -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Customise priors for outbreaker — custom_priors • outbreaker2</title>
<!-- jquery -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
<!-- Bootstrap -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css" integrity="sha256-bZLfwXAP04zRMK2BjiO8iu9pf4FbLqX6zitd+tIvLhE=" crossorigin="anonymous" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js" integrity="sha256-nuL8/2cJ5NDSSwnKD8VqreErSWHtnEP9E7AySL+1ev4=" crossorigin="anonymous"></script>
<!-- bootstrap-toc -->
<link rel="stylesheet" href="../bootstrap-toc.css">
<script src="../bootstrap-toc.js"></script>
<!-- Font Awesome icons -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.12.1/css/all.min.css" integrity="sha256-mmgLkCYLUQbXn0B1SRqzHar6dCnv9oZFPEC1g1cwlkk=" crossorigin="anonymous" />
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.12.1/css/v4-shims.min.css" integrity="sha256-wZjR52fzng1pJHwx4aV2AO3yyTOXrcDW7jBpJtTwVxw=" crossorigin="anonymous" />
<!-- clipboard.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.6/clipboard.min.js" integrity="sha256-inc5kl9MA1hkeYUt+EC3BhlIgyp/2jDIyBLS6k3UxPI=" crossorigin="anonymous"></script>
<!-- headroom.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.11.0/headroom.min.js" integrity="sha256-AsUX4SJE1+yuDu5+mAVzJbuYNPHj/WroHuZ8Ir/CkE0=" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.11.0/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script>
<!-- pkgdown -->
<link href="../pkgdown.css" rel="stylesheet">
<script src="../pkgdown.js"></script>
<meta property="og:title" content="Customise priors for outbreaker — custom_priors" />
<meta property="og:description" content="Priors can be specified in several ways in outbreaker2 (see details and
examples). The most flexible way to specify a prior is to provide a prior
function directly. This function must take an argument 'param', which is a
list which contains all the states of the parameters and augmented data. See
the documentation of create_param for more information." />
<!-- mathjax -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script>
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script>
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->
</head>
<body data-spy="scroll" data-target="#toc">
<div class="container template-reference-topic">
<header>
<div class="navbar navbar-default navbar-fixed-top" role="navigation">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<span class="navbar-brand">
<a class="navbar-link" href="../index.html">outbreaker2</a>
<span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">1.1.2</span>
</span>
</div>
<div id="navbar" class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li>
<a href="../index.html">
<span class="fas fa-home fa-lg"></span>
</a>
</li>
<li>
<a href="../reference/index.html">Reference</a>
</li>
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">
Articles
<span class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu">
<li>
<a href="../articles/customisation.html">Using custom priors, likelihood, or movements in outbreaker2</a>
</li>
<li>
<a href="../articles/introduction.html">Introduction to outbreaker2</a>
</li>
<li>
<a href="../articles/overview.html">outbreaker2: package overview</a>
</li>
<li>
<a href="../articles/Rcpp_API.html">outbreaker2: Rcpp API</a>
</li>
</ul>
</li>
<li>
<a href="../news/index.html">Changelog</a>
</li>
</ul>
<ul class="nav navbar-nav navbar-right">
</ul>
</div><!--/.nav-collapse -->
</div><!--/.container -->
</div><!--/.navbar -->
</header>
<div class="row">
<div class="col-md-9 contents">
<div class="page-header">
<h1>Customise priors for outbreaker</h1>
<div class="hidden name"><code>custom_priors.Rd</code></div>
</div>
<div class="ref-description">
<p>Priors can be specified in several ways in outbreaker2 (see details and
examples). The most flexible way to specify a prior is to provide a prior
function directly. This function must take an argument 'param', which is a
list which contains all the states of the parameters and augmented data. See
the documentation of <a href='create_param.html'>create_param</a> for more information.</p>
</div>
<pre class="usage"><span class='fu'>custom_priors</span><span class='op'>(</span><span class='va'>...</span><span class='op'>)</span>
<span class='co'># S3 method for custom_priors</span>
<span class='fu'><a href='https://rdrr.io/r/base/print.html'>print</a></span><span class='op'>(</span><span class='va'>x</span>, <span class='va'>...</span><span class='op'>)</span></pre>
<h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2>
<table class="ref-arguments">
<colgroup><col class="name" /><col class="desc" /></colgroup>
<tr>
<th>...</th>
<td><p>A list or a series of named, comma-separated functions
implementing priors. Each function must have a single argument, which
corresponds to a 'outbreaker_param' list.</p></td>
</tr>
<tr>
<th>x</th>
<td><p>an <code>outbreaker_config</code> object as returned by <code>create_config</code>.</p></td>
</tr>
</table>
<h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2>
<p>A list of custom functions with class <code>custom_priors</code>. Values
set to <code>NULL</code> will be ignored and default functions will be used
instead.</p>
<h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2>
<p>There are three ways a user can specify priors:<br /></p>
<p>1) Default: this is what happens when the 'config' has default values of
prior parameters.<br />
2) Customized parameters: in this case, the prior functions are the default
ones from the package, but will use custom parameters, specified by the user
through <code><a href='create_config.html'>create_config</a></code>.<br /></p>
<p>3) Customized functions: in this case, prior functions themselves are
specified by the user, through the '...' argument of 'custom_priors'. The
requirements is that such functions must have either hard-coded parameters or
enclosed values. They will take a single argument which is a list containing
all model parameters with the class 'outbreaker_param'. ALL PRIORS functions
are expected to return values on a LOG SCALE.<br /></p>
<p>Priors currently used for the model are:</p><ul>
<li><p><code>mu</code> (mutation rate): default function is an exponential
distribution implemented in <code>outbreaker:::cpp_prior_mu</code>. New prior
functions should use <code>x$mu</code> to refer to the current value of <code>mu</code>,
assuming their argument is called <code>x</code>.</p></li>
<li><p><code>pi</code> (reporting probability): default function is a beta
distribution implemented in <code>outbreaker:::cpp_prior_pi</code>. New prior
functions should use <code>x$pi</code> to refer to the current value of <code>pi</code>,
assuming their argument is called <code>x</code>.</p></li>
<li><p><code>eps</code> (contact reporting coverage): default function is a beta
distribution implemented in <code>outbreaker:::cpp_prior_eps</code>. New prior
functions should use <code>x$eps</code> to refer to the current value of <code>eps</code>,
assuming their argument is called <code>x</code>.</p></li>
<li><p><code>lambda</code> (non-infectious contact rate): default function is a
beta distribution implemented in <code>outbreaker:::cpp_prior_lambda</code>. New
prior functions should use <code>x$lambda</code> to refer to the current value of
<code>lambda</code>, assuming their argument is called <code>x</code>.</p></li>
</ul>
<h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2>
<div class='dont-index'><p>See <a href='http://www.repidemicsconsortium.org/outbreaker2/articles/customisation.html#customising-priors'>customization vignette</a> for detailed examples on how to customize priors.</p></div>
<h2 class="hasAnchor" id="author"><a class="anchor" href="#author"></a>Author</h2>
<p>Thibaut Jombart (<a href='mailto:thibautjombart@gmail.com'>thibautjombart@gmail.com</a>).</p>
<h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2>
<pre class="examples"><div class='input'>
<span class='co'>## BASIC CONFIGURATION</span>
<span class='fu'>custom_priors</span><span class='op'>(</span><span class='op'>)</span>
</div><div class='output co'>#>
#>
#> ///// outbreaker custom priors ///
#>
#> class: custom_priors list
#> number of items: 4
#>
#> /// custom priors set to NULL (default used) //
#> $mu
#> NULL
#>
#> $pi
#> NULL
#>
#> $eps
#> NULL
#>
#> $lambda
#> NULL
#> </div><div class='input'>
<span class='co'>## SPECIFYING PRIOR PARAMETERS</span>
<span class='co'>## - this will need to be passed to outbreaker</span>
<span class='va'>default_config</span> <span class='op'><-</span> <span class='fu'><a href='create_config.html'>create_config</a></span><span class='op'>(</span><span class='op'>)</span>
<span class='va'>new_config</span> <span class='op'><-</span> <span class='fu'><a href='create_config.html'>create_config</a></span><span class='op'>(</span>prior_mu <span class='op'>=</span> <span class='fl'>1e-5</span>,
prior_pi <span class='op'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span><span class='op'>(</span><span class='fl'>2</span>, <span class='fl'>1</span><span class='op'>)</span><span class='op'>)</span>
<span class='co'>## - to check the prior manually, default settings:</span>
<span class='va'>param</span> <span class='op'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/list.html'>list</a></span><span class='op'>(</span>mu <span class='op'>=</span> <span class='fl'>0.001</span>, pi <span class='op'>=</span> <span class='fl'>0.9</span><span class='op'>)</span>
<span class='fu'>outbreaker2</span><span class='fu'>:::</span><span class='fu'>cpp_prior_mu</span><span class='op'>(</span><span class='va'>param</span>, <span class='va'>default_config</span><span class='op'>)</span>
</div><div class='output co'>#> [1] -0.001</div><div class='input'><span class='fu'>outbreaker2</span><span class='fu'>:::</span><span class='fu'>cpp_prior_pi</span><span class='op'>(</span><span class='va'>param</span>, <span class='va'>default_config</span><span class='op'>)</span>
</div><div class='output co'>#> [1] 1.35434</div><div class='input'>
<span class='fu'>outbreaker2</span><span class='fu'>:::</span><span class='fu'>cpp_prior_mu</span><span class='op'>(</span><span class='va'>param</span>, <span class='va'>new_config</span><span class='op'>)</span>
</div><div class='output co'>#> [1] -11.51293</div><div class='input'><span class='fu'>outbreaker2</span><span class='fu'>:::</span><span class='fu'>cpp_prior_pi</span><span class='op'>(</span><span class='va'>param</span>, <span class='va'>new_config</span><span class='op'>)</span>
</div><div class='output co'>#> [1] 0.5877867</div><div class='input'>
<span class='co'>## these correspond to:</span>
<span class='fu'><a href='https://rdrr.io/r/stats/Exponential.html'>dexp</a></span><span class='op'>(</span><span class='fl'>0.001</span>, <span class='fl'>0.01</span>, log <span class='op'>=</span> <span class='cn'>TRUE</span><span class='op'>)</span>
</div><div class='output co'>#> [1] -4.60518</div><div class='input'><span class='fu'><a href='https://rdrr.io/r/stats/Beta.html'>dbeta</a></span><span class='op'>(</span><span class='fl'>0.9</span>, <span class='fl'>2</span>, <span class='fl'>1</span>, log <span class='op'>=</span> <span class='cn'>TRUE</span><span class='op'>)</span>
</div><div class='output co'>#> [1] 0.5877867</div><div class='input'>
<span class='co'>## SPECIFYING A PRIOR FUNCTION</span>
<span class='co'>## flat prior for pi between 0.5 and 1</span>
<span class='va'>f</span> <span class='op'><-</span> <span class='kw'>function</span><span class='op'>(</span><span class='va'>x</span><span class='op'>)</span> <span class='op'>{</span><span class='fu'><a href='https://rdrr.io/r/base/ifelse.html'>ifelse</a></span><span class='op'>(</span><span class='va'>x</span><span class='op'>$</span><span class='va'>pi</span> <span class='op'>></span> <span class='fl'>0.5</span>, <span class='fu'><a href='https://rdrr.io/r/base/Log.html'>log</a></span><span class='op'>(</span><span class='fl'>2</span><span class='op'>)</span>, <span class='fu'><a href='https://rdrr.io/r/base/Log.html'>log</a></span><span class='op'>(</span><span class='fl'>0</span><span class='op'>)</span><span class='op'>)</span><span class='op'>}</span>
<span class='va'>priors</span> <span class='op'><-</span> <span class='fu'>custom_priors</span><span class='op'>(</span>pi <span class='op'>=</span> <span class='va'>f</span><span class='op'>)</span>
<span class='va'>priors</span> <span class='co'># this should be passed to outbreaker</span>
</div><div class='output co'>#>
#>
#> ///// outbreaker custom priors ///
#>
#> class: custom_priors list
#> number of items: 4
#>
#> /// custom priors set to NULL (default used) //
#> $mu
#> NULL
#>
#> $eps
#> NULL
#>
#> $lambda
#> NULL
#>
#> /// custom priors //
#> $pi
#> function(x) {ifelse(x$pi > 0.5, log(2), log(0))}
#> <environment: 0x00000000348b8158>
#> </div><div class='input'>
<span class='co'>## test the prior manually</span>
<span class='va'>priors</span><span class='op'>$</span><span class='fu'>pi</span><span class='op'>(</span><span class='fu'><a href='https://rdrr.io/r/base/list.html'>list</a></span><span class='op'>(</span>pi<span class='op'>=</span><span class='fl'>1</span><span class='op'>)</span><span class='op'>)</span>
</div><div class='output co'>#> [1] 0.6931472</div><div class='input'><span class='va'>priors</span><span class='op'>$</span><span class='fu'>pi</span><span class='op'>(</span><span class='fu'><a href='https://rdrr.io/r/base/list.html'>list</a></span><span class='op'>(</span>pi<span class='op'>=</span><span class='fl'>.6</span><span class='op'>)</span><span class='op'>)</span>
</div><div class='output co'>#> [1] 0.6931472</div><div class='input'><span class='va'>priors</span><span class='op'>$</span><span class='fu'>pi</span><span class='op'>(</span><span class='fu'><a href='https://rdrr.io/r/base/list.html'>list</a></span><span class='op'>(</span>pi<span class='op'>=</span><span class='fl'>.2</span><span class='op'>)</span><span class='op'>)</span>
</div><div class='output co'>#> [1] -Inf</div><div class='input'><span class='va'>priors</span><span class='op'>$</span><span class='fu'>pi</span><span class='op'>(</span><span class='fu'><a href='https://rdrr.io/r/base/list.html'>list</a></span><span class='op'>(</span>pi<span class='op'>=</span><span class='fl'>.49</span><span class='op'>)</span><span class='op'>)</span>
</div><div class='output co'>#> [1] -Inf</div><div class='input'>
</div></pre>
</div>
<div class="col-md-3 hidden-xs hidden-sm" id="pkgdown-sidebar">
<nav id="toc" data-toggle="toc" class="sticky-top">
<h2 data-toc-skip>Contents</h2>
</nav>
</div>
</div>
<footer>
<div class="copyright">
<p>Developed by Thibaut Jombart, Finlay Campbell, Rich Fitzjohn.</p>
</div>
<div class="pkgdown">
<p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.6.1.</p>
</div>
</footer>
</div>
</body>
</html>