squiggle/packages/squiggle-lang/src/rescript/FunctionRegistry/FunctionRegistry_Library.res

116 lines
3.5 KiB
Plaintext
Raw Normal View History

open FunctionRegistry_Core
open FunctionRegistry_Helpers
2022-05-21 15:41:12 +00:00
let twoArgs = E.Tuple2.toFnCall
2022-05-24 11:52:27 +00:00
module FnDeclaration = {
type range = {min: float, max: float}
let makeRange = (min, max) => {min: min, max: max}
type t = {
fn: ReducerInterface_ExpressionValue.lambdaValue,
args: array<range>,
}
let validate = (def: t) => {
let {parameters, _} = def.fn
E.A.length(parameters) == E.A.length(def.args)
}
let frType = FRTypeRecord([
("fn", FRTypeLambda),
("inputs", FRTypeArray(FRTypeRecord([("min", FRTypeNumber), ("max", FRTypeNumber)]))),
])
let fromExpressionValue = (e: expressionValue) => {
let values = FunctionRegistry_Core.FRType.matchWithExpressionValue(frType, e)
switch values->E.O2.fmap(r =>
FunctionRegistry_Helpers.Prepare.ToValueArray.Record.twoArgs([r])
) {
| Some(Ok([FRValueLambda(lambda), FRValueArray(inputs)])) => {
open FunctionRegistry_Helpers.Prepare
let getMinMax = arg =>
ToValueArray.Record.toArgs([arg])
->E.R.bind(ToValueTuple.twoNumbers)
->E.R2.fmap(((min, max)) => makeRange(min, max))
inputs
->E.A2.fmap(getMinMax)
->E.A.R.firstErrorOrOpen
->E.R2.fmap(args => {fn: lambda, args: args})
}
| _ => Error("Error")
}
}
}
2022-05-22 14:38:17 +00:00
let registry = [
2022-05-24 00:49:10 +00:00
Function.make(
~name="FnMake",
~definitions=[
2022-05-24 11:52:27 +00:00
FnDefinition.make(~name="declareFn", ~inputs=[FnDeclaration.frType], ~run=(inputs, _) => {
let result = inputs->E.A.unsafe_get(0)->FunctionRegistry_Core.FRType.matchReverse->Ok
let foo = result->E.R2.fmap(FnDeclaration.fromExpressionValue)
Js.log2("HIHIHI", foo)
result
}),
2022-05-24 00:49:10 +00:00
],
),
2022-05-22 14:38:17 +00:00
Function.make(
~name="Normal",
~definitions=[
2022-05-22 14:38:17 +00:00
TwoArgDist.make("normal", twoArgs(SymbolicDist.Normal.make)),
2022-05-23 18:28:32 +00:00
TwoArgDist.makeRecordP5P95("normal", r =>
twoArgs(SymbolicDist.Normal.from90PercentCI, r)->Ok
),
2022-05-22 14:38:17 +00:00
TwoArgDist.makeRecordMeanStdev("normal", twoArgs(SymbolicDist.Normal.make)),
],
2022-05-22 14:38:17 +00:00
),
Function.make(
~name="Lognormal",
~definitions=[
2022-05-22 14:38:17 +00:00
TwoArgDist.make("lognormal", twoArgs(SymbolicDist.Lognormal.make)),
TwoArgDist.makeRecordP5P95("lognormal", r =>
twoArgs(SymbolicDist.Lognormal.from90PercentCI, r)->Ok
),
TwoArgDist.makeRecordMeanStdev("lognormal", twoArgs(SymbolicDist.Lognormal.fromMeanAndStdev)),
],
2022-05-22 14:38:17 +00:00
),
2022-05-20 21:36:40 +00:00
Function.make(
~name="Uniform",
2022-05-22 14:38:17 +00:00
~definitions=[TwoArgDist.make("uniform", twoArgs(SymbolicDist.Uniform.make))],
2022-05-20 21:36:40 +00:00
),
Function.make(
~name="Beta",
2022-05-22 14:38:17 +00:00
~definitions=[TwoArgDist.make("beta", twoArgs(SymbolicDist.Beta.make))],
2022-05-20 21:36:40 +00:00
),
Function.make(
~name="Cauchy",
2022-05-22 14:38:17 +00:00
~definitions=[TwoArgDist.make("cauchy", twoArgs(SymbolicDist.Cauchy.make))],
2022-05-20 21:36:40 +00:00
),
Function.make(
~name="Gamma",
2022-05-22 14:38:17 +00:00
~definitions=[TwoArgDist.make("gamma", twoArgs(SymbolicDist.Gamma.make))],
2022-05-20 21:36:40 +00:00
),
Function.make(
~name="Logistic",
2022-05-22 14:38:17 +00:00
~definitions=[TwoArgDist.make("logistic", twoArgs(SymbolicDist.Logistic.make))],
2022-05-20 21:36:40 +00:00
),
Function.make(
~name="To",
2022-05-23 18:28:32 +00:00
~definitions=[
TwoArgDist.make("to", twoArgs(SymbolicDist.From90thPercentile.make)),
TwoArgDist.make(
"credibleIntervalToDistribution",
twoArgs(SymbolicDist.From90thPercentile.make),
),
2022-05-23 17:49:39 +00:00
],
2022-05-23 18:28:32 +00:00
),
Function.make(
~name="Exponential",
~definitions=[OneArgDist.make("exponential", SymbolicDist.Exponential.make)],
),
Function.make(
~name="Bernoulli",
~definitions=[OneArgDist.make("bernoulli", SymbolicDist.Bernoulli.make)],
2022-05-21 02:54:15 +00:00
),
2022-05-20 21:36:40 +00:00
]