本文整理匯總了TypeScript中random-js.engines類的典型用法代碼示例。如果您正苦於以下問題:TypeScript engines類的具體用法?TypeScript engines怎麽用?TypeScript engines使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了engines類的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: generateRandomNumberAndDisplay
function generateRandomNumberAndDisplay() {
var minNum = minimumNumber < maximumNumber ? minimumNumber : maximumNumber;
var maxNum = minimumNumber > maximumNumber ? minimumNumber : maximumNumber;
random = random || new Random(Random.engines.mt19937().autoSeed());
var value = random.integer(minNum, maxNum);
displayResult(value.toString());
}
示例2: constructor
constructor(config: RandomConfig) {
this.engine = randomjs.engines.mt19937();
if (typeof config.seed != 'undefined')
this.engine.seed(config.seed);
else
this.engine.autoSeed();
}
示例3: Date
/**
* Options specifies arguments to the checker.
*
* @property tests The max number of tests
* @property engine A random-js engine
*/
export interface CheckOptions {
tests: number;
engine: Random.MT19937;
seed: number,
locale: string;
format: boolean
}
/**
* Create default random engine.
*/
const seed = process.env.SEED || new Date().getTime();
const engine = Random.engines.mt19937()
engine.seed(seed);
/**
* The default check options.
*/
export const stdOpts: CheckOptions = {
tests : 50,
engine : engine,
seed: seed,
locale : 'en',
format: true
};
示例4: integer
import * as Random from "random-js";
const engine = Random.engines.mt19937().autoSeed();
/**
* Randomly generate an integer, within the inclusive bounds.
* @param min The smallest possible integer.
* @param max The largest possible integer.
*/
export function integer(min: number, max: number): number {
return Random.integer(min, max)(engine);
}
/**
* Return a random boolean value
*/
export function bool(): boolean;
/**
* Return a random boolean value with a percentage change of truth
* @param percentage 0-1
*/
// tslint:disable-next-line:unified-signatures
export function bool(percentage: number): boolean;
/**
* Return a random value that is true numerator times out of denominator
*/
export function bool(numerator?: number, denominator?: number): boolean {
// any below because of bad TS definitions in the @types package.
return Random.bool(numerator as any, denominator as any)(engine);
}
示例5: Random
import { Define } from './define';
import * as Random from 'random-js';
export module Util {
export let rand: Random = new Random(Random.engines.mt19937().autoSeed());
export function dealTegomas(): string[] {
let komaCircle = Define.komaCircle.split('');
shuffle(komaCircle);
let tegomas = new Array<string>();
for (let c of cut(komaCircle, 8)) {
tegomas.push(c.join(''));
}
return tegomas;
}
export function cut<T>(array: Array<T>, len: number): Array<Array<T>> {
let ret = new Array<Array<T>>();
const cutCount = array.length / len;
for (let i = 0; i < cutCount; i = (i+1)|0) {
ret.push(array.slice(i * len, (i + 1) * len));
}
return ret;
}
/** shuffle array - with Fisher-Yates algorithm */
export function shuffle<T>(array: Array<T>) {
let n = array.length;
for (let i = n - 1; i > 0; i=i-1) {
let j = rand.integer(0, i);
let tmp = array[i];
示例6: generateEntitiesForScenario
function generateEntitiesForScenario(
input: Input,
checkFitness: FitnessFunction,
actor: string,
initialPopulation: Entity[],
seed: number
): EntityWithFitness[] {
const populationSize = 256;
const maxGenerations = 10;
let generation = 0;
const bestSolutions: BestEntities = { [actor]: [] };
const random = new Random(Random.engines.mt19937().seed(seed));
let population: Entity[] = [];
while (generation < maxGenerations) {
if (population.length < populationSize) {
population.push(
...generateEntities(
random,
populationSize - population.length,
input.keys
)
);
}
population.push(...initialPopulation);
const populationWithFitnesses = population.map(entity =>
checkFitness(input, entity, actor)
);
const populationSortedByFitness = populationWithFitnesses.sort(
(a, b) => a.fitness - b.fitness
);
if (populationSortedByFitness[0].fitness < 20) {
console.log("early return!", populationSortedByFitness[0].fitness / 1000);
return populationSortedByFitness.slice(0, 10);
}
bestSolutions[actor] = bestSolutions[actor]
.concat(populationSortedByFitness)
.sort((a, b) => a.fitness - b.fitness)
.slice(0, 100);
console.log(
generation,
(bestSolutions[actor][0] || { fitness: Infinity }).fitness / 1000
);
const children = breed(
populationSortedByFitness
.slice(0, 32)
.concat(bestSolutions[actor].slice(0, 8)),
populationSize / 2,
random
);
while (population.length > 0) {
population.pop();
}
population.push(...children);
population = population.map(entity => mutate(input.keys, random, entity));
generation += 1;
}
return bestSolutions[actor].slice(0, 10);
}
示例7: generateEntity
export function generateEntity(
seed: number,
keys: string[],
depth = 0
): Entity {
const random = new Random(Random.engines.mt19937().seed(seed));
const isLeaf = depth > 1 || random.bool();
if (isLeaf) {
const possibleCommands = [
"move",
"setVelocity",
"multiplyVelocity",
"noop"
];
const command = random.pick(possibleCommands);
if (command === "noop") {
return {
type: command,
id: seed.toString()
};
}
if (command === "move") {
const direction = random.pick([
"up",
"right",
"left",
"down"
]) as Direction;
const amount = random.integer(0, 20) / 10;
return {
type: command,
id: seed.toString(),
direction,
amount
};
}
if (command === "setVelocity") {
let velocity;
if (random.bool(0.5)) {
// cardinal direction
const scalar = random.integer(0, 20) / 20;
velocity = random.pick([
{ x: 0, y: -scalar },
{ x: scalar, y: 0 },
{ x: -scalar, y: 0 },
{ x: 0, y: scalar }
]);
} else {
velocity = {
x: random.integer(-20, 20) / 20,
y: random.integer(-20, 20) / 20
};
}
return {
type: command,
id: seed.toString(),
velocity
};
}
if (command === "multiplyVelocity") {
const scalar = random.integer(-20, 20) / 20;
return {
type: command,
id: seed.toString(),
scalar
};
}
throw new Error("Unimplemented command");
} else {
const possibleCommands = [
"sequence",
"inputConditional",
"collisionConditional"
];
if (depth === 0) {
possibleCommands.push("onCreate");
}
// TODO - fix definitely typed definition
const command = (random as any).pick(possibleCommands) as any;
if (command === "collisionConditional") {
return {
type: command,
id: seed.toString(),
children: makeChildren(random, 1, keys, depth)
};
//.........這裏部分代碼省略.........
示例8: makeFitnessChecker
Object.keys(input.actors).forEach(actor => {
const scenariosForActor = input.scenarios.filter(
scenario => actor in scenario.actors
);
if (scenariosForActor.length === 1) {
console.log("Generating for", actor);
const scenario = scenariosForActor[0];
if (!(actor in scenario.actors)) {
return;
}
const fitness = makeFitnessChecker([scenario]);
let previousSolutions: Entity[] = [];
if (previousOutput && previousOutput.entities[actor]) {
previousSolutions = [previousOutput.entities[actor]];
}
const bestSolutions = generateEntitiesForScenario(
input,
fitness,
actor,
previousSolutions,
seed
);
console.log("size before tumbler", findSize(bestSolutions[0].entity));
results.entities[actor] = tumbler(
bestSolutions[0].entity,
[scenario],
input,
actor
);
console.log("size after tumbler", findSize(results.entities[actor]));
setErrorLevel(results.errorLevels, actor, {
[scenario.id]: bestSolutions[0].fitness
});
results.positions[actor] = bestSolutions[0].positions;
} else {
console.log("Generating for", actor);
const random = new Random(Random.engines.mt19937().seed(seed));
let previousSolutions: Entity[] = [];
if (previousOutput && previousOutput.entities[actor]) {
previousSolutions = [previousOutput.entities[actor]];
}
const entitiesForEachScenario = flatten(
scenariosForActor.map(
scenario =>
console.log("scenario:", scenario.name) ||
generateEntitiesForScenario(
input,
makeFitnessChecker([scenario]),
actor,
previousSolutions,
random.integer((-2) ** 53, 2 ** 53)
)
)
);
console.log("final solution:", previousSolutions, previousOutput);
const solutions = generateEntitiesForScenario(
input,
makeFitnessChecker(scenariosForActor),
actor,
previousSolutions.concat(
entitiesForEachScenario.map(
entityWithFitness => entityWithFitness.entity
)
),
random.integer((-2) ** 53, 2 ** 53)
);
console.log("size before tumbler", findSize(solutions[0].entity));
results.entities[actor] = tumbler(
solutions[0].entity,
scenariosForActor,
input,
actor
);
console.log("size after tumbler", findSize(results.entities[actor]));
setErrorLevel(results.errorLevels, actor, solutions[0].errorLevels);
results.positions[actor] = solutions[0].positions;
}
});
示例9: chooseMutation
function chooseMutation(
keys: string[],
seed: number,
entity: Entity
): Mutation {
const random = new Random(Random.engines.mt19937().seed(seed));
if (random.bool(0.5)) {
return {
id: seed.toString(),
type: "ConvertToNoopMutation"
};
}
if (entity.type === "sequence") {
const types = [
"NewEntityMutation",
"RemovalMutation",
"SwitchMutation",
"ReplaceMutation"
];
const mutationType = random.pick(types);
if (mutationType === "NewEntityMutation") {
const newEntity = generateEntity(
random.integer(MIN_SEED, MAX_SEED),
keys,
0
);
return {
id: seed.toString(),
type: mutationType,
newEntity,
spliceIndex: random.integer(0, (entity as Branch).children.length)
};
}
if (mutationType === "ReplaceMutation") {
const newEntity = generateEntity(
random.integer(MIN_SEED, MAX_SEED),
keys,
0
);
return {
id: seed.toString(),
type: mutationType,
newEntity,
spliceIndex: random.integer(0, (entity as Branch).children.length - 1)
};
}
if (mutationType === "RemovalMutation") {
return {
id: seed.toString(),
type: mutationType,
removeIndex: random.integer(0, entity.children.length - 1)
};
}
if (mutationType === "SwitchMutation") {
return {
id: seed.toString(),
type: mutationType,
fromIndex: random.integer(0, entity.children.length - 1),
toIndex: random.integer(0, entity.children.length - 1)
};
}
}
if (entity.type === "onCreate") {
const newEntity = generateEntity(
random.integer(MIN_SEED, MAX_SEED),
keys,
0
);
return {
id: seed.toString(),
type: "ReplaceMutation",
newEntity,
spliceIndex: random.pick([0, 1])
};
}
if (entity.type === "collisionConditional") {
const newEntity = generateEntity(
random.integer(MIN_SEED, MAX_SEED),
keys,
0
);
return {
id: seed.toString(),
type: "ReplaceMutation",
newEntity,
spliceIndex: random.pick([0, 1])
};
//.........這裏部分代碼省略.........