定制 saki/fraction 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

saki/fraction

最新稳定版本:3.0.0

Composer 安装命令:

composer require saki/fraction

包简介

README 文档

README

Latest Stable Version Push codecov License

Install

For PHP 8.4:

composer require saki/fraction: "3.*"

For PHP 8.3 and 8.2:

composer require saki/fraction: "2.*"

This library requires the BCMath extension.

Description

This is a PHP library that handles fractions using BcMath\Number. The class is final and readonly, so an immutable object.

Create a object

The constructor is:

// __construct(Number|int|string $numerator, Number|int|string $denominator = 1)

use Saki\Fraction;

$fraction = new Fraction(1, 2); // 1/2
$fraction = new Fraction('0.5', -1); // -1/2
$fraction = new Fraction('-3'); // -3/1
$fraction = new Fraction('-2', '-4'); // 1/2

You can also create objects from strings representing fractions like "1/2".

$fraction = Saki\Fraction::createFromFractionString('1/2');

Methods

The available methods are:

  • add(Fraction|Number|int|string $num): Fraction
  • sub(Fraction|Number|int|string $num): Fraction
  • mul(Fraction|Number|int|string $num): Fraction
  • div(Fraction|Number|int|string $num): Fraction
  • mod(Fraction|Number|int|string $num): Fraction
  • divmod(Fraction|Number|int|string $num): Fraction[]
  • pow(Number|int|string $num): Fraction
  • compare(Fraction|Number|int|string $num): int
  • toNumber(): Number

Additionally, this class is Stringable and supports serialization.

Convert to BcMath\Number

When converting a Fraction to BcMath\Number, for example, a value like "1/10000000000" was too small and could end up as "0". Therefore, in this case, the numerator is 1 digit and the denominator is 11 digits, so the division is executed with BcMath\Number::scale extended by the 10 digits of the difference. Division of BcMath\Number automatically extends BcMath\Number::scale by up to another 10 digits from this state, so you can obtain sufficient precision.

e.g.

// Example of indivisible division

use Saki\Fraction;

$fraction = new Fraction(1, 30000);
var_dump($fraction->toNumber());

output:

object(BcMath\Number)#2 (2) {
  ["value"]=>
  string(16) "0.00003333333333"
  ["scale"]=>
  int(14)
}

Cast to string

When cast to string, it becomes a string representing a fraction, such as "-3/10".

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-12-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固