當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript engines.mt19937方法代碼示例

本文整理匯總了TypeScript中random-js.engines.mt19937方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript engines.mt19937方法的具體用法?TypeScript engines.mt19937怎麽用?TypeScript engines.mt19937使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在random-js.engines的用法示例。


在下文中一共展示了engines.mt19937方法的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());
	}
開發者ID:tkorcak,項目名稱:createidsvscode,代碼行數:7,代碼來源:extension.ts

示例2: constructor

 constructor(config: RandomConfig) {
     this.engine = randomjs.engines.mt19937();
     if (typeof config.seed != 'undefined')
         this.engine.seed(config.seed);
     else
         this.engine.autoSeed();
 }
開發者ID:sbj42,項目名稱:sbj42.github.io,代碼行數:7,代碼來源:random.ts

示例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
};
開發者ID:hychen,項目名稱:hycheck,代碼行數:31,代碼來源:constants.ts

示例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);
}
開發者ID:MPennanti,項目名稱:HungryDragon,代碼行數:30,代碼來源:random.ts

示例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];
開發者ID:Goita,項目名稱:goita-core-js,代碼行數:31,代碼來源:util.ts

示例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);
}
開發者ID:helix-pi,項目名稱:helix-pi,代碼行數:75,代碼來源:index.ts

示例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)
      };
//.........這裏部分代碼省略.........
開發者ID:helix-pi,項目名稱:helix-pi,代碼行數:101,代碼來源:index.ts

示例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;
    }
  });
開發者ID:helix-pi,項目名稱:helix-pi,代碼行數:90,代碼來源:index.ts

示例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])
    };
//.........這裏部分代碼省略.........
開發者ID:helix-pi,項目名稱:helix-pi,代碼行數:101,代碼來源:index.ts


注:本文中的random-js.engines.mt19937方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。