Maison >interface Web >js tutoriel >Calcul précis des nombres à virgule flottante js
//Fonction de division, utilisée pour obtenir des résultats de division précis
//Explication : Le résultat de division de JavaScript aura des erreurs, qui seront plus évidentes lors de la division de deux nombres à virgule flottante. Cette fonction renvoie un résultat de division plus précis.
//Appel : accp(arg1,arg2)
//Valeur de retour : le résultat exact de la division de arg1 par arg2
function accp(arg1,arg2){ var t1=0,t2=0,r1,r2; try{t1=arg1.toString().split(".")[1].length}catch(e){} try{t2=arg2.toString().split(".")[1].length}catch(e){} with(Math){ r1=Number(arg1.toString().replace(".","")); r2=Number(arg2.toString().replace(".","")); return (r1/r2)*pow(10,t2-t1); } }
//Donner Number L'ajout d'une méthode p au type rend l'appel plus pratique.
Number.prototype.p = function (arg){
return accp(this, arg);
}
//Fonction de multiplication, utilisée pour obtenir des résultats de multiplication précis
//Explication : Le résultat de la multiplication de JavaScript comportera des erreurs, qui seront plus évidentes lorsque deux nombres à virgule flottante seront multipliés. Cette fonction renvoie un résultat de multiplication plus précis.
//Appel : accMul(arg1,arg2)
//Valeur de retour : le résultat exact de arg1 multiplié par arg2
function accMul(arg1,arg2) { var m=0,s1=arg1.toString(),s2=arg2.toString(); try{m+=s1.split(".")[1].length}catch(e){} try{m+=s2.split(".")[1].length}catch(e){} return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m); }
//Give Number Ajoutez une méthode mul au type pour le rendre plus pratique à appeler.
Number.prototype.mul = function (arg){ return accMul(arg, this); };
//Fonction d'addition, utilisée pour obtenir des résultats d'addition précis
//Explication : Le résultat de l'addition de JavaScript aura des erreurs et sera comparé lors de l'ajout de deux nombres à virgule flottante évidents. . Cette fonction renvoie un résultat d'addition plus précis.
//Appel : accAdd(arg1,arg2)
//Valeur de retour : le résultat exact de arg1 plus arg2
function accAdd(arg1,arg2){ var r1,r2,m; try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0} try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0} m=Math.pow(10,Math.max(r1,r2)); return (arg1*m+arg2*m)/m; }
//给Number类型增加一个add方法,调用起来更加方便。 Number.prototype.add = function (arg){ return accAdd(arg,this); } //减法函数 function accSub(arg1,arg2){ var r1,r2,m,n; try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0} try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0} m=Math.pow(10,Math.max(r1,r2)); //last modify by deeka //动态控制精度长度 n=(r1>=r2)?r1:r2; return ((arg2*m-arg1*m)/m).toFixed(n); } ///给number类增加一个sub方法,调用起来更加方便 Number.prototype.sub = function (arg){ return accSub(arg,this); }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!