Skip to content

Commit

Permalink
Remove sampleSpace variables
Browse files Browse the repository at this point in the history
  • Loading branch information
fzaiser committed Nov 3, 2023
1 parent ecdc5e6 commit 671d977
Show file tree
Hide file tree
Showing 5 changed files with 35 additions and 69 deletions.
6 changes: 3 additions & 3 deletions src/Distributions/Bernoulli/Correctness.dfy
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ module Bernoulli.Correctness {

assert e in Rand.eventSpace && Rand.prob(e) == 0.0 by {
Rand.ProbIsProbabilityMeasure();
assert Measures.IsSigmaAlgebra(Rand.eventSpace, Rand.sampleSpace);
assert Measures.IsSigmaAlgebra(Rand.eventSpace);
assert Measures.IsPositive(Rand.eventSpace, Rand.prob);
}
} else {
Expand Down Expand Up @@ -102,7 +102,7 @@ module Bernoulli.Correctness {
calc {
Rand.prob(e);
Rand.prob(e1 + e2);
{ reveal A1; reveal A2; assert e1 * e2 == iset{}; Rand.ProbIsProbabilityMeasure(); Measures.PosCountAddImpliesAdd(Rand.eventSpace, Rand.sampleSpace, Rand.prob); assert Measures.IsAdditive(Rand.eventSpace, Rand.prob); }
{ reveal A1; reveal A2; assert e1 * e2 == iset{}; Rand.ProbIsProbabilityMeasure(); Measures.PosCountAddImpliesAdd(Rand.eventSpace, Rand.prob); assert Measures.IsAdditive(Rand.eventSpace, Rand.prob); }
Rand.prob(e1) + Rand.prob(e2);
{ reveal A1; reveal A2; }
(1.0 / n as real) + ((m - 1) as real / n as real);
Expand All @@ -114,7 +114,7 @@ module Bernoulli.Correctness {
Rand.ProbIsProbabilityMeasure();
reveal A1;
reveal A2;
Measures.BinaryUnion(Rand.eventSpace, Rand.sampleSpace, e1, e2);
Measures.BinaryUnion(Rand.eventSpace, e1, e2);
}
}
}
Expand Down
6 changes: 3 additions & 3 deletions src/Distributions/UniformPowerOfTwo/Correctness.dfy
Original file line number Diff line number Diff line change
Expand Up @@ -89,13 +89,13 @@ module UniformPowerOfTwo.Correctness {
assert e in Rand.eventSpace by {
assert e == e1 + e2;
Rand.ProbIsProbabilityMeasure();
Measures.BinaryUnion(Rand.eventSpace, Rand.sampleSpace, e1, e2);
Measures.BinaryUnion(Rand.eventSpace, e1, e2);
}
calc {
Rand.prob(e);
{ assert e == e1 + e2; }
Rand.prob(e1 + e2);
{ assert e1 * e2 == iset{}; Rand.ProbIsProbabilityMeasure(); Measures.PosCountAddImpliesAdd(Rand.eventSpace, Rand.sampleSpace, Rand.prob); assert Measures.IsAdditive(Rand.eventSpace, Rand.prob); }
{ assert e1 * e2 == iset{}; Rand.ProbIsProbabilityMeasure(); Measures.PosCountAddImpliesAdd(Rand.eventSpace, Rand.prob); assert Measures.IsAdditive(Rand.eventSpace, Rand.prob); }
Rand.prob(e1) + Rand.prob(e2);
{ UnifCorrectness2(n, m-1); UnifCorrectness2Inequality(n, m-1); }
(1.0 / (Helper.Power(2, Helper.Log2Floor(n)) as real)) + (((m-1) as real) / (Helper.Power(2, Helper.Log2Floor(n)) as real));
Expand All @@ -119,7 +119,7 @@ module UniformPowerOfTwo.Correctness {
if k == 0 {
reveal Model.Sample();
if m == 0 {
assert (iset s | Model.Sample(1)(s).value == m) == (iset s);
assert (iset s | Model.Sample(1)(s).value == m) == Measures.SampleSpace();
} else {
assert (iset s | Model.Sample(1)(s).value == m) == iset{};
}
Expand Down
62 changes: 22 additions & 40 deletions src/Math/Measures.dfy
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,17 @@ module Measures {

type Probability = x: real | 0.0 <= x <= 1.0

ghost predicate IsSigmaAlgebra<T(!new)>(eventSpace: iset<iset<T>>, sampleSpace: iset<T>) {
&& (forall e | e in eventSpace :: e <= sampleSpace)
ghost function Complement<T(!new)>(event: iset<T>): iset<T> {
iset x: T | x !in event
}

ghost function SampleSpace<T(!new)>(): iset<T> {
Complement(iset{})
}

ghost predicate IsSigmaAlgebra<T(!new)>(eventSpace: iset<iset<T>>) {
&& (iset{}) in eventSpace
&& (forall e | e in eventSpace :: (sampleSpace - e) in eventSpace)
&& (forall e | e in eventSpace :: Complement(e) in eventSpace)
&& (forall f: nat -> iset<T> | (forall n :: f(n) in eventSpace) :: (CountableUnion(f) in eventSpace))
}

Expand All @@ -26,20 +33,12 @@ module Measures {
f(i) + CountableSum(f, i+1)
}

ghost function Powerset<A(!new)>(): iset<A> {
iset _: A
}

ghost function DiscreteSigmaAlgebra<A(!new)>(): iset<iset<A>> {
iset _: iset<A>
}

ghost const boolSampleSpace: iset<bool> := Powerset<bool>()

ghost const boolEventSpace: iset<iset<bool>> := DiscreteSigmaAlgebra<bool>()

ghost const natSampleSpace: iset<nat> := Powerset<nat>()

// The sigma algebra on the natural numbers is just the power set
ghost const natEventSpace: iset<iset<nat>> := DiscreteSigmaAlgebra<nat>()

Expand All @@ -60,8 +59,8 @@ module Measures {
}

// Definition 6
ghost predicate IsMeasure<T(!new)>(eventSpace: iset<iset<T>>, sampleSpace: iset<T>, Prob: iset<T> -> real) {
&& IsSigmaAlgebra(eventSpace, sampleSpace)
ghost predicate IsMeasure<T(!new)>(eventSpace: iset<iset<T>>, Prob: iset<T> -> real) {
&& IsSigmaAlgebra(eventSpace)
&& IsPositive(eventSpace, Prob)
&& IsCountablyAdditive(eventSpace, Prob)
}
Expand All @@ -82,9 +81,9 @@ module Measures {
}

// Definition 12
ghost predicate IsProbability<T(!new)>(eventSpace: iset<iset<T>>, sampleSpace: iset<T>, Prob: iset<T> -> real) {
&& IsMeasure(eventSpace, sampleSpace, Prob)
&& Prob(sampleSpace) == 1.0
ghost predicate IsProbability<T(!new)>(eventSpace: iset<iset<T>>, Prob: iset<T> -> real) {
&& IsMeasure(eventSpace, Prob)
&& Prob(Complement(iset{})) == 1.0
}

// Definition 13
Expand All @@ -99,17 +98,11 @@ module Measures {
*******/

lemma boolsHaveSigmaAlgebra()
ensures IsSigmaAlgebra(boolEventSpace, boolSampleSpace)
{
forall e | e in boolEventSpace ensures e <= boolSampleSpace {
assert e <= boolSampleSpace by {
forall x: bool ensures x in e ==> x in boolSampleSpace {}
}
}
}
ensures IsSigmaAlgebra(boolEventSpace)
{}

lemma natsHaveSigmaAlgebra()
ensures IsSigmaAlgebra(natEventSpace, natSampleSpace)
ensures IsSigmaAlgebra(natEventSpace)
{}

lemma PreImageIdentity<S(!new)>(f: S -> S, e: iset<S>)
Expand All @@ -122,20 +115,9 @@ module Measures {
ensures PreImage(f, e) == PreImage(f', e')
{}

lemma SampleSpaceInEventSpace<T>(sampleSpace: iset<T>, eventSpace: iset<iset<T>>)
requires IsSigmaAlgebra(eventSpace, sampleSpace)
ensures sampleSpace in eventSpace
{
var empty := iset{};
assert empty in eventSpace;
var compl := sampleSpace - empty;
assert compl == sampleSpace;
assert compl in eventSpace;
}

// Equation (2.18)
lemma PosCountAddImpliesAdd<T(!new)>(eventSpace: iset<iset<T>>, sampleSpace: iset<T>, Prob: iset<T> -> real)
requires IsSigmaAlgebra(eventSpace, sampleSpace)
lemma PosCountAddImpliesAdd<T(!new)>(eventSpace: iset<iset<T>>, Prob: iset<T> -> real)
requires IsSigmaAlgebra(eventSpace)
requires IsPositive(eventSpace, Prob)
requires IsCountablyAdditive(eventSpace, Prob)
ensures IsAdditive(eventSpace, Prob)
Expand Down Expand Up @@ -174,8 +156,8 @@ module Measures {
ensures CountableUnion(f, i) == f(i) + CountableUnion(f, i + 1)
{}

lemma BinaryUnion<T(!new)>(eventSpace: iset<iset<T>>, sampleSpace: iset<T>, e1: iset<T>, e2: iset<T>)
requires IsSigmaAlgebra(eventSpace, sampleSpace)
lemma BinaryUnion<T(!new)>(eventSpace: iset<iset<T>>, e1: iset<T>, e2: iset<T>)
requires IsSigmaAlgebra(eventSpace)
requires e1 in eventSpace
requires e2 in eventSpace
ensures e1 + e2 in eventSpace
Expand Down
26 changes: 6 additions & 20 deletions src/ProbabilisticProgramming/Monad.dfy
Original file line number Diff line number Diff line change
Expand Up @@ -59,10 +59,6 @@ module Monad {
}
}

ghost function ResultSampleSpace<A(!new)>(sampleSpace: iset<A>): iset<Result<A>> {
iset r: Result<A> | r.Diverging? || (r.value in sampleSpace && r.rest in Rand.sampleSpace)
}

ghost function Values<A>(results: iset<Result<A>>): iset<A> {
iset r <- results | r.Result? :: r.value
}
Expand All @@ -75,12 +71,8 @@ module Monad {
iset e: iset<Result<A>> | Values(e) in eventSpace && Rests(e) in Rand.eventSpace
}

ghost const boolResultSampleSpace: iset<Result<bool>> := ResultSampleSpace(Measures.boolSampleSpace)

ghost const boolResultEventSpace: iset<iset<Result<bool>>> := ResultEventSpace(Measures.boolEventSpace)

ghost const natResultSampleSpace: iset<Result<nat>> := ResultSampleSpace(Measures.natSampleSpace)

ghost const natResultEventSpace: iset<iset<Result<nat>>> := ResultEventSpace(Measures.natEventSpace)

ghost function ResultsWithValueIn<A(!new)>(values: iset<A>): iset<Result<A>> {
Expand Down Expand Up @@ -145,12 +137,9 @@ module Monad {
ensures ResultsWithValueIn(event) in ResultEventSpace(eventSpace)
{
var results := ResultsWithValueIn(event);
assert Measures.IsSigmaAlgebra(Rand.eventSpace, Rand.sampleSpace) by {
assert Measures.IsSigmaAlgebra(Rand.eventSpace) by {
Rand.ProbIsProbabilityMeasure();
}
assert Rand.sampleSpace in Rand.eventSpace by {
Measures.SampleSpaceInEventSpace(Rand.sampleSpace, Rand.eventSpace);
}
assert Values(results) == event by {
forall v: A ensures v in event <==> v in Values(results) {
var s: Rand.Bitstream :| true;
Expand All @@ -159,8 +148,8 @@ module Monad {
}
assert Rests(results) in Rand.eventSpace by {
if v :| v in event {
assert Rests(results) == Rand.sampleSpace by {
forall s: Rand.Bitstream ensures s in Rests(results) <==> s in Rand.sampleSpace {
assert Rests(results) == Measures.SampleSpace() by {
forall s: Rand.Bitstream ensures s in Rests(results) <==> s in Measures.SampleSpace() {
calc {
s in Rests(results);
Result(v, s) in results;
Expand All @@ -177,19 +166,16 @@ module Monad {
lemma LiftRestInEventSpaceToResultEventSpace<A(!new)>(rests: iset<Rand.Bitstream>, eventSpace: iset<iset<A>>)
requires rests in Rand.eventSpace
requires iset{} in eventSpace
requires Measures.Powerset<A>() in eventSpace
requires Measures.SampleSpace() in eventSpace
ensures ResultsWithRestIn(rests) in ResultEventSpace(eventSpace)
{
var results := ResultsWithRestIn(rests);
assert Measures.IsSigmaAlgebra(Rand.eventSpace, Rand.sampleSpace) by {
assert Measures.IsSigmaAlgebra(Rand.eventSpace) by {
Rand.ProbIsProbabilityMeasure();
}
assert Rand.sampleSpace in Rand.eventSpace by {
Measures.SampleSpaceInEventSpace(Rand.sampleSpace, Rand.eventSpace);
}
assert Values(results) in eventSpace by {
if rest :| rest in rests {
assert Values(results) == Measures.Powerset<A>() by {
assert Values(results) == Measures.SampleSpace() by {
forall v: A ensures v in Values(results) {
assert Result(v, rest) in results;
}
Expand Down
4 changes: 1 addition & 3 deletions src/ProbabilisticProgramming/RandomSource.dfy
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,6 @@ module Rand {

type Bitstream = nat -> bool

ghost const sampleSpace: iset<Bitstream> := iset s: Bitstream

ghost const eventSpace: iset<iset<Bitstream>>

ghost const prob: iset<Bitstream> -> real
Expand Down Expand Up @@ -50,7 +48,7 @@ module Rand {
*******/

lemma {:axiom} ProbIsProbabilityMeasure()
ensures Measures.IsProbability(eventSpace, sampleSpace, prob)
ensures Measures.IsProbability(eventSpace, prob)

// Equation (2.68) && (2.77)
lemma {:axiom} CoinHasProbOneHalf(b: bool)
Expand Down

0 comments on commit 671d977

Please sign in to comment.