Joshua
open source statistical hierarchical phrase-based machine translation system
 All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator Friends
src/kenlm/util/double-conversion/bignum-dtoa.h
00001 // Copyright 2010 the V8 project authors. All rights reserved.
00002 // Redistribution and use in source and binary forms, with or without
00003 // modification, are permitted provided that the following conditions are
00004 // met:
00005 //
00006 //     * Redistributions of source code must retain the above copyright
00007 //       notice, this list of conditions and the following disclaimer.
00008 //     * Redistributions in binary form must reproduce the above
00009 //       copyright notice, this list of conditions and the following
00010 //       disclaimer in the documentation and/or other materials provided
00011 //       with the distribution.
00012 //     * Neither the name of Google Inc. nor the names of its
00013 //       contributors may be used to endorse or promote products derived
00014 //       from this software without specific prior written permission.
00015 //
00016 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00017 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00018 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
00019 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
00020 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00021 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00022 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00023 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00024 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00025 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00026 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00027 
00028 #ifndef DOUBLE_CONVERSION_BIGNUM_DTOA_H_
00029 #define DOUBLE_CONVERSION_BIGNUM_DTOA_H_
00030 
00031 #include "utils.h"
00032 
00033 namespace double_conversion {
00034 
00035 enum BignumDtoaMode {
00036   // Return the shortest correct representation.
00037   // For example the output of 0.299999999999999988897 is (the less accurate but
00038   // correct) 0.3.
00039   BIGNUM_DTOA_SHORTEST,
00040   // Same as BIGNUM_DTOA_SHORTEST but for single-precision floats.
00041   BIGNUM_DTOA_SHORTEST_SINGLE,
00042   // Return a fixed number of digits after the decimal point.
00043   // For instance fixed(0.1, 4) becomes 0.1000
00044   // If the input number is big, the output will be big.
00045   BIGNUM_DTOA_FIXED,
00046   // Return a fixed number of digits, no matter what the exponent is.
00047   BIGNUM_DTOA_PRECISION
00048 };
00049 
00050 // Converts the given double 'v' to ascii.
00051 // The result should be interpreted as buffer * 10^(point-length).
00052 // The buffer will be null-terminated.
00053 //
00054 // The input v must be > 0 and different from NaN, and Infinity.
00055 //
00056 // The output depends on the given mode:
00057 //  - SHORTEST: produce the least amount of digits for which the internal
00058 //   identity requirement is still satisfied. If the digits are printed
00059 //   (together with the correct exponent) then reading this number will give
00060 //   'v' again. The buffer will choose the representation that is closest to
00061 //   'v'. If there are two at the same distance, than the number is round up.
00062 //   In this mode the 'requested_digits' parameter is ignored.
00063 //  - FIXED: produces digits necessary to print a given number with
00064 //   'requested_digits' digits after the decimal point. The produced digits
00065 //   might be too short in which case the caller has to fill the gaps with '0's.
00066 //   Example: toFixed(0.001, 5) is allowed to return buffer="1", point=-2.
00067 //   Halfway cases are rounded up. The call toFixed(0.15, 2) thus returns
00068 //     buffer="2", point=0.
00069 //   Note: the length of the returned buffer has no meaning wrt the significance
00070 //   of its digits. That is, just because it contains '0's does not mean that
00071 //   any other digit would not satisfy the internal identity requirement.
00072 //  - PRECISION: produces 'requested_digits' where the first digit is not '0'.
00073 //   Even though the length of produced digits usually equals
00074 //   'requested_digits', the function is allowed to return fewer digits, in
00075 //   which case the caller has to fill the missing digits with '0's.
00076 //   Halfway cases are again rounded up.
00077 // 'BignumDtoa' expects the given buffer to be big enough to hold all digits
00078 // and a terminating null-character.
00079 void BignumDtoa(double v, BignumDtoaMode mode, int requested_digits,
00080                 Vector<char> buffer, int* length, int* point);
00081 
00082 }  // namespace double_conversion
00083 
00084 #endif  // DOUBLE_CONVERSION_BIGNUM_DTOA_H_