mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2024-10-23 10:13:13 +02:00
65 lines
1.1 KiB
TypeScript
65 lines
1.1 KiB
TypeScript
|
|
|||
|
export interface RNG {
|
|||
|
random(): number
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
* very bad RNG, meant to be used as introduction to RNG manipulation. It has a
|
|||
|
* period of 1024.
|
|||
|
*/
|
|||
|
class RNG0 implements RNG {
|
|||
|
x: number;
|
|||
|
m: number = 1024;
|
|||
|
a: number = 341;
|
|||
|
c: number = 1;
|
|||
|
|
|||
|
constructor() {
|
|||
|
this.x = 0;
|
|||
|
this.reset();
|
|||
|
}
|
|||
|
|
|||
|
step() {
|
|||
|
this.x = (this.a*this.x+this.c) % this.m;
|
|||
|
}
|
|||
|
|
|||
|
random(): number {
|
|||
|
this.step();
|
|||
|
return this.x/this.m;
|
|||
|
}
|
|||
|
|
|||
|
reset() {
|
|||
|
this.x = (new Date()).getTime() % this.m;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
export const BadRNG: RNG0 = new RNG0();
|
|||
|
|
|||
|
/*
|
|||
|
* Wichmann–Hill PRNG
|
|||
|
* The period is 6e12.
|
|||
|
*/
|
|||
|
export class WHRNG implements RNG {
|
|||
|
s1: number = 0;
|
|||
|
s2: number = 0;
|
|||
|
s3: number = 0;
|
|||
|
|
|||
|
constructor(totalPlaytime: number) {
|
|||
|
// This one is seeded by the players total play time.
|
|||
|
const v: number = (totalPlaytime/1000)%30000;
|
|||
|
this.s1 = v;
|
|||
|
this.s2 = v;
|
|||
|
this.s3 = v;
|
|||
|
}
|
|||
|
|
|||
|
step() {
|
|||
|
this.s1 = (171 * this.s1) % 30269;
|
|||
|
this.s2 = (172 * this.s2) % 30307;
|
|||
|
this.s3 = (170 * this.s3) % 30323;
|
|||
|
}
|
|||
|
|
|||
|
random(): number {
|
|||
|
this.step();
|
|||
|
return (this.s1/30269.0 + this.s2/30307.0 + this.s3/30323.0)%1.0;
|
|||
|
}
|
|||
|
}
|