Created
November 9, 2013 16:30
-
-
Save anderssonfilip/7387119 to your computer and use it in GitHub Desktop.
Random Generators
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| trait Generator[+T] { | |
| self => | |
| def generate: T | |
| def map[S](f: T => S): Generator[S] = new Generator[S] { | |
| def generate = f(self.generate) | |
| } | |
| def flatMap[S](f: T => Generator[S]): Generator[S] = new Generator[S] { | |
| def generate = f(self.generate).generate | |
| } | |
| } | |
| trait Tree | |
| case class Leaf(x: Int) extends Tree | |
| case class Inner(left: Tree, right: Tree) extends Tree | |
| object RandomGenerators { | |
| val integers = new Generator[Int] { | |
| def generate = scala.util.Random.nextInt() | |
| } | |
| //val booleans = new Generator[Boolean] { | |
| // def generate = integers.generate > 0 | |
| //} | |
| //val pairs = new Generator[(Int, Int)] { | |
| // def generate = (integers.generate, integers.generate) | |
| //} | |
| val booleans = integers map (_ >= 0) | |
| def pairs[T, U](t: Generator[T], u: Generator[U]) = t flatMap { x => u map { y => (x, y) } } | |
| def single[T](x: T): Generator[T] = new Generator[T] { | |
| def generate = x | |
| } | |
| def choose(lo: Int, hi: Int): Generator[Int] = for (x <- integers) yield lo + x % (hi - lo) | |
| def oneOf[T](xs: T*): Generator[T] = for (idx <- choose(0, xs.length)) yield xs(idx) | |
| def nonEmptyLists = for { | |
| head <- integers | |
| tail <- lists | |
| } yield head :: tail | |
| def lists: Generator[List[Int]] = for { | |
| isEmpty <- booleans | |
| list <- if (isEmpty) single(Nil) else nonEmptyLists | |
| } yield list | |
| def leafs: Generator[Leaf] = for { | |
| x <- integers | |
| } yield Leaf(x) | |
| def inners: Generator[Inner] = for { | |
| l <- trees | |
| r <- trees | |
| } yield Inner(l, r) | |
| def trees: Generator[Tree] = for { | |
| isLeaf <- booleans | |
| tree <- if (isLeaf) leafs else inners | |
| } yield tree | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment