当前位置: 首页 > news >正文

Aimless.js API完全参考手册:所有函数用法和参数详解

Aimless.js API完全参考手册:所有函数用法和参数详解

【免费下载链接】aimless.jsThe missing JavaScript randomness library.项目地址: https://gitcode.com/gh_mirrors/ai/aimless.js

Aimless.js是JavaScript中缺失的随机性库,提供了丰富的随机数生成函数,满足各种随机数据需求。本文将详细介绍Aimless.js的所有API函数,帮助开发者快速掌握这个强大的随机数工具库。

核心函数概览

Aimless.js的核心功能通过src/aimless.ts文件统一导出,主要包含以下几类随机数生成函数:

  • 基础随机值:bool,char,sign
  • 数值范围:intRange,floatRange
  • 概率分布:normalDist,exponentialDist,customDist
  • 序列生成:sequence,intSequence,uniqFuncSequence
  • 特殊功能:oneOf,weighted,uuid

基础随机值生成

bool() - 随机布尔值

功能:生成随机布尔值(true或false)

参数

  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { bool } from 'aimless.js'; // 生成随机布尔值 const randomBool = bool(); console.log(randomBool); // 输出: true 或 false

实现源码:src/bool.ts

char() - 随机字符

功能:生成随机字符,支持自定义字符集

参数

  • chars: 可选,字符集字符串,默认为大小写字母和数字
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { char } from 'aimless.js'; // 生成随机字母数字字符 const randomChar = char(); // 生成随机小写字母 const lowercaseChar = char('abcdefghijklmnopqrstuvwxyz');

数值范围生成

intRange() - 整数范围随机数

功能:生成指定范围内的随机整数(包含边界值)

参数

  • min: 必需,最小值
  • max: 必需,最大值
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { intRange } from 'aimless.js'; // 生成1-10之间的随机整数 const randomInt = intRange(1, 10); console.log(randomInt); // 输出: 3 (示例)

实现源码:src/int-range.ts

floatRange() - 浮点数范围随机数

功能:生成指定范围内的随机浮点数

参数

  • min: 必需,最小值
  • max: 必需,最大值
  • precision: 可选,小数位数,默认为2
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { floatRange } from 'aimless.js'; // 生成0-1之间的随机浮点数 const randomFloat = floatRange(0, 1); // 生成10-20之间保留4位小数的随机浮点数 const preciseFloat = floatRange(10, 20, 4);

概率分布生成

normalDist() - 正态分布随机数

功能:生成符合正态分布的随机数

参数

  • mean: 可选,均值,默认为0
  • stddev: 可选,标准差,默认为1
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { normalDist } from 'aimless.js'; // 生成标准正态分布随机数 const normalValue = normalDist(); // 生成均值为50,标准差为10的正态分布随机数 const customNormal = normalDist(50, 10);

exponentialDist() - 指数分布随机数

功能:生成符合指数分布的随机数

参数

  • lambda: 可选,率参数,默认为1
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { exponentialDist } from 'aimless.js'; // 生成率参数为0.5的指数分布随机数 const expValue = exponentialDist(0.5);

序列与集合操作

sequence() - 随机序列生成

功能:生成包含随机值的序列数组

参数

  • length: 必需,序列长度
  • generator: 必需,生成每个元素的函数
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { sequence, intRange } from 'aimless.js'; // 生成包含5个1-100随机整数的序列 const randomSequence = sequence(5, () => intRange(1, 100));

oneOf() - 从数组中随机选择

功能:从数组中随机选择一个元素

参数

  • array: 必需,源数组
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { oneOf } from 'aimless.js'; const fruits = ['apple', 'banana', 'orange', 'grape']; // 随机选择一个水果 const randomFruit = oneOf(fruits);

weighted() - 加权随机选择

功能:根据权重从数组中随机选择元素

参数

  • options: 必需,包含value和weight属性的对象数组
  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { weighted } from 'aimless.js'; const options = [ { value: 'A', weight: 1 }, { value: 'B', weight: 2 }, { value: 'C', weight: 3 } ]; // 按权重随机选择(C被选中的概率最高) const selected = weighted(options);

特殊功能

uuid() - 生成UUID

功能:生成符合RFC4122标准的UUID v4

参数

  • engine: 可选,随机数引擎实例,默认为defaultEngine

示例

import { uuid } from 'aimless.js'; // 生成随机UUID const id = uuid(); console.log(id); // 输出: "a1b2c3d4-5678-90ef-ghij-klmnopqrstuv"

seedFunc() - 种子函数生成

功能:创建可复现的随机数生成函数

参数

  • seed: 必需,种子值

示例

import { seedFunc, intRange } from 'aimless.js'; // 创建种子随机数引擎 const seededEngine = seedFunc(12345); // 使用种子引擎生成可复现的随机数 const firstRun = intRange(1, 100, seededEngine); // 重置引擎后会得到相同的结果 seededEngine.reset(); const secondRun = intRange(1, 100, seededEngine); console.log(firstRun === secondRun); // 输出: true

带引擎的函数变体

Aimless.js中的大多数函数都提供了WithEngine后缀的变体(如boolWithEngineintRangeWithEngine),这些函数允许你创建绑定到特定引擎的生成器函数:

示例

import { intRangeWithEngine, seedFunc } from 'aimless.js'; // 创建绑定到特定种子引擎的整数生成器 const seededIntRange = intRangeWithEngine(seedFunc(9876)); // 后续调用无需再指定引擎 const number1 = seededIntRange(1, 10); const number2 = seededIntRange(1, 10);

安装与使用

要开始使用Aimless.js,首先需要克隆仓库:

git clone https://gitcode.com/gh_mirrors/ai/aimless.js cd aimless.js npm install

然后在你的项目中导入所需的函数:

import { intRange, normalDist, oneOf } from 'aimless.js';

总结

Aimless.js提供了全面的随机数生成解决方案,从简单的布尔值到复杂的概率分布,从基础的数值生成到高级的序列操作。通过本文介绍的API,你可以轻松实现各种随机数据需求。无论是游戏开发、数据分析还是模拟测试,Aimless.js都能成为你可靠的随机数工具库。

更多详细信息和高级用法,请参考项目的测试文件:test/index.js。

【免费下载链接】aimless.jsThe missing JavaScript randomness library.项目地址: https://gitcode.com/gh_mirrors/ai/aimless.js

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

http://www.rkmt.cn/news/1546515.html

相关文章:

  • 5分钟上手deep-fonts:零基础也能玩转AI字体生成
  • PDF 批量转 PNG 工具 高清无水印本地批量文档转换
  • 西安蝴蝶扣性价比怎么样,2026实力测评避坑指南 - 工业品牌热点
  • 2026年,行业内热门磁滞测功机销售厂家,哪家才是靠谱之选?
  • 庄荣华法律服务机构价格,性价比高的选择 - mypinpai
  • 植物大战僵尸杂交版手机版下载v0.2 2026最新
  • E1S社区贡献指南:如何参与这个开源项目的开发和改进
  • 江苏省省级企业技术中心认定及评价流程详解
  • RAG 还是长上下文(Long Context)?2026 年检索增强到底该怎么选
  • 提升WeatherBench预测精度:从线性回归到深度学习的进阶技巧
  • [](https://blog.csdn.net/bdfcfff77fa/article/details/161459626?spm=1001.2014.3001.5501)零基础,能转行做网络
  • Invoify:如何在5分钟内创建专业发票?Next.js驱动的现代化解决方案
  • Dramatron:大型语言模型驱动的剧本协同创作技术架构解析
  • 第7篇:《连接器Layout防呆设计:定位孔+方向标记+引脚编号丝印》
  • ML模型服务稳定性工程:从Triton弹性部署到业务熔断实践
  • 题解:AcWing 395 冗余路径
  • RPA与pytest-metadata集成:构建可观测的自动化测试框架
  • 【毕业设计】基于 Spring Boot 的政务事项申报审批管理系统的设计与实现 基于 Spring Boot 的基层电子政务运维管理平台(源码+文档+远程调试,全bao定制等)
  • 登报遗失声明一般多少钱?登报遗失声明如何办理呢?
  • 揭秘无锡永辉大推拉雨棚,遮阳效果与满意度 - myqiye
  • 终极Windows Defender修复指南:no-defender工具的决策流程图解法
  • Bedrock Guardrails 新 API:不用创建资源,直接给 Agent 每一步加安全检查
  • Windows界面定制深度解析:ExplorerPatcher技术实现与专业级应用指南
  • Windows 7系统激活全解析:从授权原理到合规操作指南
  • AI代理自发卡特尔现象:隐式协调与目标漂移的工程实证
  • CAST模型:程序化视频检索的技术突破与应用
  • 2026年英文论文降AIGC指南:从94%压到7%的实操方法与4款工具盘点 - 降AI实验室
  • Bedrock Guardrails 新 API 实战:无需创建资源,给 Agent 每一步加安全检查
  • 抖音视频下载神器:10分钟掌握无水印批量下载技巧
  • 抖音视频下载终极指南:10分钟掌握无水印批量下载技巧