Canola
0.8.D001
|
00001 // 00002 // canola - canon canola 1614p emulator 00003 // Copyright (C) 2011, 2012 Peter Miller 00004 // 00005 // This program is free software; you can redistribute it and/or modify 00006 // it under the terms of the GNU General Public License, version 3, as 00007 // published by the Free Software Foundation. 00008 // 00009 // This program is distributed in the hope that it will be useful, 00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00012 // General Public License for more details. 00013 // 00014 // You should have received a copy of the GNU General Public License along 00015 // with this program. If not, see <http://www.gnu.org/licenses/>. 00016 // 00017 00018 #include <lib/ac/assert.h> 00019 #include <lib/ac/math.h> 00020 00021 #include <lib/number.h> 00022 00023 00024 void 00025 number::operator/=(const number &rhs) 00026 { 00027 *this = operator/(rhs); 00028 } 00029 00030 00031 number 00032 number::operator/(const number &rhs) 00033 const 00034 { 00035 if (rhs.is_zero()) 00036 return number::infinity(); 00037 00038 bool neg = (negative != rhs.negative); 00039 00040 unsigned t3ndec = 16; 00041 assert(t3ndec * 2 >= decimal); 00042 assert(t3ndec >= rhs.decimal); 00043 number_z t1(value.shift_left(t3ndec * 2 - decimal)); 00044 number_z t2(rhs.value.shift_left(t3ndec - rhs.decimal)); 00045 number_z t3 = t1 / t2; 00046 00047 // Instruction Manual, p. 21: 00048 // "If the number of digits in the result exceeds 16, the leftmost 00049 // digit priority system functions and excess digits at the right 00050 // are dropped." 00051 truncate_floating_operation(t3, t3ndec); 00052 00053 // <question> 00054 // Does division strip redundant decimal places to the right of the 00055 // decimal point? 00056 // </question> 00057 strip_redundant_decimal_places(t3, t3ndec); 00058 00059 return number(t3, t3ndec, neg); 00060 } 00061 00062 00063 // vim: set ts=8 sw=4 et :