PHP에서 고정밀 계산을 처리 할 때 일부 특수 기능 라이브러리에 의존 할 수 있습니다. BCMath는 그 중 하나입니다. BCMATH는 각각 고정밀 곱셈 및 디비전 계산에 사용되는 BCMUL () 및 BCDIV ()를 포함하여 고정밀 부동산 지점 및 정수 작업을 처리하기위한 여러 기능을 제공합니다.
이 기사에서는 BCMul () 및 bcdiv ()를 사용하여 실제 사례를 통해 고정밀 계산을 달성하는 방법을 보여줍니다. 기본 사용 및 장점을 이해하는 것은 개발자 정확도 요구 사항을 개선하는 데 중요한 단계입니다.
PHP의 기본 플로팅 포인트 번호 유형 ( Float )은 대부분의 숫자 작업을 처리 할 수 있지만 매우 크거나 작은 값에 직면 할 때 정확도 손실이 발생할 수 있습니다. 고정화 작업의 결과를 보장하기 위해 BCMATH 확장은 임의의 정밀도에 대한 수치 계산 지원을 제공하므로 기존 데이터 유형에 의해 제한되지 않고 정확한 계산을 수행 할 수 있습니다.
BCMUL () 은 BCMATH 확장의 곱셈 함수이며, 이는 두 개의 고 차정 숫자를 곱하는 데 사용됩니다. 기존의 곱셈 작업과 달리 BCMUL ()을 사용하면 정확도가 불충분하여 결과 오류를 방지하기 위해 계산의 정확도를 설정할 수 있습니다.
<span><span><span class="hljs-title function_ invoke__">bcmul</span></span><span>(</span><span><span class="hljs-keyword">string</span></span><span> </span><span><span class="hljs-variable">$left_operand</span></span><span>, </span><span><span class="hljs-keyword">string</span></span><span> </span><span><span class="hljs-variable">$right_operand</span></span><span>, </span><span><span class="hljs-keyword">int</span></span><span> </span><span><span class="hljs-variable">$scale</span></span><span> = </span><span><span class="hljs-number">0</span></span><span>): </span><span><span class="hljs-keyword">string</span></span><span>
</span></span>
$ left_operand : 첫 번째 피연산자는 문자열로 전달되었습니다.
$ right_operand : 두 번째 피연산자도 문자열로 전달되었습니다.
$ 스케일 : 선택적 매개 변수, 소수점 후 정확도를 지정합니다.
<span><span><span class="hljs-variable">$num1</span></span><span> = </span><span><span class="hljs-string">'123.456789'</span></span><span>;
</span><span><span class="hljs-variable">$num2</span></span><span> = </span><span><span class="hljs-string">'987.654321'</span></span><span>;
</span><span><span class="hljs-variable">$result</span></span><span> = </span><span><span class="hljs-title function_ invoke__">bcmul</span></span><span>(</span><span><span class="hljs-variable">$num1</span></span><span>, </span><span><span class="hljs-variable">$num2</span></span><span>, </span><span><span class="hljs-number">6</span></span><span>); </span><span><span class="hljs-comment">// 곱셈 결과가 보존됩니다6소수</span></span><span>
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-variable">$result</span></span><span>; </span><span><span class="hljs-comment">// 산출 121931.439820</span></span><span>
</span></span>
BCDIV () 는 BCMATH 확장의 분할 함수이며, 두 가지 고 차정 숫자에 대한 분할 계산을 수행하는 데 사용됩니다. 또한 결과의 정확성을 보장하기 위해 계산 정확도 설정을 지원합니다.
<span><span><span class="hljs-title function_ invoke__">bcdiv</span></span><span>(</span><span><span class="hljs-keyword">string</span></span><span> </span><span><span class="hljs-variable">$dividend</span></span><span>, </span><span><span class="hljs-keyword">string</span></span><span> </span><span><span class="hljs-variable">$divisor</span></span><span>, </span><span><span class="hljs-keyword">int</span></span><span> </span><span><span class="hljs-variable">$scale</span></span><span> = </span><span><span class="hljs-number">0</span></span><span>): </span><span><span class="hljs-keyword">string</span></span><span>
</span></span>
$ 배당 : 배당금, 문자열로 통과되었습니다.
$ divisor : divisor, 또한 문자열을 전달합니다.
$ 스케일 : 선택적 매개 변수, 소수점 후 정확도를 지정합니다.
<span><span><span class="hljs-variable">$num1</span></span><span> = </span><span><span class="hljs-string">'123.456789'</span></span><span>;
</span><span><span class="hljs-variable">$num2</span></span><span> = </span><span><span class="hljs-string">'9.87654321'</span></span><span>;
</span><span><span class="hljs-variable">$result</span></span><span> = </span><span><span class="hljs-title function_ invoke__">bcdiv</span></span><span>(</span><span><span class="hljs-variable">$num1</span></span><span>, </span><span><span class="hljs-variable">$num2</span></span><span>, </span><span><span class="hljs-number">6</span></span><span>); </span><span><span class="hljs-comment">// 분할 결과가 유지됩니다6소수</span></span><span>
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-variable">$result</span></span><span>; </span><span><span class="hljs-comment">// 산출 12.500000</span></span><span>
</span></span>
실제 개발에서 특히 금융 분야 또는 전자 상거래 플랫폼에서 고정밀 가격 계산이 종종 필요합니다. 제품의 총 가격, 할인 된 가격 및 세금을 계산해야한다고 가정하십시오. 플로팅 계산 정확도로 인한 금액 오류를 피하기 위해 BCMul () 및 bcdiv ()를 사용하여 이러한 작업을 처리 할 수 있습니다.
제품의 단가 : 99.99
수량 : 10
할인 : 0.85 (85% 할인)
세율 : 0.1 (10% 세율)
우리는 항목의 총 가격, 할인 된 가격 및 세금 인상 후 최종 가격을 계산합니다.
<span><span><span class="hljs-comment">// 제품 단가 및 수량</span></span><span>
</span><span><span class="hljs-variable">$price</span></span><span> = </span><span><span class="hljs-string">'99.99'</span></span><span>;
</span><span><span class="hljs-variable">$quantity</span></span><span> = </span><span><span class="hljs-string">'10'</span></span><span>;
</span><span><span class="hljs-comment">// 제품의 총 가격을 계산하십시오</span></span><span>
</span><span><span class="hljs-variable">$total_price</span></span><span> = </span><span><span class="hljs-title function_ invoke__">bcmul</span></span><span>(</span><span><span class="hljs-variable">$price</span></span><span>, </span><span><span class="hljs-variable">$quantity</span></span><span>, </span><span><span class="hljs-number">2</span></span><span>);
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"제품의 총 가격:<span class="hljs-subst">$total_price</span></span></span><span>\n"; </span><span><span class="hljs-comment">// 산출:제품의 총 가격:999.90</span></span><span>
</span><span><span class="hljs-comment">// 할인 후 가격을 계산하십시오</span></span><span>
</span><span><span class="hljs-variable">$discount</span></span><span> = </span><span><span class="hljs-string">'0.85'</span></span><span>;
</span><span><span class="hljs-variable">$discounted_price</span></span><span> = </span><span><span class="hljs-title function_ invoke__">bcmul</span></span><span>(</span><span><span class="hljs-variable">$total_price</span></span><span>, </span><span><span class="hljs-variable">$discount</span></span><span>, </span><span><span class="hljs-number">2</span></span><span>);
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"할인 후 가격:<span class="hljs-subst">$discounted_price</span></span></span><span>\n"; </span><span><span class="hljs-comment">// 산출:할인 후 가격:849.91</span></span><span>
</span><span><span class="hljs-comment">// 세금과 수수료를 계산합니다</span></span><span>
</span><span><span class="hljs-variable">$tax_rate</span></span><span> = </span><span><span class="hljs-string">'0.1'</span></span><span>;
</span><span><span class="hljs-variable">$tax</span></span><span> = </span><span><span class="hljs-title function_ invoke__">bcmul</span></span><span>(</span><span><span class="hljs-variable">$discounted_price</span></span><span>, </span><span><span class="hljs-variable">$tax_rate</span></span><span>, </span><span><span class="hljs-number">2</span></span><span>);
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"구실:<span class="hljs-subst">$tax</span></span></span><span>\n"; </span><span><span class="hljs-comment">// 산출:구실:84.99</span></span><span>
</span><span><span class="hljs-comment">// 최종 가격을 계산하십시오(할인 후 가격 + 구실)</span></span><span>
</span><span><span class="hljs-variable">$final_price</span></span><span> = </span><span><span class="hljs-title function_ invoke__">bcadd</span></span><span>(</span><span><span class="hljs-variable">$discounted_price</span></span><span>, </span><span><span class="hljs-variable">$tax</span></span><span>, </span><span><span class="hljs-number">2</span></span><span>);
</span><span><span class="hljs-keyword">echo</span></span><span> </span><span><span class="hljs-string">"최종 가격:<span class="hljs-subst">$final_price</span></span></span><span>\n"; </span><span><span class="hljs-comment">// 산출:최종 가격:934.90</span></span><span>
</span></span>
여러 할부, 복합 관심 계산 등과 같은보다 복잡한 재무 계산을 위해서는 BCMUL () 및 BCDIV ()를 결합하여 정확한 수학적 모델을 구현할 수도 있습니다. 계산 정확도 매개 변수 ( Scale )를 합리적으로 선택함으로써 매우 복잡한 계산 프로세스조차도 최종 결과를 정확하게 유지할 수 있습니다.
성능 고려 사항 : BCMATH 작동은 문자열을 기반으로 작동하기 때문에 기본 PHP 작업보다 느립니다. 그럼에도 불구하고 고정화 컴퓨팅은 종종 응용 프로그램 시나리오에서 필수품이므로 이러한 시나리오에서는 BCMath를 사용하는 것이 좋습니다.
정확도 손실 방지 : BCMATH를 사용할 때는 항상 들어오는 데이터가 적절한 정밀도로 형식화되었는지 확인하십시오. 그렇지 않으면 결과에 여전히 정확도 오류가있을 수 있습니다.
PHP에서 BCMATH Extension은 강력한 고정밀 컴퓨팅 기능을 제공하며, 이는 높은 정확도가 필요한 금융 및 과학 컴퓨팅과 같은 시나리오를 처리하는 데 특히 적합합니다. bcmul () 및 bcdiv () 함수를 통해 고정밀 곱셈 및 분할 작업을 쉽게 구현하여 계산 결과의 정확성을 보장 할 수 있습니다. 실제 개발에서 부동 계산 오류를 피하기 위해 요구 사항에 따라 적절한 정확도와 스케일을 설정하여 신뢰할 수있는 결과를 얻습니다.