squiggle/packages/website/docs/Features/Functions.mdx

224 lines
6.3 KiB
Plaintext
Raw Normal View History

2022-03-25 02:08:46 +00:00
---
title: Functions reference
2022-03-25 02:08:46 +00:00
sidebar_position: 7
---
2022-04-11 00:13:11 +00:00
import { SquiggleEditor } from "../../src/components/SquiggleEditor";
2022-03-25 02:08:46 +00:00
_The source of truth for this document is [this file of code](https://github.com/quantified-uncertainty/squiggle/blob/develop/packages/squiggle-lang/src/rescript/ReducerInterface/ReducerInterface_GenericDistribution.res)_
2022-03-25 02:08:46 +00:00
# Inventory distributions
2022-03-25 02:08:46 +00:00
We provide starter distributions, computed symbolically.
## Normal distribution
2022-03-25 02:08:46 +00:00
The `normal(mean, sd)` function creates a normal distribution with the given mean
and standard deviation.
<SquiggleEditor initialSquiggleString="normal(5, 1)" />
2022-03-25 02:08:46 +00:00
### Validity
- `sd > 0`
## Uniform distribution
2022-03-25 02:08:46 +00:00
The `uniform(low, high)` function creates a uniform distribution between the
two given numbers.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="uniform(3, 7)" />
2022-03-25 02:08:46 +00:00
### Validity
- `low < high`
## Lognormal distribution
2022-03-25 02:08:46 +00:00
The `lognormal(mu, sigma)` returns the log of a normal distribution with parameters
`mu` and `sigma`. The log of `lognormal(mu, sigma)` is a normal distribution with mean `mu` and standard deviation `sigma`.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="lognormal(0, 0.7)" />
2022-03-25 02:08:46 +00:00
An alternative format is also available. The `to` notation creates a lognormal
2022-03-25 02:08:46 +00:00
distribution with a 90% confidence interval between the two numbers. We add
this convinience as lognormal distributions are commonly used in practice.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="2 to 10" />
### Future feature:
2022-03-25 02:08:46 +00:00
Furthermore, it's also possible to create a lognormal from it's actual mean
and standard deviation, using `lognormalFromMeanAndStdDev`.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="lognormalFromMeanAndStdDev(20, 10)" />
2022-03-25 02:08:46 +00:00
### Validity
- `sigma > 0`
- In `x to y` notation, `x < y`
## Beta distribution
2022-03-25 02:08:46 +00:00
The `beta(a, b)` function creates a beta distribution with parameters `a` and `b`:
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="beta(20, 20)" />
### Validity
- `a > 0`
- `b > 0`
- Empirically, we have noticed that numerical instability arises when `a < 1` or `b < 1`
2022-03-25 02:08:46 +00:00
## Exponential distribution
The `exponential(rate)` function creates an exponential distribution with the given
rate.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="exponential(1)" />
### Validity
- `rate > 0`
## Triangular distribution
2022-03-25 02:08:46 +00:00
The `triangular(a,b,c)` function creates a triangular distribution with lower
bound `a`, mode `b` and upper bound `c`.
### Validity
- `a < b < c`
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="triangular(1, 2, 4)" />
## Scalar (constant dist)
2022-03-25 02:08:46 +00:00
Squiggle, when the context is right, automatically casts a float to a constant distribution.
# Operating on distributions
Here are the ways we combine distributions.
## Mixture of distributions
The `mx` function combines 2 or more other distributions to create a weighted
2022-03-25 02:08:46 +00:00
combination of the two. The first positional arguments represent the distributions
to be combined, and the last argument is how much to weigh every distribution in the
combination.
2022-04-12 07:39:38 +00:00
<SquiggleEditor initialSquiggleString="mx(uniform(0,1), normal(1,1), [0.5, 0.5])" />
2022-03-25 02:08:46 +00:00
It's possible to create discrete distributions using this method.
2022-03-25 02:08:46 +00:00
2022-04-12 07:39:38 +00:00
<SquiggleEditor initialSquiggleString="mx(0, 1, [0.2,0.8])" />
2022-03-25 02:08:46 +00:00
As well as mixed distributions:
2022-04-12 07:39:38 +00:00
<SquiggleEditor initialSquiggleString="mx(3, 8, 1 to 10, [0.2, 0.3, 0.5])" />
2022-03-25 02:08:46 +00:00
An alias of `mx` is `mixture`
2022-03-25 02:08:46 +00:00
### Validity
Using javascript's variable arguments notation, consider `mx(...dists, weights)`:
- `dists.length == weights.length`
2022-04-10 23:15:46 +00:00
## Addition (horizontal right shift)
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="dist1 = 1 to 10; dist2 = triangular(1,2,3); dist1 + dist2">
2022-03-25 02:08:46 +00:00
## Subtraction (horizontal left shift)
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="dist1 = 1 to 10; dist2 = triangular(1,2,3); dist1 - dist2">
2022-03-25 02:08:46 +00:00
## Multiplication (??)
<SquiggleEditor initialSquiggleString="dist1 = 1 to 10; dist2 = triangular(1,2,3); dist1 * dist2">
## Division (???)
<SquiggleEditor initialSquiggleString="dist1 = 1 to 10; dist2 = triangular(1,2,3); dist1 / dist2">
## Taking the base `e` exponential
<SquiggleEditor initialSquiggleString="dist = triangular(1,2,3); exp(dist)">
## Taking the base `e` and base `10` logarithm
<SquiggleEditor initialSquiggleString="dist = triangular(1,2,3); log(dist)">
<SquiggleEditor initialSquiggleString="dist = beta(1,2); log10(dist)">
### Validity
- See [the current discourse](https://github.com/quantified-uncertainty/squiggle/issues/304)
# Standard functions on distributions
## Probability density function
2022-03-25 02:08:46 +00:00
The `pdf(dist, x)` function returns the density of a distribution at the
given point x.
<SquiggleEditor initialSquiggleString="pdf(normal(0,1),0)" />
### Validity
- `x` must be a scalar
- `dist` must be a distribution
2022-03-25 02:08:46 +00:00
## Cumulative density function
The `cdf(dist, x)` gives the cumulative probability of the distribution
or all values lower than x. It is the inverse of `inv`.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="cdf(normal(0,1),0)" />
### Validity
- `x` must be a scalar
- `dist` must be a distribution
## Inverse CDF
The `inv(dist, prob)` gives the value x or which the probability for all values
lower than x is equal to prob. It is the inverse of `cdf`.
<SquiggleEditor initialSquiggleString="inv(normal(0,1),0.5)" />
### Validity
- `prob` must be a scalar (please only put it in `(0,1)`)
- `dist` must be a distribution
## Mean
2022-04-10 23:15:46 +00:00
The `mean(distribution)` function gives the mean (expected value) of a distribution.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="mean(normal(5, 10))" />
## Sampling a distribution
2022-04-10 23:15:46 +00:00
The `sample(distribution)` samples a given distribution.
2022-03-25 02:08:46 +00:00
<SquiggleEditor initialSquiggleString="sample(normal(0, 10))" />
# Normalization
Some distribution operations (like horizontal shift) return an unnormalized distriibution.
We provide a `normalize` function
<SquiggleEditor initialSquiggleString="normalize((1e-1 to 1e0) + triangular(1e-1, 1e0, 1e1))" />
### Valdity
- Input to `normalize` must be a dist
We provide a predicate `isNormalized`, for when we have simple control flow
<SquiggleEditor initialSquiggleString="isNormalized((1e-1 to 1e0) * triangular(1e-1, 1e0, 1e1))" />
### Validity
- Input to `isNormalized` must be a dist
# Convert any distribution to a sample set distribution
`toSampleSet` has two signatures
It is unary when you use an internal hardcoded number of samples
<SquiggleEditor initialSquiggleString="toSampleSet(1e-1 to 1e0)" />
And binary when you provide a number of samples (truncated)
<SquiggleEditor initialSquiggleString="toSampleSet(1e-1 to 1e0, 1e2)" />