123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- /**
- * Created by jimiz on 2017/3/28.
- */
- let scMathUtil = {
- innerRoundTo: function(num, digit){
- let lFactor = Math.pow(10, digit);
- let fOffSet = 0.5;
- let sign = '';
- if (num < 0){
- sign = '-';
- num = Math.abs(num);
- }
- let result = Math.floor((num / lFactor) + fOffSet).toString();
- let iLength = result.length;
- let r1 = result.substring(0, iLength + digit);
- let r2 = result.substring(iLength + digit, iLength);
- return Number(sign + r1 + '.' + r2);
- },
- floatToBin: function(num) {
- return num.toString(2);
- },
- binToFloat: function(bin) {
- let result = 0;
- let iLength = bin.length;
- let sign = '';
- if (iLength > 0 && bin[0]==='-'){
- sign = '-';
- bin = bin.substring(1, iLength);
- }
- iLength = bin.length;
- let iDot = bin.indexOf('.');
- if (iDot >= 0) {
- for (let i = 0; i < iLength; i++) {
- let num = Number(bin[i]);
- let idx = iDot - i;
- if (idx === 0) {
- continue
- };
- if (idx > 0) {
- idx -= 1
- };
- let r = Math.pow(2, idx);
- result += num * r;
- }
- }
- else {
- result = parseInt(bin, 2);
- };
- return sign + result;
- },
- zeroString: function(length){
- let result = '';
- for (let i = 0; i < length; i++){
- result = result + '0';
- };
- return result;
- },
- incMantissa: function(bin){
- let result = bin;
- let iDot = bin.indexOf('.');
- if (iDot < 0){return result};
- let iLength = bin.length;
- for (let i = iLength - 1; i > iDot; i--){
- let num = Number(bin[i]);
- if (num === 0){
- num = 1;
- let bin1 = bin.substring(0, i);
- let bin2 = zeroString(iLength - (i + 1));//bin.substring(i + 1, iLength);
- result = bin1 + num.toString() + bin2;
- break;
- }
- };
- return result;
- },
- roundTo: function(num, digit){
- let me = this;
- return me.innerRoundTo(me.binToFloat(me.incMantissa(me.floatToBin(num))), digit);
- }
- };
|