Skip to content
This repository has been archived by the owner on Apr 2, 2023. It is now read-only.

Commit

Permalink
feat(random): adds several ways of generating seeded random numbers
Browse files Browse the repository at this point in the history
Using the pure-rand library, we now provide several ways to generate seeded random data:
xorshift128plus, mersenne, xoroshiro128plus, congruential, congruential32
  • Loading branch information
tdreyno committed Feb 11, 2020
1 parent b53fd18 commit e2da149
Show file tree
Hide file tree
Showing 10 changed files with 310 additions and 82 deletions.
1 change: 1 addition & 0 deletions SUMMARY.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,3 +10,4 @@
- [Instance Methods](docs/api/instance.md)
- [Simplex Methods](docs/api/simplex.md)
- [Combinatorial Methods](docs/api/combinatorics.md)
- [Random Number Generating Methods](docs/api/random.md)
143 changes: 143 additions & 0 deletions docs/api/random.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
# Random Number Generating Methods

These methods create reproducible sequences of random numbers given an initial seed value.

This methods rely on the [pure-rand](https://github.com/dubzzz/pure-rand) project.

## random

Generates random numbers using the Mersenne Twister generator whose values are within the range 0 to 0xffffffff.

{% tabs %}
{% tab title="Usage" %}

```typescript
const SEED = 5;
const sequence: Seq<number> = random(SEED);
```

{% endtab %}

{% tab title="Type Definition" %}

```typescript
type random = (seed = DEFAULT_SEED) => Seq<number>;
```

{% endtab %}
{% endtabs %}

## mersenne

Generates random numbers using the Mersenne Twister generator whose values are within the range 0 to 0xffffffff.

{% tabs %}
{% tab title="Usage" %}

```typescript
const SEED = 5;
const sequence: Seq<number> = mersenne(SEED);
```

{% endtab %}

{% tab title="Type Definition" %}

```typescript
type mersenne = (seed = DEFAULT_SEED) => Seq<number>;
```

{% endtab %}
{% endtabs %}

## xorshift128plus

Generates random numbers using the xorshift128+ generator whose values are within the range -0x80000000 to 0x7fffffff.

{% tabs %}
{% tab title="Usage" %}

```typescript
const SEED = 5;
const sequence: Seq<number> = xorshift128plus(SEED);
```

{% endtab %}

{% tab title="Type Definition" %}

```typescript
type xorshift128plus = (seed = DEFAULT_SEED) => Seq<number>;
```

{% endtab %}
{% endtabs %}

## xoroshiro128plus

Generates random numbers using the xoroshiro128+ generator whose values are within the range -0x80000000 to 0x7fffffff.

{% tabs %}
{% tab title="Usage" %}

```typescript
const SEED = 5;
const sequence: Seq<number> = xoroshiro128plus(SEED);
```

{% endtab %}

{% tab title="Type Definition" %}

```typescript
type xoroshiro128plus = (seed = DEFAULT_SEED) => Seq<number>;
```

{% endtab %}
{% endtabs %}

## congruential

Generates random numbers using a Linear Congruential generator whose values are within the range 0 to 0x7fff.

{% tabs %}
{% tab title="Usage" %}

```typescript
const SEED = 5;
const sequence: Seq<number> = congruential(SEED);
```

{% endtab %}

{% tab title="Type Definition" %}

```typescript
type congruential = (seed = DEFAULT_SEED) => Seq<number>;
```

{% endtab %}
{% endtabs %}

## congruential32

Generates random numbers using a Linear Congruential generator whose values are within the range 0 to 0xffffffff.

{% tabs %}
{% tab title="Usage" %}

```typescript
const SEED = 5;
const sequence: Seq<number> = congruential32(SEED);
```

{% endtab %}

{% tab title="Type Definition" %}

```typescript
type congruential32 = (seed = DEFAULT_SEED) => Seq<number>;
```

{% endtab %}
{% endtabs %}
9 changes: 3 additions & 6 deletions docs/api/simplex.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ Generates a 2d simplex noise.

```typescript
const SEED = 5;
const sequence: Seq<number> = Seq.simplex2D((x, y) => x + y, SEED);
const sequence: Seq<number> = simplex2D((x, y) => x + y, SEED);
```

{% endtab %}
Expand All @@ -39,7 +39,7 @@ Generates a 3d simplex noise.

```typescript
const SEED = 5;
const sequence: Seq<number> = Seq.simplex3D((x, y, z) => x + y + z, SEED);
const sequence: Seq<number> = simplex3D((x, y, z) => x + y + z, SEED);
```

{% endtab %}
Expand All @@ -65,10 +65,7 @@ Generates a 4d simplex noise.

```typescript
const SEED = 5;
const sequence: Seq<number> = Seq.simplex4D(
(x, y, z, w) => x + y + z + w,
SEED
);
const sequence: Seq<number> = simplex4D((x, y, z, w) => x + y + z + w, SEED);
```

{% endtab %}
Expand Down
74 changes: 37 additions & 37 deletions docs/api/static.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ Takes a normal JavaScript array and turns it into a Sequence of the same type.
{% tab title="Usage" %}

```typescript
const sequence: Seq<number> = Seq.fromArray([1, 2, 3]);
const sequence: Seq<number> = fromArray([1, 2, 3]);
```

{% endtab %}
Expand All @@ -31,7 +31,7 @@ The `iterate` method simplifies the construction of infinite sequences which are

```typescript
// Builds an infinite sequence that counts up from 0.
const sequence: Seq<number> = Seq.iterate(a => a + 1, 0);
const sequence: Seq<number> = iterate(a => a + 1, 0);
```

{% endtab %}
Expand All @@ -53,7 +53,7 @@ The `fib` method generates a sequence of fibonacci numbers.
{% tab title="Usage" %}
```typescript
const sequence: Seq<number> = Seq.fib();
const sequence: Seq<number> = fib();
```

{% endtab %}
Expand All @@ -76,7 +76,7 @@ Generates a random sequence using `Math.random`.

```typescript
// Builds sequence of random numbers between 0 and 1.
const sequence: Seq<number> = Seq.random();
const sequence: Seq<number> = random();
```

{% endtab %}
Expand All @@ -99,27 +99,27 @@ Creates a sequence that counts between a start and end value. Takes an optional

```typescript
// Step by 1 from 0 through 10.
const sequence: Seq<number> = Seq.range(0, 10);
const sequence: Seq<number> = range(0, 10);
```

```typescript
// Step by 1 from 0 through Infinity.
const sequence: Seq<number> = Seq.range(0, Infinity);
const sequence: Seq<number> = range(0, Infinity);
```

```typescript
// Step by 1 from -10 through +10.
const sequence: Seq<number> = Seq.range(-10, 10);
const sequence: Seq<number> = range(-10, 10);
```

```typescript
// Step down from +10 through -10.
const sequence: Seq<number> = Seq.range(10, -10);
const sequence: Seq<number> = range(10, -10);
```

```typescript
// Step by 2 from 0 through 10.
const sequence: Seq<number> = Seq.range(0, 10, 2);
const sequence: Seq<number> = range(0, 10, 2);
```

{% endtab %}
Expand All @@ -145,7 +145,7 @@ A sequence that counts from `0` to `Infinity`.
{% tab title="Usage" %}

```typescript
const sequence: Seq<number> = Seq.infinite();
const sequence: Seq<number> = infinite();
```

{% endtab %}
Expand All @@ -169,7 +169,7 @@ A sequence with only a single value inside. Also known as "singleton."
{% tab title="Usage" %}

```typescript
const sequence: Seq<number> = Seq.of(2);
const sequence: Seq<number> = of(2);
```

{% endtab %}
Expand All @@ -191,7 +191,7 @@ Create a sequence that is the infinite repetition of a series of values.
{% tab title="Usage" %}

```typescript
const sequence: Seq<string> = Seq.cycle(["a", "b", "c"]);
const sequence: Seq<string> = cycle(["a", "b", "c"]);
```

{% endtab %}
Expand All @@ -214,12 +214,12 @@ Create a sequence which repeats the same value X number of times. The length of

```typescript
// Creates a sequence of 5 true values.
const sequence: Seq<boolean> = Seq.repeat(true, 5);
const sequence: Seq<boolean> = repeat(true, 5);
```

```typescript
// Creates a sequence of 0 which repeats infinitely.
const sequence: Seq<number> = Seq.repeat(0);
const sequence: Seq<number> = repeat(0);
```

{% endtab %}
Expand All @@ -241,7 +241,7 @@ Creates a sequence which pulls from an impure callback to generate the sequence.
{% tab title="Usage" %}

```typescript
const sequence: Seq<Date> = Seq.repeatedly(() => new Date());
const sequence: Seq<Date> = repeatedly(() => new Date());
```

{% endtab %}
Expand All @@ -263,7 +263,7 @@ A sequence with nothing in it. Useful as a "no op" for certain code-paths when j
{% tab title="Usage" %}

```typescript
const sequence: Seq<never> = Seq.empty();
const sequence: Seq<never> = empty();
```

{% endtab %}
Expand All @@ -285,11 +285,11 @@ Takes two sequences and lazily combines them to produce a tuple with the current
{% tab title="Usage" %}

```typescript
const seq1 = Seq.fromArray(["zero", "one", "two", "three"]);
const seq2 = Seq.range(0, 3);
const seq1 = fromArray(["zero", "one", "two", "three"]);
const seq2 = range(0, 3);

// Gives: ["zero", 0] -> ["one", 1] -> ["two", 2] -> ["three", 3]
const sequence: Seq<[string, number]> = Seq.zip(seq1, seq2);
const sequence: Seq<[string, number]> = zip(seq1, seq2);
```

{% endtab %}
Expand All @@ -314,11 +314,11 @@ Takes two sequences and lazily combines them to produce an arbitrary value by ma
{% tab title="Usage" %}

```typescript
const seq1 = Seq.range(0, 3);
const seq2 = Seq.repeat(2);
const seq1 = range(0, 3);
const seq2 = repeat(2);

// Gives: 0 -> 2 -> 4 -> 6
const sequence: Seq<number> = Seq.zipWith(
const sequence: Seq<number> = zipWith(
([num, multiplier]) => num * multiplier,
seq1,
seq2
Expand Down Expand Up @@ -351,12 +351,12 @@ Takes three sequences and lazily combines them to produce a 3-tuple with the cur
{% tab title="Usage" %}

```typescript
const seq1 = Seq.fromArray(["zero", "one", "two", "three"]);
const seq2 = Seq.range(0, 3);
const seq3 = Seq.range(3, 0);
const seq1 = fromArray(["zero", "one", "two", "three"]);
const seq2 = range(0, 3);
const seq3 = range(3, 0);

// Gives: ["zero", 0, 3] -> ["one", 1, 2] -> ["two", 2, 1] -> ["three", 3, 0]
const sequence: Seq<[string, number]> = Seq.zip3(seq1, seq2, seq3);
const sequence: Seq<[string, number]> = zip3(seq1, seq2, seq3);
```

{% endtab %}
Expand All @@ -382,12 +382,12 @@ Takes three sequences and lazily combines them to produce an arbitrary value by
{% tab title="Usage" %}

```typescript
const seq1 = Seq.range(0, 3);
const seq2 = Seq.repeat(2);
const seq3 = Seq.repeat(1);
const seq1 = range(0, 3);
const seq2 = repeat(2);
const seq3 = repeat(1);

// Gives: 0 -> 2 -> 4 -> 6
const sequence: Seq<number> = Seq.zip3With(
const sequence: Seq<number> = zip3With(
([num, multiplier, divisor]) => (num * multiplier) / divisor,
seq1,
seq2,
Expand Down Expand Up @@ -429,10 +429,10 @@ Combines 2 or more sequences into a single sequence.
{% tab title="Usage" %}

```typescript
const sequence: Seq<number> = Seq.concat(
Seq.fromArray([0, 1]),
Seq.fromArray([2, 3]),
Seq.fromArray([4, 5])
const sequence: Seq<number> = concat(
fromArray([0, 1]),
fromArray([2, 3]),
fromArray([4, 5])
);
```

Expand All @@ -456,9 +456,9 @@ Takes 2 or more sequences and creates a new sequence built by pulling the next v

```typescript
// Builds: a -> 1 -> b -> 2 -> c -> 3
const sequence: Seq<string | number> = Seq.interleave(
Seq.fromArray(["a", "b", "c"]),
Seq.range(1, 3)
const sequence: Seq<string | number> = interleave(
fromArray(["a", "b", "c"]),
range(1, 3)
);
```

Expand Down
Loading

0 comments on commit e2da149

Please sign in to comment.