承接 iamvar/math 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

iamvar/math

最新稳定版本:v1.0.1

Composer 安装命令:

composer require iamvar/math

包简介

Calculate expression, using bcmath functions.

关键字:

README 文档

README

Every developer knows: float is not the best choice for precise calculation.

php > var_dump(1.2 * 3);
float(3.5999999999999996)

We have bcmath, you say.

Yes, but calculating small expression, like ($a + $b * $c - $d) / $e becomes as heavy as

<?php

$result = bcdiv(bcsub(bcadd($a, bcmul($b, $c)), $d), $e);

That is where this tool becomes useful:

With registered helpers functions, you can just use

<?php

$result = calc("$a + $b * $c - $d");

That's it!

All calculations behind the scene use bcmath functions.

php > var_dump(calc("1.2 * 3"));
string("3.6")

php > isTrue('1 < 2 < 3'); // true

Helper Functions

To register global helper functions, just update your composer.json with

"autoload": {
    "files": [
        "vendor/iamvar/math/src/helpers.php"
    ]
},

Examples

<?php

$a = 0.1E1;
$b = 2e-7;
$c = 2;
calc("$a + $b * $c"); // 1.0000004
calc("1.69 ^ (1/2) + (0.1 - 0.25) * 2"); // 1
calc('min(09.12, abs(-10.01))'); // 9.12
calc('max(1, 1.000000000000001)'); // 1.000000000000001

isTrue('(1 + 0.2) * 3 == 3.6 + (1-9) * 0"); // true
isTrue('1 < 2 < 3'); // true
isTrue('1 < 2 > 3'); // false

bcscale

All calculations are performed with scale, taken by default from bcscale().
Do not forget to set required bcscale in your bootstrap file.

<?php

bcscale(25);

Usage

By default calc function cuts trailing zeroes,
e.g with scale = 4 calc("0.1 + 0.9") will return "1"

If you want to save scale, add second parameter as false
calc("0.1 + 0.9", false) will return "1.0000"

License

Math is licensed under the MIT License.

统计信息

  • 总下载量: 6
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-05-29