写点什么

Math.js:多用途的 JavaScript 数学库

  • 2014-01-26
  • 本文字数:1393 字

    阅读完需:约 5 分钟

Math.js 是一款开源的 JavaScript 和 Node.js 数学库,用于处理数字、大数、复数、单位和矩阵。它还有一个灵活的表达式解析器。为了解更多信息,InfoQ 联系了该项目的创始人 Jos De Jong。

Jos 解释了项目背后的动机——

对于 JavaScript,我们有很好的库来处理矩阵、复数和统计等计算。欠缺的是用于高级数学计算的集成解决方案。大多数现有的库支持链式 API,它们使用起来很直观,但只接受库本身已知的数据类型。因此,整合时存在的问题 是:矩阵库不能处理复数,反之亦然,你无法将它们合并起来。math.js 的 API 和 JavaScript 的 Math 对象和内置操作符的 API 是相同的,都是支持各种输入类型的静态函数。 Math.js 对该 API 进行了扩展,为高级数据类型、函数和常数提供了支持。

我希望 math.js 能使应用程序开发中的数学处理变得简单,并且更为有趣,希望还能帮助弥合开发者的世界与学术世界直接的鸿沟。

Math.js 有三种使用方式——

  1. 用静态函数和常数(就像 JavaScript 的 Math 对象) ```

math.add(2, 3)math.add(2, 3); // 5
math.sqrt(-4); // 2i
math.pow([[-1, 2], [3, 1]], 2); // [[7, 0], [0, 7]]

复制代码
2. 对字符串表达式进行求值运算 ```
math.eval('1.2 * (2 + 4.5)'); //7.8
math.eval('5.08 cm to inch'); //2 inch
  1. 使用链式操作 ```

math.select(3)
.add(4)
.multiply(2)
.done(); //14

复制代码
[math.js 网站有几个示例,文档](http://mathjs.org/) 中也有。
Jos 希望在几个月内发布第一个稳定版本 1.0。
> 版本 1.0 还剩下的工作是写一个参考文档,代码的单元测试覆盖率达到 100%,解决 一些不完善的地方。
到版本 1.0 发布时,API 也将稳定下来,之后我们的焦点可能会转移到优化上。Jos 提出了可能会带来潜在性能改进的几个方向,如使用类型化数组、并行化和 <a>asm.js</a>
<a>Jos</a> 为什么选择了 JavaScript,而没有选择像已有诸如 NumPi/SCIPI 等库的 Python 这样的语言,原因是——
> 最近几年,我们已看到了云计算和 Web 应用程序的发展浪潮,而且我自己也完全融入其中了。浏览器和 JavaScript 引擎也正在变得越来越快。几年前,我们就可以使用 [node.js](http://nodejs.org/) 运行 JavaScript 服务器端。这开拓了许多新的可能性,并导致了 JavaScript 的生态系统及其受欢迎程度的 [爆炸性增长](http://resin.io/happy-18th-birthday-javascript/)。看起来 JavaScript 正在成为应用最普遍的语言。尽管 JavaScript 远不完美,但我非常喜欢 JavaScript 及其社区。
目前已经有几个使用 math.js 的最终用户应用。Jos 自己的项目 [mathnotepad](http://mathnotepad.com/) 也是基于 math.js 的,目前还处于早期开发阶段。[numerics](http://numerics.info/) 这款流行的计算器项目也用到了 Math.js。
如果想使用 Math.js,可以查看 [文档](https://github.com/josdejong/mathjs/blob/master/docs/getting_started.md)。
** 查看英文原文:**[Math.js: Versatile Math Library For JavaScript](http://www.infoq.com/news/2014/01/mathjs)
- - - - - -
感谢 [臧秀涛](http://www.infoq.com/cn/author/%E8%87%A7%E7%A7%80%E6%B6%9B) 对本文的审校。
给 InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 [editors@cn.infoq.com](mailto:editors@cn.infoq.com)。也欢迎大家通过新浪微博([@InfoQ](http://www.weibo.com/infoqchina))或者腾讯微博([@InfoQ](http://t.qq.com/infoqchina))关注我们,并与我们的编辑和其他读者朋友交流。
2014-01-26 08:2611348

评论

发布
暂无评论
发现更多内容

Omnissa Dynamic Environment Manager 2412 - 个性化动态 Windows 桌面环境管理

sysin

horizon

全新市场阶段, Plume 生态不断壮大的 RWAfi 版图

股市老人

云服务器Flexus X实例,Docker集成搭建DVWA靶场

平平无奇爱好科技

Flexus云服务器X实例安装Docker管理工具Portainer

平平无奇爱好科技

Flexus X实例安装H5ai目录列表程序

平平无奇爱好科技

Flexus云服务器X实例实践:部署ServerBee监控工具

平平无奇爱好科技

深入理解 ECMAScript 2024 新特性:Promise.withResolvers

李游Leo

ecmascript 前端

【这就是ChatGPT】了解原理让大语言模型AI成为你的打工人—慢慢学AI006

AI决策者洞察

#人工智能 Prompt

ROS通信机制详解:Service与Parameter Server的工作原理与应用场景

芯动大师

ROS TOPIC sevice

云服务器Flexus X实例,Docker集成搭建搭建Flink

平平无奇爱好科技

使用华为云Flexus云服务器X搭建部署茶叶商城小程序uniapp

平平无奇爱好科技

Tomcat保姆级安装教程

平平无奇爱好科技

Flexus云服务器X实例部署宝塔面板

平平无奇爱好科技

懒猫微服移植 DataEase 应用

玄兴梦影

NAS DataEase 懒猫微服应用移植 懒猫微服

万字长文,带你进入“具身智能”世界!

机器人头条

科技 大模型 人形机器人 具身智能

云服务器Flexus X实例,Docker集成搭建YesPlayMusic网易云音乐播放器

平平无奇爱好科技

Flexus云服务器X实例实践:部署Alist文件列表程序

平平无奇爱好科技

8款客户跟进管理系统测评:哪个更适合你的企业?

易成研发中心

客户关系管理 客户关系管理软件 客户跟进系统

企业怎么做知识管理

易成研发中心

知识管理 知识管理系统 知识管理软件

如何轻松部署“未知表白墙”项目:华为云Flexus X实例指南

平平无奇爱好科技

云服务器Flexus X实例,Docker集成搭建MinIO

平平无奇爱好科技

华为云Flexus云服务器X实例之openEuler系统部署Beszel轻量级服务器监控系统

平平无奇爱好科技

Flexus云服务器X实例部署Docker管理仪表板DweebUI

平平无奇爱好科技

Flexus 云服务器 X 实例实践探索:部署slash书签应用

平平无奇爱好科技

Math.js:多用途的JavaScript数学库_JavaScript_Roopesh Shenoy_InfoQ精选文章