Blame numpy/core/src/multiarray/dragon4.h

Packit Service a47777
/*
Packit Service a47777
 * Copyright (c) 2014 Ryan Juckett
Packit Service a47777
 * http://www.ryanjuckett.com/
Packit Service a47777
 *
Packit Service a47777
 * This software is provided 'as-is', without any express or implied
Packit Service a47777
 * warranty. In no event will the authors be held liable for any damages
Packit Service a47777
 * arising from the use of this software.
Packit Service a47777
 *
Packit Service a47777
 * Permission is granted to anyone to use this software for any purpose,
Packit Service a47777
 * including commercial applications, and to alter it and redistribute it
Packit Service a47777
 * freely, subject to the following restrictions:
Packit Service a47777
 *
Packit Service a47777
 * 1. The origin of this software must not be misrepresented; you must not
Packit Service a47777
 *    claim that you wrote the original software. If you use this software
Packit Service a47777
 *    in a product, an acknowledgment in the product documentation would be
Packit Service a47777
 *    appreciated but is not required.
Packit Service a47777
 *
Packit Service a47777
 * 2. Altered source versions must be plainly marked as such, and must not be
Packit Service a47777
 *    misrepresented as being the original software.
Packit Service a47777
 *
Packit Service a47777
 * 3. This notice may not be removed or altered from any source
Packit Service a47777
 *    distribution.
Packit Service a47777
 */
Packit Service a47777
Packit Service a47777
/*
Packit Service a47777
 * This file contains a modified version of Ryan Juckett's Dragon4
Packit Service a47777
 * implementation, which has been ported from C++ to C and which has
Packit Service a47777
 * modifications specific to printing floats in numpy.
Packit Service a47777
 */
Packit Service a47777
Packit Service a47777
#ifndef _NPY_DRAGON4_H_
Packit Service a47777
#define _NPY_DRAGON4_H_
Packit Service a47777
Packit Service a47777
#include "Python.h"
Packit Service a47777
#include "structmember.h"
Packit Service a47777
#define NPY_NO_DEPRECATED_API NPY_API_VERSION
Packit Service a47777
#define _MULTIARRAYMODULE
Packit Service a47777
#include "numpy/arrayobject.h"
Packit Service a47777
#include "npy_config.h"
Packit Service a47777
#include "npy_pycompat.h"
Packit Service a47777
#include "numpy/arrayscalars.h"
Packit Service a47777
Packit Service 565ba0
/* Half binary format */
Packit Service 565ba0
#define NPY_HALF_BINFMT_NAME IEEE_binary16
Packit Service 565ba0
Packit Service 565ba0
/* Float binary format */
Packit Service 565ba0
#if NPY_BITSOF_FLOAT == 32
Packit Service 565ba0
    #define NPY_FLOAT_BINFMT_NAME IEEE_binary32
Packit Service 565ba0
#elif NPY_BITSOF_FLOAT == 64
Packit Service 565ba0
    #define NPY_FLOAT_BINFMT_NAME IEEE_binary64
Packit Service 565ba0
#else
Packit Service 565ba0
    #error No float representation defined
Packit Service 565ba0
#endif
Packit Service 565ba0
Packit Service 565ba0
/* Double binary format */
Packit Service 565ba0
#if NPY_BITSOF_DOUBLE == 32
Packit Service 565ba0
    #define NPY_DOUBLE_BINFMT_NAME IEEE_binary32
Packit Service 565ba0
#elif NPY_BITSOF_DOUBLE == 64
Packit Service 565ba0
    #define NPY_DOUBLE_BINFMT_NAME IEEE_binary64
Packit Service 565ba0
#else
Packit Service 565ba0
    #error No double representation defined
Packit Service 565ba0
#endif
Packit Service 565ba0
Packit Service 565ba0
/* LongDouble binary format */
Packit Service 565ba0
#if defined(HAVE_LDOUBLE_IEEE_QUAD_BE)
Packit Service 565ba0
    #define NPY_LONGDOUBLE_BINFMT_NAME IEEE_binary128_be
Packit Service 565ba0
#elif defined(HAVE_LDOUBLE_IEEE_QUAD_LE)
Packit Service 565ba0
    #define NPY_LONGDOUBLE_BINFMT_NAME IEEE_binary128_le
Packit Service 565ba0
#elif (defined(HAVE_LDOUBLE_IEEE_DOUBLE_LE) || \
Packit Service 565ba0
       defined(HAVE_LDOUBLE_IEEE_DOUBLE_BE))
Packit Service 565ba0
    #define NPY_LONGDOUBLE_BINFMT_NAME IEEE_binary64
Packit Service 565ba0
#elif defined(HAVE_LDOUBLE_INTEL_EXTENDED_12_BYTES_LE)
Packit Service 565ba0
    #define NPY_LONGDOUBLE_BINFMT_NAME Intel_extended96
Packit Service 565ba0
#elif defined(HAVE_LDOUBLE_INTEL_EXTENDED_16_BYTES_LE)
Packit Service 565ba0
    #define NPY_LONGDOUBLE_BINFMT_NAME Intel_extended128
Packit Service 565ba0
#elif defined(HAVE_LDOUBLE_MOTOROLA_EXTENDED_12_BYTES_BE)
Packit Service 565ba0
    #define NPY_LONGDOUBLE_BINFMT_NAME Motorola_extended96
Packit Service 565ba0
#elif (defined(HAVE_LDOUBLE_IBM_DOUBLE_DOUBLE_LE) || \
Packit Service 565ba0
       defined(HAVE_LDOUBLE_IBM_DOUBLE_DOUBLE_BE))
Packit Service 565ba0
    #define NPY_LONGDOUBLE_BINFMT_NAME IBM_double_double
Packit Service 565ba0
#else
Packit Service 565ba0
    #error No long double representation defined
Packit Service 565ba0
#endif
Packit Service 565ba0
Packit Service a47777
typedef enum DigitMode
Packit Service a47777
{
Packit Service a47777
    /* Round digits to print shortest uniquely identifiable number. */
Packit Service a47777
    DigitMode_Unique,
Packit Service a47777
    /* Output the digits of the number as if with infinite precision */
Packit Service a47777
    DigitMode_Exact,
Packit Service a47777
} DigitMode;
Packit Service a47777
Packit Service a47777
typedef enum CutoffMode
Packit Service a47777
{
Packit Service a47777
    /* up to cutoffNumber significant digits */
Packit Service a47777
    CutoffMode_TotalLength,
Packit Service a47777
    /* up to cutoffNumber significant digits past the decimal point */
Packit Service a47777
    CutoffMode_FractionLength,
Packit Service a47777
} CutoffMode;
Packit Service a47777
Packit Service a47777
typedef enum TrimMode
Packit Service a47777
{
Packit Service a47777
    TrimMode_None,         /* don't trim zeros, always leave a decimal point */
Packit Service a47777
    TrimMode_LeaveOneZero, /* trim all but the zero before the decimal point */
Packit Service a47777
    TrimMode_Zeros,        /* trim all trailing zeros, leave decimal point */
Packit Service a47777
    TrimMode_DptZeros,     /* trim trailing zeros & trailing decimal point */
Packit Service a47777
} TrimMode;
Packit Service a47777
Packit Service 565ba0
#define make_dragon4_typedecl(Type, npy_type) \
Packit Service 565ba0
    PyObject *\
Packit Service 565ba0
    Dragon4_Positional_##Type(npy_type *val, DigitMode digit_mode,\
Packit Service 565ba0
                              CutoffMode cutoff_mode, int precision,\
Packit Service 565ba0
                              int sign, TrimMode trim, int pad_left,\
Packit Service 565ba0
                              int pad_right);\
Packit Service 565ba0
    PyObject *\
Packit Service 565ba0
    Dragon4_Scientific_##Type(npy_type *val, DigitMode digit_mode,\
Packit Service 565ba0
                              int precision, int sign, TrimMode trim,\
Packit Service 565ba0
                              int pad_left, int exp_digits);
Packit Service a47777
Packit Service 565ba0
make_dragon4_typedecl(Half, npy_half)
Packit Service 565ba0
make_dragon4_typedecl(Float, npy_float)
Packit Service 565ba0
make_dragon4_typedecl(Double, npy_double)
Packit Service 565ba0
make_dragon4_typedecl(LongDouble, npy_longdouble)
Packit Service 565ba0
Packit Service 565ba0
#undef make_dragon4_typedecl
Packit Service a47777
Packit Service a47777
PyObject *
Packit Service a47777
Dragon4_Positional(PyObject *obj, DigitMode digit_mode, CutoffMode cutoff_mode,
Packit Service a47777
                   int precision, int sign, TrimMode trim, int pad_left,
Packit Service a47777
                   int pad_right);
Packit Service a47777
Packit Service a47777
PyObject *
Packit Service a47777
Dragon4_Scientific(PyObject *obj, DigitMode digit_mode, int precision,
Packit Service a47777
                   int sign, TrimMode trim, int pad_left, int exp_digits);
Packit Service a47777
Packit Service a47777
#endif
Packit Service a47777