QDouble.st
author Claus Gittinger <cg@exept.de>
Fri, 29 Nov 2019 20:41:31 +0100
changeset 5315 2d4dfaeac032
parent 5314 1ac391a7075b
child 5326 680b5176c8ef
permissions -rw-r--r--
#FEATURE by cg class: QDouble comment/format in: #ln class: QDouble class added: #fromLongFloat:
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
     1
"{ Encoding: utf8 }"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
     2
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
 COPYRIGHT (c) 2017 by eXept Software AG
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
     5
              All Rights Reserved
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 This software is furnished under a license and may be used
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
 hereby transferred.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
"{ Package: 'stx:libbasic2' }"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
"{ NameSpace: Smalltalk }"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
LimitedPrecisionReal variableByteSubclass:#QDouble
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    19
        instanceVariableNames:''
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    20
        classVariableNames:'DefaultPrintFormat E Epsilon FMax FMin InvFact Ln10 Ln2 NaN Pi
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    21
                QDoubleOne QDoubleZero'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    22
        poolDictionaries:''
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    23
        category:'Magnitude-Numbers'
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
!QDouble primitiveDefinitions!
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    27
%{
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    28
#include <stdio.h>
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    29
#include <errno.h>
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    30
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    31
#define __USE_ISOC9X 1
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    32
#define __USE_ISOC99 1
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    33
#include <math.h>
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    34
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    35
/*
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    36
 * on some systems, errno is a macro ... check for it here
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    37
 */
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    38
#ifndef errno
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    39
 extern errno;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    40
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    41
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    42
#if !defined (__win32__)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    43
# include <locale.h>
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    44
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    45
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    46
#if defined (__aix__)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    47
# include <float.h>
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    48
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    49
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    50
#if defined(__irix__) || defined(__solaris__) || defined(__sunos__)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    51
# include <nan.h>
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    52
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    53
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    54
#if defined(__linux__)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    55
# ifndef NAN
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    56
#  include <bits/nan.h>
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    57
# endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    58
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    59
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    60
#ifdef __win32__
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    61
# ifndef isinf
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    62
#  define isinf(x) \
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    63
        ((((unsigned int *)(&x))[0] == 0x00000000) && \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    64
         ((((unsigned int *)(&x))[1] & 0x7FF00000) == 0x7FF00000))
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    65
# endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    66
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    67
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    68
/*
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    69
 * fpu_fix_start:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    70
 *     Set the round-to-double flag, and save the old control word in old_cw.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    71
 * fpu_fix_end:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    72
 *     Restore the control word.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    73
 */
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    74
#if defined(__x86__) || defined(__x86_64__)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    75
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    76
# ifndef _FPU_EXTENDED
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    77
#  define _FPU_EXTENDED 0x0300
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    78
# endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    79
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    80
# ifndef _FPU_DOUBLE
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    81
#  define _FPU_DOUBLE 0x0200
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    82
# endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    83
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    84
# if defined( __win32__ )
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    85
#  if defined( __BORLANDC__ )
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    86
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    87
#   define fpu_fix_start(old_cw_ptr) {  \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    88
        *old_cw_ptr = _control87(0, 0); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    89
        _control87(_FPU_DOUBLE, _FPU_EXTENDED);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    90
    }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    91
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    92
#   define fpu_fix_end(old_cw_ptr) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    93
        _control87(*old_cw_ptr, 0xFFFF);\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    94
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    95
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    96
#  else
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    97
#   define fpu_fix_start(old_cw_ptr) {  \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    98
        *old_cw_ptr = _control87(0, 0); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
    99
        _control87(0x00010000, 0x00030000);\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   100
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   101
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   102
#   define fpu_fix_end(old_cw_ptr) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   103
        _control87(*old_cw_ptr, 0xFFFFFFFF);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   104
    }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   105
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   106
#  endif
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   107
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   108
# else // assume MINGW, GCC or CLANG
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   109
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   110
#  ifndef _FPU_GETCW
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   111
#   define _FPU_GETCW(x) asm volatile ("fnstcw %0":"=m" (x));
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   112
#  endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   113
#  ifndef _FPU_SETCW
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   114
#   define _FPU_SETCW(x) asm volatile ("fldcw %0": :"m" (x));
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   115
#  endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   116
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   117
#  define fpu_fix_start(old_cw_ptr) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   118
        volatile unsigned short cw, new_cw;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   119
        _FPU_GETCW(cw);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   120
        new_cw = (cw & ~_FPU_EXTENDED) | _FPU_DOUBLE;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   121
        _FPU_SETCW(new_cw);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   122
        *old_cw_ptr = cw;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   123
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   124
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   125
#  define fpu_fix_end(old_cw_ptr) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   126
        volatile unsigned short cw = *old_cw_ptr;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   127
        _FPU_SETCW(cw);\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   128
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   129
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   130
# endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   131
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   132
#endif // defined(__x86__) || defined(__x86_64__)
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   133
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   134
#define __qNew_qdReal(newQD, d0,d1,d2,d3) { \
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   135
    double* __d__;  \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   136
    __qNew(newQD, sizeof(struct __qDoubleStruct));   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   137
    __stx_setClass(newQD, QDouble);                  \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   138
    __d__ = __QDoubleInstPtr(newQD)->d_qDoubleValue; \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   139
    __d__[0] = d0;   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   140
    __d__[1] = d1;   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   141
    __d__[2] = d2;   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   142
    __d__[3] = d3;   \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   143
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   144
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   145
#if 0
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   146
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   147
// sigh: not all compilers (borland) support inline functions;
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   148
// therefore we have to use macros...
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   149
// sigh2: c-macros are unhygienic - to avoid catching/hiding variable bindings,
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   150
// use different names in each macros (i.e. a_xxx)
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   151
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   152
#define _QD_SPLITTER 134217729.0               // = 2^27 + 1
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   153
#define _QD_SPLIT_THRESH 6.69692879491417e+299 // = 2^996
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   154
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   155
#define m_quick_two_sum(rslt_1, a_1, b_1, err_1)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   156
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   157
    double s_1 = (a_1) + (b_1);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   158
    (err_1) = (b_1) - (s_1 - (a_1));\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   159
    (rslt_1) = s_1; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   160
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   161
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   162
#define m_quick_two_diff(rslt_2, a_2, b_2, err_2)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   163
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   164
    double s_2 = (a_2) - (b_2);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   165
    (err_2) = ((a_2) - s_2) - (b_2);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   166
    (rslt_2) = s_2;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   167
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   168
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   169
#define m_two_sum(rslt_3, a_3, b_3, err_3)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   170
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   171
    double s_3 = (a_3) + (b_3);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   172
    double v_3 = s_3 - (a_3);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   173
    (err_3) = ((a_3) - (s_3 - v_3)) + ((b_3) - v_3);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   174
    (rslt_3) = s_3;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   175
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   176
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   177
/* Computes fl(a-b) and err(a-b).  */
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   178
#define m_two_diff(rslt_4, a_4, b_4, err_4)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   179
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   180
    double s_4 = (a_4) - (b_4);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   181
    double bb_4 = s_4 - (a_4);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   182
    (err_4) = ((a_4) - (s_4 - bb_4)) - ((b_4) + bb_4);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   183
    (rslt_4) = s_4;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   184
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   185
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   186
#define m_three_sum(a_5, b_5, c_5)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   187
{ \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   188
    double t1_5, t2_5, t3_5; \
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   189
    m_two_sum(t1_5, (a_5), (b_5), t2_5); \
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   190
    m_two_sum((a_5), (c_5), t1_5, t3_5); \
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   191
    m_two_sum((b_5), t2_5, t3_5, (c_5)); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   192
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   193
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   194
#define m_three_sum2(a_6, b_6, c_6)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   195
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   196
    double t1_6, t2_6, t3_6;\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   197
    m_two_sum(t1_6, (a_6), (b_6), t2_6);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   198
    m_two_sum((a_6), (c_6), t1_6, t3_6);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   199
    (b_6) = t2_6 + t3_6;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   200
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   201
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   202
#ifndef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   203
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   204
/* Computes high word and lo word of a */
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   205
#define m_split(a_7, hi_7, lo_7)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   206
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   207
    double temp_7;\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   208
    double thi_7, tlo_7;\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   209
    if ((a_7) > _QD_SPLIT_THRESH || (a_7) < -_QD_SPLIT_THRESH) {\
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   210
        (a_7) *= 3.7252902984619140625e-09;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   211
        temp_7 = _QD_SPLITTER * (a_7);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   212
        thi_7 = temp_7 - (temp_7 - (a_7));\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   213
        tlo_7 = (a_7) - thi_7;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   214
        thi_7 *= 268435456.0;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   215
        tlo_7 *= 268435456.0;\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   216
    } else {\
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   217
        temp_7 = _QD_SPLITTER * (a_7);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   218
        thi_7 = temp_7 - (temp_7 - (a_7));\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   219
        tlo_7 = (a_7) - thi_7;\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   220
    }\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   221
    (hi_7) = thi_7; \
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   222
    (lo_7) = tlo_7; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   223
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   224
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   225
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   226
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   227
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   228
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   229
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   230
/* Computes fl(a*b) and err(a*b). */
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   231
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   232
#define m_two_prod(rslt_8, a_8, b_8, err_8)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   233
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   234
    double p_8 = (a_8) * (b_8);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   235
    err_8 = QD_FMS((a_8), (b_8), p_8);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   236
    rslt_8 = p_8; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   237
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   238
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   239
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   240
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   241
#define m_two_prod(rslt_8, a_8, b_8, err_8)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   242
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   243
    double a_hi_8, a_lo_8, b_hi_8, b_lo_8;\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   244
    double p_8 = (a_8) * (b_8);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   245
    m_split(a_8, a_hi_8, a_lo_8);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   246
    m_split(b_8, b_hi_8, b_lo_8);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   247
    err_8 = ((a_hi_8 * b_hi_8 - p_8) + a_hi_8 * b_lo_8 + a_lo_8 * b_hi_8) + a_lo_8 * b_lo_8;\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   248
    rslt_8 = p_8; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   249
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   250
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   251
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   252
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   253
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   254
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   255
#define m_two_sqr(rslt_9, a_9, err_9)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   256
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   257
    double p_9 = (a_9) * (a_9);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   258
    err_9 = QD_FMS((a_9), (a_9), p_9);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   259
    rslt_9 = p_9;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   260
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   261
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   262
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   263
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   264
#define m_two_sqr(rslt_9, a_9, err_9)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   265
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   266
    double hi_9, lo_9;\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   267
    double q_9 = (a_9) * (a_9);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   268
    m_split(a_9, hi_9, lo_9);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   269
    err_9 = ((hi_9 * hi_9 - q_9) + 2.0 * hi_9 * lo_9) + lo_9 * lo_9;\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   270
    rslt_9 = q_9;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   271
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   272
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   273
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   274
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   275
#define m_renorm4(c0_10, c1_10, c2_10, c3_10)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   276
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   277
    double s0_10, s1_10, s2_10 = 0.0, s3_10 = 0.0;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   278
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   279
    if (! isinf(c0_10)) { \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   280
\
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   281
        m_quick_two_sum(s0_10, c2_10, c3_10, c3_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   282
        m_quick_two_sum(s0_10, c1_10, s0_10, c2_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   283
        m_quick_two_sum(c0_10, c0_10, s0_10, c1_10);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   284
\
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   285
        s0_10 = c0_10;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   286
        s1_10 = c1_10;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   287
        if (s1_10 != 0.0) {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   288
             m_quick_two_sum(s1_10, s1_10, c2_10, s2_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   289
            if (s2_10 != 0.0) {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   290
                 m_quick_two_sum(s2_10, s2_10, c3_10, s3_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   291
            } else {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   292
                 m_quick_two_sum(s1_10, s1_10, c3_10, s2_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   293
            }\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   294
        } else {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   295
            m_quick_two_sum(s0_10, s0_10, c2_10, s1_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   296
            if (s1_10 != 0.0) {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   297
                 m_quick_two_sum(s1_10, s1_10, c3_10, s2_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   298
            } else {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   299
                 m_quick_two_sum(s0_10, s0_10, c3_10, s1_10);\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   300
            }\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   301
        }\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   302
\
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   303
        c0_10 = s0_10;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   304
        c1_10 = s1_10;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   305
        c2_10 = s2_10;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   306
        c3_10 = s3_10;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   307
    }\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   308
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   309
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   310
#define m_renorm5(c0_11, c1_11, c2_11, c3_11, c4_11)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   311
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   312
    double s0_11, s1_11, s2_11 = 0.0, s3_11 = 0.0; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   313
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   314
    if (! isinf(c0_11)) { \
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   315
        m_quick_two_sum(s0_11, c3_11, c4_11, c4_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   316
        m_quick_two_sum(s0_11, c2_11, s0_11, c3_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   317
        m_quick_two_sum(s0_11, c1_11, s0_11, c2_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   318
        m_quick_two_sum(c0_11, c0_11, s0_11, c1_11); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   319
\
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   320
        s0_11 = c0_11; \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   321
        s1_11 = c1_11; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   322
\
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   323
        m_quick_two_sum(s0_11, c0_11, c1_11, s1_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   324
        if (s1_11 != 0.0) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   325
            m_quick_two_sum(s1_11, s1_11, c2_11, s2_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   326
            if (s2_11 != 0.0) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   327
                m_quick_two_sum(s2_11 ,s2_11, c3_11, s3_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   328
                if (s3_11 != 0.0) {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   329
                    s3_11 += c4_11; \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   330
                } else {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   331
                    s2_11 += c4_11;\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   332
                }\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   333
            } else { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   334
                m_quick_two_sum(s1_11, s1_11, c3_11, s2_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   335
                if (s2_11 != 0.0) {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   336
                    m_quick_two_sum(s2_11, s2_11, c4_11, s3_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   337
                } else { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   338
                    m_quick_two_sum(s1_11, s1_11, c4_11, s2_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   339
                } \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   340
            } \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   341
        } else { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   342
            m_quick_two_sum(s0_11,s0_11, c2_11, s1_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   343
            if (s1_11 != 0.0) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   344
                m_quick_two_sum(s1_11,s1_11, c3_11, s2_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   345
                if (s2_11 != 0.0) {\
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   346
                    m_quick_two_sum(s2_11,s2_11, c4_11, s3_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   347
                } else { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   348
                    m_quick_two_sum(s1_11 ,s1_11, c4_11, s2_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   349
                } \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   350
            } else { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   351
                m_quick_two_sum(s0_11,s0_11, c3_11, s1_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   352
                if (s1_11 != 0.0) { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   353
                    m_quick_two_sum(s1_11,s1_11, c4_11, s2_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   354
                } else { \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   355
                    m_quick_two_sum(s0_11,s0_11, c4_11, s1_11); \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   356
                } \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   357
            } \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   358
        } \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   359
 \
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   360
        c0_11 = s0_11; \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   361
        c1_11 = s1_11; \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   362
        c2_11 = s2_11; \
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   363
        c3_11 = s3_11; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   364
    } \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   365
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   366
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   367
#endif // 0
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   368
%}
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   370
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
!QDouble primitiveFunctions!
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   372
%{
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   373
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
   374
#ifdef __BORLANDC__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   375
# define INLINE /* */
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   376
#else
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   377
# define INLINE inline
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   378
#endif
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   379
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   380
#define QD_IEEE_ADD
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   381
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   382
// routines
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   383
// fast_two_sum : s + e = a + b, s = fl(a + b), e = err(a + b), assumption |a|>|b|, Dekker('71)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   384
// two_sum      : s + e = a + b, s = fl(a + b), e = err(a + b), Knuth('69)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   385
// three_sum    : d + e + f = a + b + c, def are nonoverlapping, Bailey
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   386
// three_sum2   : d + e = a + b + c, de are nonoverlapping, Bailey
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   387
// two_prod     : s + e = a * b, s = fl(a * b), e = err(a * b), Verkamp and Dekker
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   388
// sqr          : s + e = a^2, s = fl(a * a), e = err(a * a)
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   389
// renorm       : renormalization algorithm
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   390
// qd_add_s  : qd + double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   391
// qd_add_qd : qd + qd (sloppy add)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   392
// s_sub_qd  : double - qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   393
// qd_sub_qd : qd - qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   394
// s_mul_qd  : double * qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   395
// qd_mul_qd : qd * qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   396
// qd_div_qd : qd / qd
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   397
// qd_sqr    : qd ^ 2
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   398
// qd_sqrt   : square root (scalar)
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   399
// qd_pow    : qd ^ n (n integer)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   400
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   401
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   402
fast_two_sum(double *s, double *e, double a, double b)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   403
{
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   404
    double t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   405
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   406
    s[0] = t = a + b;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   407
    e[0] = b - (t - a);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   408
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   409
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   410
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   411
two_sum(double *s, double *e, double a, double b)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   412
{
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   413
    double t, bb;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   414
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   415
    s[0] = t = a + b;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   416
    bb = t - a;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   417
    e[0] = (a - (t - bb)) + (b - bb);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   418
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   419
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   420
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   421
three_sum(double *d, double *e, double *f, double a, double b, double c)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   422
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   423
    double t1,t2,t3,v;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   424
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   425
    d[0] = 0.0; e[0] = 0.0; f[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   426
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   427
    t1= a + b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   428
    v = t1 - a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   429
    t2= (a - (t1 - v))+(b - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   430
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   431
    d[0] = t1 + c;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   432
    v = d[0] - t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   433
    t3= (t1 - (d[0] - v))+(c - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   434
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   435
    e[0] = t2 + t3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   436
    v = e[0] - t2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   437
    f[0] = (t2 - (e[0] - v))+(t3 - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   438
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   439
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   440
static INLINE void
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   441
three_sum2(double *d, double *e, double a, double b, double c) {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   442
    double t1,t2,t3,v;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   443
    d[0] = 0.0; e[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   444
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   445
    t1= a + b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   446
    v = t1 - a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   447
    t2= (a - (t1 - v))+(b - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   448
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   449
    d[0] = t1 + c;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   450
    v = d[0] - t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   451
    t3= (t1 - (d[0] - v))+(c - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   452
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   453
    e[0] = t2 + t3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   454
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   455
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   456
/* Computes high word and lo word of a */
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   457
#define _QD_SPLITTER 134217729.0               // = 2^27 + 1
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   458
#define _QD_SPLIT_THRESH 6.69692879491417e+299 // = 2^996
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   459
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   460
static INLINE void
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   461
split(double a, double *hi, double *lo) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   462
    double temp;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   463
    if (a > _QD_SPLIT_THRESH || a < -_QD_SPLIT_THRESH) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   464
        a *= 3.7252902984619140625e-09;  // 2^-28
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   465
        temp = _QD_SPLITTER * a;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   466
        *hi = temp - (temp - a);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   467
        *lo = a - *hi;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   468
        *hi *= 268435456.0;          // 2^28
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   469
        *lo *= 268435456.0;          // 2^28
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   470
    } else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   471
        temp = _QD_SPLITTER * a;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   472
        *hi = temp - (temp - a);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   473
        *lo = a - *hi;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   474
    }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   475
}
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   476
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   477
#if 0
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   478
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   479
two_prod(double *p, double *e, double a, double b)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   480
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   481
    double t,ah,al,bh,bl;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   482
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   483
    p[0] = a * b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   484
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   485
    t = 134217729 * a;       // splitter: 2^27 + 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   486
    ah = t -(t - a);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   487
    al = a - ah;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   488
    t = 134217729 * b;       // splitter: 2^27 + 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   489
    bh = t -(t - b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   490
    bl = b - bh;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   491
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   492
    e[0] = ((ah*bh - p[0]) + ah*bl + al*bh) + al*bl;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   493
}
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   494
#else
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   495
static INLINE double
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   496
two_prod(double *o, double *e, double a, double b) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   497
  double a_hi, a_lo, b_hi, b_lo;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   498
  double p = a * b;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   499
  split(a, &a_hi, &a_lo);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   500
  split(b, &b_hi, &b_lo);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   501
  e[0] = ((a_hi * b_hi - p) + a_hi * b_lo + a_lo * b_hi) + a_lo * b_lo;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   502
  o[0] = p;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   503
}
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   504
#endif
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   505
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   506
#if 0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   507
// multiply by something known to be a power of 2
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   508
static INLINE
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   509
mul_pwr2(double *o0, double *o1, double *o2, double *o3, double a0, double a1, double a2, double a3, double b) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   510
    o0[0] = a0 * b;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   511
    o0[1] = a1 * b;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   512
    o0[2] = a2 * b;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   513
    o0[3] = a3 * b;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   514
}
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   515
#endif
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   516
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   517
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   518
sqr(double *p, double *e, double a)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   519
{
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   520
#if 0
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   521
    double t,ah,al;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   522
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   523
    p[0] = a * a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   524
    t = 134217729 * a;          // splitter: 2^27 + 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   525
    ah = t -(t - a);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   526
    al = a - ah;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   527
    e[0] = ((ah*ah - p[0]) + (ah*al)*2.0) + al*al;
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   528
#else
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   529
    double hi, lo;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   530
    double q = a * a;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   531
    split(a, &hi, &lo);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   532
    *e = ((hi * hi - q) + 2.0 * hi * lo) + lo * lo;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   533
    p[0] = q;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   534
#endif
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   535
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   536
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   537
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   538
renorm(double *b0, double *b1, double *b2, double *b3, double a0, double a1, double a2, double a3, double a4)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   539
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   540
    double t0,t1,t2,t3,t4,s,ss;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   541
    s = 0.0; ss = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   542
    t0 = 0.0;t1 = 0.0;t2 = 0.0;t3 = 0.0;t4 = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   543
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   544
//    fast_two_sum(&x, &y, a3, a4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   545
//    s = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   546
//    t4 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   547
//    fast_two_sum(&x, &y, a2, s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   548
//    s = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   549
//    t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   550
//    fast_two_sum(&x, &y, a1, s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   551
//    s = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   552
//    t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   553
//    fast_two_sum(&x, &y, a0, s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   554
//    t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   555
//    t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   556
//    if(t1 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   557
//        fast_two_sum(&x, &y, t1, t2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   558
//        t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   559
//        t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   560
//        if(t2 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   561
//            fast_two_sum(&x, &y,t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   562
//            t2 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   563
//            t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   564
//            if(t3 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   565
//                t3 += t4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   566
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   567
//                t2 += t4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   568
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   569
//        } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   570
//            fast_two_sum(&x, &y, t1, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   571
//            t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   572
//            t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   573
//            if(t2 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   574
//                fast_two_sum(&x, &y, t2, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   575
//                t2 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   576
//                t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   577
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   578
//                fast_two_sum(&x, &y, t1, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   579
//                t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   580
//                t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   581
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   582
//        }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   583
//    } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   584
//        fast_two_sum(&x, &y, t0, t2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   585
//        t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   586
//        t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   587
//        if(t1 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   588
//            fast_two_sum(&x, &y, t1, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   589
//            t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   590
//            t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   591
//            if(t2 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   592
//                fast_two_sum(&x, &y, t2, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   593
//                t2 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   594
//                t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   595
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   596
//                fast_two_sum(&x, &y, t1, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   597
//                t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   598
//                t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   599
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   600
//        } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   601
//            fast_two_sum(&x, &y, t0, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   602
//            t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   603
//            t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   604
//            if(t1 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   605
//                fast_two_sum(&x, &y, t1, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   606
//                t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   607
//                t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   608
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   609
//                fast_two_sum(&x, &y, t0, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   610
//                t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   611
//                t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   612
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   613
//        }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   614
//    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   615
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   616
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   617
    //[s,t4] = fast_two_sum(a4,a5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   618
    s = a3 + a4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   619
    t3 = a4 - (s - a3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   620
    //[ss,t3] = fast_two_sum(a3,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   621
    ss = a2 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   622
    t2 = s - (ss - a2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   623
    //[s,t2] = fast_two_sum(a2,ss);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   624
    s  = a1 + ss;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   625
    t1 = ss - (s - a1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   626
    //[b1,t1] = fast_two_sum(a1,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   627
    b0[0] = a0 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   628
    t0 = s - (b0[0] - a0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   629
    //[s,t3] = fast_two_sum(t3,t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   630
    s = t2 + t3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   631
    t2 = t3 - (s - t2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   632
    //[ss,t2] = fast_two_sum(t2,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   633
    ss = t1 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   634
    t1 = s - (ss - t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   635
    //[b2,t1] = fast_two_sum(t1,ss);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   636
    b1[0] = t0 + ss;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   637
    t0 = ss - (b1[0] - t0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   638
    //[s,t2] = fast_two_sum(t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   639
    s = t1 + t2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   640
    t1 = t2 - (s -t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   641
    //[b3,t1] = fast_two_sum(t1,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   642
    b2[0] = t0 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   643
    t0 = s - (b2[0] - t0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   644
    b3[0] = t0 + t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   645
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   646
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   647
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   648
renorm4(double *c0Ptr, double *c1Ptr, double *c2Ptr, double *c3Ptr) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   649
    double s0, s1, s2 = 0.0, s3 = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   650
    double c0 = *c0Ptr;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   651
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   652
    if (isinf(c0)) return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   653
    fast_two_sum(&s0, c3Ptr, *c2Ptr, *c3Ptr);    // s0 = fast_two_sum(*c2Ptr, *c3Ptr, c3Ptr);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   654
    fast_two_sum(&s0, c2Ptr, *c1Ptr, s0);        // s0 = quick_two_sum(*c1Ptr, s0, c2Ptr);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   655
    fast_two_sum(&c0, c1Ptr, c0, s0);            // c0 = quick_two_sum(c0, s0, c1Ptr);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   656
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   657
    s0 = c0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   658
    s1 = *c1Ptr;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   659
    if (s1 != 0.0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   660
        fast_two_sum(&s1, &s2, s1, *c2Ptr);   // s1 = quick_two_sum(s1, *c2Ptr, &s2);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   661
        if (s2 != 0.0)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   662
            fast_two_sum(&s2, &s3, s2, *c3Ptr);   // s2 = quick_two_sum(s2, *c3Ptr, &s3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   663
        else
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   664
            fast_two_sum(&s1, &s2, s1, *c3Ptr);   // s1 = quick_two_sum(s1, *c3Ptr, &s2);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   665
    } else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   666
        fast_two_sum(&s0, &s1, s0, *c2Ptr);   // s0 = quick_two_sum(s0, *c2Ptr, &s1);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   667
        if (s1 != 0.0)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   668
            fast_two_sum(&s1, &s2, s1, *c3Ptr);   // s1 = quick_two_sum(s1, *c3Ptr, &s2);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   669
        else
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
   670
            fast_two_sum(&s0, &s1, s0, *c3Ptr);   // s0 = quick_two_sum(s0, *c3Ptr, &s1);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   671
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   672
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   673
    *c0Ptr = s0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   674
    *c1Ptr = s1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   675
    *c2Ptr = s2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   676
    *c3Ptr = s3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   677
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   678
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   679
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   680
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   681
// quad-double square
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   682
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   683
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   684
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   685
qd_sqr(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   686
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   687
    double p01,p11,p02,p03,p12,e00,e01,e11,e02,x,y,w,z,s0,s1,t0,t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   688
    c0[0] = 0.0; c1[0] = 0.0; c2[0] = 0.0; c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   689
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   690
    //O(1) term
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   691
    sqr(&x, &y, a0);                c0[0] = x;      e00 = y;        //O(1) term ok
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   692
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   693
    //O(eps) term
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   694
    two_prod(&x, &y, a0, a1);       p01 = 2.0*x;    e01 = 2.0*y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   695
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   696
    //O(eps^2) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   697
    two_prod(&x, &y, a0, a2);       p02 = 2.0*x;    e02 = 2.0*y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   698
    sqr(&x, &y, a1);                p11 = x;        e11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   699
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   700
    two_sum(&x, &y, p01, e00);      c1[0] = x;      e00 = y;                //O(eps) term ok
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   701
    two_sum(&x, &y, e00, e01);      e00 = x;        e01 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   702
    two_sum(&x, &y, p02, p11);      p02 = x;        p11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   703
    two_sum(&x, &y, e00, p02);      s0 = x;         t0 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   704
    two_sum(&x, &y, e01, p11);      s1 = x;         t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   705
    two_sum(&x, &y, s1, t0);        s1 = x;         t0 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   706
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   707
    t0 = t0 + t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   708
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   709
    fast_two_sum(&x, &y, s1, t0);   s1 = x;         t0 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   710
    fast_two_sum(&x, &y, s0, s1);   c2[0] = x;      t1 = y;         //O(eps^2) term ok
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   711
    fast_two_sum(&x, &y, t1, t0);   p11 = x;        e00 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   712
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   713
    //O(eps^3) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   714
    p03 = 2.0 * a0 * a3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   715
    p12 = 2.0 * a1 * a2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   716
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   717
    two_sum(&x, &y, p03, p12);      p03 = x;        p12 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   718
    two_sum(&x, &y, e02, e11);      e02 = x;        e11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   719
    two_sum(&x, &y, p03, e02);      t0 = x;         t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   720
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   721
    t1 = t1 + p12 + e11;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   722
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   723
    two_sum(&x, &y, p11, t0);       c3[0] = x;      p03 = y;                //O(eps^3) term ok
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   724
    p03 = p03 + e00 + t1;                                                   //O(eps^4) term ok
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   725
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   726
    renorm(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], p03);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   727
    c0[0] = x;      c1[0] = y;      c2[0] = w;      c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   728
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   729
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   730
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   731
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   732
// addition quad-double + double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   733
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   734
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   735
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   736
qd_add_s(double *o0, double *o1, double *o2, double *o3, double a0, double a1, double a2, double a3, double b)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   737
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   738
    double e,x,y,w,z;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   739
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   740
    c0 = 0.0; c1 = 0.0; c2 = 0.0; c3 = 0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   741
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   742
    two_sum(&x, &y, a0, b);         c0 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   743
    two_sum(&x, &y, a1, e);         c1 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   744
    two_sum(&x, &y, a2, e);         c2 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   745
    two_sum(&x, &y, a3, e);         c3 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   746
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   747
    o0[0] = x; o1[0] = y; o2[0] = w; o3[0] = z;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   748
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   749
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   750
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   751
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   752
// addition quad-double + double-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   753
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   754
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   755
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   756
qd_add_dd(double *o0, double *o1, double *o2, double *o3, double a0, double a1, double a2, double a3, double b0, double b1)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   757
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   758
    double e1,e2,x,y,w,z;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   759
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   760
    c0 = 0.0; c1 = 0.0; c2 = 0.0; c3 = 0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   761
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   762
    two_sum(&x, &y, a0, b0);    c0 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   763
    two_sum(&x, &y, a1, b1);    c1 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   764
    two_sum(&x, &y, c1, e1);    c1 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   765
    two_sum(&x, &y, a2, e2);    c2 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   766
    two_sum(&x, &y, c2, e1);    c2 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   767
    two_sum(&x, &y, e1, e2);    e1 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   768
    two_sum(&x, &y, a3, e1);    c3 = x;      e1 = y;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   769
    e1 = e1 + e2;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   770
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e1);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   771
    o0[0] = x;  o1[0] = y;      o2[0] = w;      o3[0] = z;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   772
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   773
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   774
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   775
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   776
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   777
// addition quad-double + quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   778
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   779
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   780
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   781
qd_add_qd(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3, double b0, double b1, double b2, double b3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   782
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   783
    double e1,e2,e3,e4,x,y,w,z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   784
    c0[0] = 0.0; c1[0] = 0.0; c2[0] = 0.0; c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   785
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   786
    two_sum(&x, &y, a0, b0);        c0[0] = x;      e1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   787
    two_sum(&x, &y, a1, b1);        c1[0] = x;      e2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   788
    two_sum(&x, &y, c1[0], e1);     c1[0] = x;      e1 = y;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   789
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   790
    two_sum(&x, &y, a2, b2);        c2[0] = x;      e3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   791
    three_sum(&x, &y, &z, c2[0], e2, e1);   c2[0] = x;      e1 = y; e2 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   792
    two_sum(&x, &y, a3, b3);        c3[0] = x;      e4 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   793
    three_sum2(&x, &y, c3[0], e3, e1);              c3[0] = x;      e1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   794
    e1 = e1 + e2 + e4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   795
    renorm(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], e1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   796
    c0[0] = x;      c1[0] = y;      c2[0] = w;      c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   797
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   798
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   799
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   800
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   801
// subtraction double - quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   802
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   803
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   804
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   805
s_sub_qd(double *o0, double *o1, double *o2, double *o3, double a, double b0, double b1, double b2, double b3)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   806
{
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   807
    double e,x,y,w,z;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   808
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   809
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   810
    e=0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   811
    c0 = 0.0; c1 = 0.0; c2 = 0.0; c3 = 0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   812
    b0=-b0; b1=-b1; b2=-b2; b3=-b3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   813
    two_sum(&x, &y, a, b0);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   814
    c0 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   815
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   816
    two_sum(&x, &y, b1, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   817
    c1 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   818
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   819
    two_sum(&x, &y, b2, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   820
    c2 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   821
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   822
    two_sum(&x, &y, b3, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   823
    c3 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   824
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   825
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   826
    o0[0] = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   827
    o1[0] = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   828
    o2[0] = w;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   829
    o3[0] = z;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   830
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   831
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   832
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   833
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   834
// subtraction quad-double - quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   835
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   836
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   837
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   838
qd_sub_qd(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3, double b0, double b1, double b2, double b3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   839
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   840
    double e1,e2,e3,e4,x,y,w,z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   841
    b0 = -b0; b1 = -b1;     b2 = -b2; b3 = -b3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   842
    c0[0] = 0.0; c1[0] = 0.0; c2[0] = 0.0; c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   843
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   844
    two_sum(&x, &y, a0, b0);        c0[0] = x;      e1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   845
    two_sum(&x, &y, a1, b1);        c1[0] = x;      e2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   846
    two_sum(&x, &y, c1[0], e1);     c1[0] = x;      e1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   847
    two_sum(&x, &y, a2, b2);        c2[0] = x;      e3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   848
    three_sum(&x, &y, &z, c2[0], e2, e1);   c2[0] = x;      e1 = y; e2 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   849
    two_sum(&x, &y, a3, b3);        c3[0] = x;      e4 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   850
    three_sum2(&x, &y, c3[0], e3, e1);              c3[0] = x;      e1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   851
    e1 = e1 + e2 + e4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   852
    renorm(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], e1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   853
    c0[0] = x;      c1[0] = y;      c2[0] = w;      c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   854
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   855
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   856
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   857
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   858
// multiplication double * quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   859
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   860
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   861
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   862
s_mul_qd(double *o0, double *o1, double *o2, double *o3, double b, double a0, double a1, double a2, double a3)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   863
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   864
    double e0,e1,e2,x,y,w,z;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   865
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   866
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   867
    c0 = 0.0; c1 = 0.0; c2 = 0.0; c3 = 0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   868
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   869
    two_prod(&x, &y, a0, b);            c0 = x;      e0 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   870
    two_prod(&x, &y, a1, b);            c1 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   871
    two_sum(&x, &y, c1, e0);            c1 = x;      e0 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   872
    two_prod(&x, &y, a2, b);            c2 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   873
    three_sum(&x, &y, &z, c2, e1, e0);  c2 = x;      e0 = y; e1 = z;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   874
    c3 = a3*b;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   875
    three_sum2(&x, &y, c3, e2, e0);     c3 = x;      e0 = y;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   876
    e0 = e0 + e1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   877
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   878
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e0);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   879
    o0[0] = x;      o1[0] = y;      o2[0] = w;      o3[0] = z;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   880
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   881
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   882
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   883
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   884
// multiplication quad-double * quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   885
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   886
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   887
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   888
qd_mul_qd(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3, double b0, double b1, double b2, double b3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   889
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   890
    double p10,p01,p11,p20,p02,e00,e10,e01,e11,e20,e02,x,y,w,z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   891
    c0[0] = 0.0; c1[0] = 0.0; c2[0] = 0.0; c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   892
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   893
    //O(1) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   894
    two_prod(&x, &y, a0, b0);       c0[0] = x;      e00 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   895
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   896
    //O(eps) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   897
    two_prod(&x, &y, a0, b1);       p01 = x;        e01 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   898
    two_prod(&x, &y, a1, b0);       p10 = x;        e10 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   899
    three_sum(&x, &y, &z, p01, p10, e00);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   900
    c1[0] = x;      //O(eps)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   901
    p10 = y;        //O(eps^2)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   902
    p01 = z;        //O(eps^3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   903
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   904
    //O(eps^2) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   905
    two_prod(&x, &y, a0, b2);       p02 = x;        e02 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   906
    two_prod(&x, &y, a1, b1);       p11 = x;        e11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   907
    two_prod(&x, &y, a2, b0);       p20 = x;        e20 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   908
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   909
    //six three sum for p10, e01, e10, p02, p11, p20
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   910
    three_sum(&x, &y, &z, p10, e01, e10);       p10 = x;        e01 = y;        e10 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   911
    three_sum(&x, &y, &z, p02, p11, p20);       p02 = x;        p11 = y;        p20 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   912
    two_sum(&x, &y, p02, p10);                  c2[0] = x;      p10 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   913
    two_sum(&x, &y, p11, e01);                  p11 = x;        e01 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   914
    two_sum(&x, &y, p10, p11);                  p10 = x;        p11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   915
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   916
    e10 = e10 + p20 + e01 + p11;    //O(eps^4) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   917
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   918
    //O(eps^3) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   919
    c3[0] = p10 + a0*b3 + a1*b2 + a2*b1 + a3*b0 + e02 + e11 + e20;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   920
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   921
    renorm(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], e10);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   922
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   923
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   924
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   925
    c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   926
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   927
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   928
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   929
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   930
// division quad-double / double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   931
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   932
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   933
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   934
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   935
qd_div_s(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3, double b)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   936
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   937
    double x,y,w,z,t0,t1,r0,r1,r2,r3,e;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   938
    c0[0] = 0.0; c1[0] = 0.0; c2[0] = 0.0; c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   939
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   940
    c0[0] = a0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   941
    // reminder a - c_0*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   942
    two_prod(&x, &y, c0[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   943
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   944
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   945
    //qd subtruction (a - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   946
    qd_add_dd(&x, &y, &w, &z, a0, a1, a2, a3, t0, t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   947
    r0 = x;     r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   948
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   949
    c1[0] = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   950
    // reminder r - c_1*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   951
    two_prod(&x, &y, c1[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   952
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   953
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   954
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   955
    qd_add_dd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   956
    r0 = x;     r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   957
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   958
    c2[0] = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   959
    // reminder r - c_2*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   960
    two_prod(&x, &y, c2[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   961
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   962
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   963
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   964
    qd_add_dd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   965
    r0 = x;     r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   966
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   967
    c3[0] = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   968
    // reminder r - c_3*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   969
    two_prod(&x, &y, c3[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   970
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   971
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   972
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   973
    qd_add_dd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   974
    r0 = x;     r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   975
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   976
    e = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   977
    renorm(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], e);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   978
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   979
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   980
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   981
    c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   982
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   983
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   984
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   985
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   986
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   987
// division quad-double / quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   988
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   989
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   990
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   991
qd_div_qd(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3, double b0, double b1, double b2, double b3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   992
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   993
    double x,y,w,z,t0,t1,t2,t3,r0,r1,r2,r3,e;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   994
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   995
    c0[0] = 0.0; c1[0] = 0.0; c2[0] = 0.0; c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   996
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   997
    c0[0] = a0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   998
    // reminder a - c_0*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   999
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1000
    s_mul_qd(&x, &y, &w, &z, c0[0], b0, b1, b2, b3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1001
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1002
    //qd subtruction (a - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1003
    qd_add_qd(&x, &y, &w, &z, a0, a1, a2, a3, t0, t1, t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1004
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1005
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1006
    c1[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1007
    // reminder r - c_1*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1008
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1009
    s_mul_qd(&x, &y, &w, &z, c1[0], b0, b1, b2, b3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1010
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1011
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1012
    qd_add_qd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1, t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1013
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1014
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1015
    c2[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1016
    // reminder r - c_2*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1017
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1018
    s_mul_qd(&x, &y, &w, &z, c2[0], b0, b1, b2, b3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1019
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1020
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1021
    qd_add_qd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1, t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1022
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1023
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1024
    c3[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1025
    // reminder r - c_3*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1026
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1027
    s_mul_qd(&x, &y, &w, &z, c3[0], b0, b1, b2, b3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1028
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1029
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1030
    qd_add_qd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1, t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1031
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1032
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1033
    e = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1034
    renorm(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], e);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1035
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1036
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1037
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1038
    c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1039
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1040
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1041
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1042
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1043
// division double / quad-double sloppy
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1044
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1045
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1046
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1047
s_div_qd(double *c0, double *c1, double *c2, double *c3, double a, double b0, double b1, double b2, double b3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1048
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1049
    double x,y,w,z,t0,t1,t2,t3,r0,r1,r2,r3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1050
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1051
    c0[0] = 0.0; c1[0] = 0.0; c2[0] = 0.0; c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1052
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1053
    c0[0] = a/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1054
    // reminder a - c_0*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1055
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1056
    s_mul_qd(&x, &y, &w, &z, c0[0], b0, b1, b2, b3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1057
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1058
    //qd subtruction (a - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1059
    qd_add_s(&x, &y, &w, &z, t0, t1, t2, t3, a);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1060
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1061
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1062
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1063
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1064
    c1[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1065
    // reminder r - c_1*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1066
    s_mul_qd(&x, &y, &w, &z, c1[0], b0, b1, b2, b3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1067
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1068
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1069
    qd_add_qd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1, t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1070
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1071
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1072
    c2[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1073
    // reminder r - c_2*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1074
    s_mul_qd(&x, &y, &w, &z, c2[0], b0, b1, b2, b3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1075
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1076
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1077
    qd_add_qd(&x, &y, &w, &z, r0, r1, r2, r3, t0, t1, t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1078
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1079
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1080
    c3[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1081
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1082
    renorm(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], 0.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1083
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1084
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1085
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1086
    c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1087
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1088
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1089
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1090
qd_sqrt(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1091
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1092
    double h0,h1,h2,h3,x0,x1,x2,x3,p,q,r,s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1093
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1094
    c0[0] = 0.0;    c1[0] = 0.0;    c2[0] = 0.0;    c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1095
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1096
    c0[0] = 1.0/sqrt(a0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1097
    h0 = 0.5*a0;    h1 = 0.5*a1;    h2 = 0.5*a2;    h3 = 0.5*a3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1098
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1099
    qd_sqr(&x0, &x1, &x2, &x3, c0[0], c1[0], c2[0], c3[0]);                                 //x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1100
    qd_mul_qd(&p, &q, &r, &s, h0, h1, h2, h3, x0, x1, x2, x3);                              //0.5 * a * x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1101
    x0 = -p;        x1 = -q;        x2 = -r;        x3 = -s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1102
    qd_add_s(&p, &q, &r, &s, x0, x1, x2, x3, 0.5);                                                  //0.5 - 0.5 * a * x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1103
    qd_mul_qd(&x0, &x1, &x2, &x3, p, q, r, s, c0[0], c1[0], c2[0], c3[0]);  //(0.5 - 0.5 * a * x_k^2)*x_k
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1104
    qd_add_qd(&p, &q, &r, &s, c0[0], c1[0], c2[0], c3[0], x0, x1, x2, x3);  //x_k+1 = x_k + (0.5 - 0.5 * a * x_k^2)*x_k
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1105
    c0[0] = p; c1[0] = q; c2[0] = r; c3[0] = s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1106
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1107
    qd_sqr(&x0, &x1, &x2, &x3, c0[0], c1[0], c2[0], c3[0]);                                 //x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1108
    qd_mul_qd(&p, &q, &r, &s, h0, h1, h2, h3, x0, x1, x2, x3);                              //0.5 * a * x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1109
    x0 = -p;        x1 = -q;        x2 = -r;        x3 = -s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1110
    qd_add_s(&p, &q, &r, &s, x0, x1, x2, x3, 0.5);                                                  //0.5 - 0.5 * a * x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1111
    qd_mul_qd(&x0, &x1, &x2, &x3, p, q, r, s, c0[0], c1[0], c2[0], c3[0]);  //(0.5 - 0.5 * a * x_k^2)*x_k
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1112
    qd_add_qd(&p, &q, &r, &s, c0[0], c1[0], c2[0], c3[0], x0, x1, x2, x3);  //x_k+1 = x_k + (0.5 - 0.5 * a * x_k^2)*x_k
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1113
    c0[0] = p; c1[0] = q; c2[0] = r; c3[0] = s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1114
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1115
    qd_sqr(&x0, &x1, &x2, &x3, c0[0], c1[0], c2[0], c3[0]);                                 //x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1116
    qd_mul_qd(&p, &q, &r, &s, h0, h1, h2, h3, x0, x1, x2, x3);                              //0.5 * a * x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1117
    x0 = -p;        x1 = -q;        x2 = -r;        x3 = -s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1118
    qd_add_s(&p, &q, &r, &s, x0, x1, x2, x3, 0.5);                                                  //0.5 - 0.5 * a * x_k^2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1119
    qd_mul_qd(&x0, &x1, &x2, &x3, p, q, r, s, c0[0], c1[0], c2[0], c3[0]);  //(0.5 - 0.5 * a * x_k^2)*x_k
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1120
    qd_add_qd(&p, &q, &r, &s, c0[0], c1[0], c2[0], c3[0], x0, x1, x2, x3);  //x_k+1 = x_k + (0.5 - 0.5 * a * x_k^2)*x_k
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1121
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1122
    qd_mul_qd(&x0, &x1, &x2, &x3, a0, a1, a2, a3, p, q, r, s);      //(0.5 - 0.5 * a * x_k^2)*x_k*a
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1123
    c0[0] = x0; c1[0] = x1; c2[0] = x2; c3[0] = x3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1124
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1125
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1126
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1127
qd_pow(double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3, int p)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1128
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1129
    double r0,r1,r2,r3,x,y,w,z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1130
    int abs_p;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1131
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1132
    c0[0] = 0.0;        c1[0] = 0.0;    c2[0] = 0.0;    c3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1133
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1134
    if (p == 0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1135
        c0[0] = 1.0;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1136
    } else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1137
        r0 = a0; r1 = a1; r2 = a2; r3 = a3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1138
        c0[0] = 1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1139
        abs_p = abs(p);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1140
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1141
        if (abs_p > 1) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1142
            while (abs_p > 0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1143
                if ((abs_p % 2)==1) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1144
                    qd_mul_qd(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], r0, r1, r2, r3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1145
                    c0[0] = x;  c1[0] = y;      c2[0] = w;      c3[0] = z;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1146
                }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1147
                abs_p = abs_p / 2;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1148
                if (abs_p > 0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1149
                    qd_sqr(&x, &y, &w, &z, r0, r1, r2, r3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1150
                    r0 = x; r1 = y; r2 = w; r3 = z;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1151
                }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1152
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1153
        } else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1154
            c0[0] = r0; c1[0] = r1;     c2[0] = r2;     c3[0] = r3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1155
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1156
        if (p < 0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1157
            s_div_qd(&x, &y, &w, &z, 1.0, c0[0], c1[0], c2[0], c3[0]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1158
            c0[0] = x;  c1[0] = y;      c2[0] = w;      c3[0] = z;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1159
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1160
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1161
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1162
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1163
// round to nearest integer
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1164
#define round(x)  (floor((x)+0.5))
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1165
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1166
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1167
nint_qd(double *x0, double *x1, double *x2, double *x3, double a0, double a1, double a2, double a3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1168
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1169
    x0[0]=round(a0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1170
    x1[0]=0.0; x2[0]=0.0; x3[0]=0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1171
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1172
    if(x0[0]==a0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1173
        x1[0]=round(a1);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1174
        if(x1[0]==a1) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1175
            x2[0]=round(a2);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1176
            if(x2[0]==a2) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1177
                x3[0]=round(a3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1178
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1179
            else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1180
                if(((int)fabs(x2[0]-a2)==0.5) && (a3<0.0)) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1181
                    x2[0]=x2[0]-1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1182
                }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1183
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1184
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1185
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1186
            if(((int)fabs(x1[0]-a1)==0.5) && (a2<0.0)) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1187
                x1[0]=x1[0]-1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1188
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1189
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1190
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1191
    else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1192
        if(((int)fabs(x0[0]-a0)==0.5) && (a1<0.0)) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1193
            x0[0]=x0[0]-1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1194
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1195
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1196
    renorm(&x0[0],&x1[0],&x2[0],&x3[0],x0[0],x1[0],x2[0],x3[0],0.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1197
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1198
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1199
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1200
static double s_table[256][4]= {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1201
    {3.0679567629659761e-03, 1.2690279085455925e-19,       5.2879464245328389e-36, -1.7820334081955298e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1202
    {6.1358846491544753e-03, 9.0545257482474933e-20,       1.6260113133745320e-37, -9.7492001208767410e-55},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1203
    {9.2037547820598194e-03, -1.2136591693535934e-19,       5.5696903949425567e-36, 1.2505635791936951e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1204
    {1.2271538285719925e-02, 6.9197907640283170e-19,       -4.0203726713435555e-36, -2.0688703606952816e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1205
    {1.5339206284988102e-02, -8.4462578865401696e-19,       4.6535897505058629e-35, -1.3923682978570467e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1206
    {1.8406729905804820e-02, 7.4195533812833160e-19,       3.9068476486787607e-35, 3.6393321292898614e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1207
    {2.1474080275469508e-02, -4.5407960207688566e-19,       -2.2031770119723005e-35, 1.2709814654833741e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1208
    {2.4541228522912288e-02, -9.1868490125778782e-20,       4.8706148704467061e-36, -2.8153947855469224e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1209
    {2.7608145778965743e-02, -1.5932358831389269e-18,       -7.0475416242776030e-35, -2.7518494176602744e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1210
    {3.0674803176636626e-02, -1.6936054844107918e-20,       -2.0039543064442544e-36, -1.6267505108658196e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1211
    {3.3741171851377587e-02, -2.0096074292368340e-18,       -1.3548237016537134e-34, 6.5554881875899973e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1212
    {3.6807222941358832e-02, 6.1060088803529842e-19,       -4.0448721259852727e-35, -2.1111056765671495e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1213
    {3.9872927587739811e-02, 4.6657453481183289e-19,       3.4119333562288684e-35, 2.4007534726187511e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1214
    {4.2938256934940820e-02, 2.8351940588660907e-18,       1.6991309601186475e-34, 6.8026536098672629e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1215
    {4.6003182130914630e-02, -1.1182813940157788e-18,       7.5235020270378946e-35, 4.1187304955493722e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1216
    {4.9067674327418015e-02, -6.7961037205182801e-19,       -4.4318868124718325e-35, -9.9376628132525316e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1217
    {5.2131704680283324e-02, -2.4243695291953779e-18,       -1.3675405320092298e-34, -8.3938137621145070e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1218
    {5.5195244349689941e-02, -1.3340299860891103e-18,       -3.4359574125665608e-35, 1.1911462755409369e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1219
    {5.8258264500435759e-02, 2.3299905496077492e-19,       1.9376108990628660e-36, -5.1273775710095301e-53},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1220
    {6.1320736302208578e-02, -5.1181134064638108e-19,       -4.2726335866706313e-35, 2.6368495557440691e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1221
    {6.4382630929857465e-02, -4.2325997000052705e-18,       3.3260117711855937e-35, 1.4736267706718352e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1222
    {6.7443919563664065e-02, -6.9221796556983636e-18,       1.5909286358911040e-34, -7.8828946891835218e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1223
    {7.0504573389613870e-02, -6.8552791107342883e-18,       -1.9961177630841580e-34, 2.0127129580485300e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1224
    {7.3564563599667426e-02, -2.7784941506273593e-18,       -9.1240375489852821e-35, -1.9589752023546795e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1225
    {7.6623861392031492e-02, 2.3253700287958801e-19,       -1.3186083921213440e-36, -4.9927872608099673e-53},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1226
    {7.9682437971430126e-02, -4.4867664311373041e-18,       2.8540789143650264e-34, 2.8491348583262741e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1227
    {8.2740264549375692e-02, 1.4735983530877760e-18,       3.7284093452233713e-35, 2.9024430036724088e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1228
    {8.5797312344439894e-02, -3.3881893830684029e-18,       -1.6135529531508258e-34, 7.7294651620588049e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1229
    {8.8853552582524600e-02, -3.7501775830290691e-18,       3.7543606373911573e-34, 2.2233701854451859e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1230
    {9.1908956497132724e-02, 4.7631594854274564e-18,       1.5722874642939344e-34, -4.8464145447831456e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1231
    {9.4963495329639006e-02, -6.5885886400417564e-18,       -2.1371116991641965e-34, 1.3819370559249300e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1232
    {9.8017140329560604e-02, -1.6345823622442560e-18,       -1.3209238810006454e-35, -3.5691060049117942e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1233
    {1.0106986275482782e-01, 3.3164325719308656e-18,       -1.2004224885132282e-34, 7.2028828495418631e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1234
    {1.0412163387205457e-01, 6.5760254085385100e-18,       1.7066246171219214e-34, -4.9499340996893514e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1235
    {1.0717242495680884e-01, 6.4424044279026198e-18,       -8.3956976499698139e-35, -4.0667730213318321e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1236
    {1.1022220729388306e-01, -5.6789503537823233e-19,       1.0380274792383233e-35, 1.5213997918456695e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1237
    {1.1327095217756435e-01, 2.7100481012132900e-18,       1.5323292999491619e-35, 4.9564432810360879e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1238
    {1.1631863091190477e-01, 1.0294914877509705e-18,       -9.3975734948993038e-35, 1.3534827323719708e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1239
    {1.1936521481099137e-01, -3.9500089391898506e-18,       3.5317349978227311e-34, 1.8856046807012275e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1240
    {1.2241067519921620e-01, 2.8354501489965335e-18,       1.8151655751493305e-34, -2.8716592177915192e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1241
    {1.2545498341154623e-01, 4.8686751763148235e-18,       5.9878105258097936e-35, -3.3534629098722107e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1242
    {1.2849811079379317e-01, 3.8198603954988802e-18,       -1.8627501455947798e-34, -2.4308161133527791e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1243
    {1.3154002870288312e-01, -5.0039708262213813e-18,       -1.2983004159245552e-34, -4.6872034915794122e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1244
    {1.3458070850712620e-01, -9.1670359171480699e-18,       1.5916493007073973e-34, 4.0237002484366833e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1245
    {1.3762012158648604e-01, 6.6253255866774482e-18,       -2.3746583031401459e-34, -9.3703876173093250e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1246
    {1.4065823933284924e-01, -7.9193932965524741e-18,       6.0972464202108397e-34, 2.4566623241035797e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1247
    {1.4369503315029444e-01, 1.1472723016618666e-17,       -5.1884954557576435e-35, -4.2220684832186607e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1248
    {1.4673047445536175e-01, 3.7269471470465677e-18,       3.7352398151250827e-34, -4.0881822289508634e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1249
    {1.4976453467732151e-01, 8.0812114131285151e-18,       1.2979142554917325e-34, 9.9380667487736254e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1250
    {1.5279718525844344e-01, -7.6313573938416838e-18,       5.7714690450284125e-34, -3.7731132582986687e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1251
    {1.5582839765426523e-01, 3.0351307187678221e-18,       -1.0976942315176184e-34, 7.8734647685257867e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1252
    {1.5885814333386145e-01, -4.0163200573859079e-18,       -9.2840580257628812e-35, -2.8567420029274875e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1253
    {1.6188639378011183e-01, 1.1850519643573528e-17,       -5.0440990519162957e-34, 3.0510028707928009e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1254
    {1.6491312048996992e-01, -7.0405288319166738e-19,       3.3211107491245527e-35, 8.6663299254686031e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1255
    {1.6793829497473117e-01, 5.4284533721558139e-18,       -3.3263339336181369e-34, -1.8536367335123848e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1256
    {1.7096188876030122e-01, 9.1919980181759094e-18,       -6.7688743940982606e-34, -1.0377711384318389e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1257
    {1.7398387338746382e-01, 5.8151994618107928e-18,       -1.6751014298301606e-34, -6.6982259797164963e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1258
    {1.7700422041214875e-01, 6.7329300635408167e-18,       2.8042736644246623e-34, 3.6786888232793599e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1259
    {1.8002290140569951e-01, 7.9701826047392143e-18,       -7.0765920110524977e-34, 1.9622512608461784e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1260
    {1.8303988795514095e-01, 7.7349918688637383e-18,       -4.4803769968145083e-34, 1.1201148793328890e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1261
    {1.8605515166344666e-01, -1.2564893007679552e-17,       7.5953844248530810e-34, -3.8471695132415039e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1262
    {1.8906866414980622e-01, -7.6208955803527778e-18,       -4.4792298656662981e-34, -4.4136824096645007e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1263
    {1.9208039704989244e-01, 4.3348343941174903e-18,       -2.3404121848139937e-34, 1.5789970962611856e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1264
    {1.9509032201612828e-01, -7.9910790684617313e-18,       6.1846270024220713e-34, -3.5840270918032937e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1265
    {1.9809841071795359e-01, -1.8434411800689445e-18,       1.4139031318237285e-34, 1.0542811125343809e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1266
    {2.0110463484209190e-01, 1.1010032669300739e-17,       -3.9123576757413791e-34, 2.4084852500063531e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1267
    {2.0410896609281687e-01, 6.0941297773957752e-18,       -2.8275409970449641e-34, 4.6101008563532989e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1268
    {2.0711137619221856e-01, -1.0613362528971356e-17,       2.2456805112690884e-34, 1.3483736125280904e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1269
    {2.1011183688046961e-01, 1.1561548476512844e-17,       6.0355905610401254e-34, 3.3329909618405675e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1270
    {2.1311031991609136e-01, 1.2031873821063860e-17,       -3.4142699719695635e-34, -1.2436262780241778e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1271
    {2.1610679707621952e-01, -1.0111196082609117e-17,       7.2789545335189643e-34, -2.9347540365258610e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1272
    {2.1910124015686980e-01, -3.6513812299150776e-19,       -2.3359499418606442e-35, 3.1785298198458653e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1273
    {2.2209362097320354e-01, -3.0337210995812162e-18,       6.6654668033632998e-35, 2.0110862322656942e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1274
    {2.2508391135979283e-01, 3.9507040822556510e-18,       2.4287993958305375e-35, 5.6662797513020322e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1275
    {2.2807208317088573e-01, 8.2361837339258012e-18,       6.9786781316397937e-34, -6.4122962482639504e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1276
    {2.3105810828067111e-01, 1.0129787149761869e-17,       -6.9359234615816044e-34, -2.8877355604883782e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1277
    {2.3404195858354343e-01, -6.9922402696101173e-18,       -5.7323031922750280e-34, 5.3092579966872727e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1278
    {2.3702360599436720e-01, 8.8544852285039918e-18,       1.3588480826354134e-34, 1.0381022520213867e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1279
    {2.4000302244874150e-01, -1.2137758975632164e-17,       -2.6448807731703891e-34, -1.9929733800670473e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1280
    {2.4298017990326390e-01, -8.7514315297196632e-18,       -6.5723260373079431e-34, -1.0333158083172177e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1281
    {2.4595505033579462e-01, -1.1129044052741832e-17,       4.3805998202883397e-34, 1.2219399554686291e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1282
    {2.4892760574572018e-01, -8.1783436100020990e-18,       5.5666875261111840e-34, 3.8080473058748167e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1283
    {2.5189781815421697e-01, -1.7591436032517039e-17,       -1.0959681232525285e-33, 5.6209426020232456e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1284
    {2.5486565960451457e-01, -1.3602299806901461e-19,       -6.0073844642762535e-36, -3.0072751311893878e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1285
    {2.5783110216215899e-01, 1.8480038630879957e-17,       3.3201664714047599e-34, -5.5547819290576764e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1286
    {2.6079411791527551e-01, 4.2721420983550075e-18,       5.6782126934777920e-35, 3.1428338084365397e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1287
    {2.6375467897483140e-01, -1.8837947680038700e-17,       1.3720129045754794e-33, -8.2763406665966033e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1288
    {2.6671275747489837e-01, 2.0941222578826688e-17,       -1.1303466524727989e-33, 1.9954224050508963e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1289
    {2.6966832557291509e-01, 1.5765657618133259e-17,       -6.9696142173370086e-34, -4.0455346879146776e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1290
    {2.7262135544994898e-01, 7.8697166076387850e-18,       6.6179388602933372e-35, -2.7642903696386267e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1291
    {2.7557181931095814e-01, 1.9320328962556582e-17,       1.3932094180100280e-33, 1.3617253920018116e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1292
    {2.7851968938505312e-01, -1.0030273719543544e-17,       7.2592115325689254e-34, -1.0068516296655851e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1293
    {2.8146493792575800e-01, -1.2322299641274009e-17,       -1.0564788706386435e-34, 7.5137424251265885e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1294
    {2.8440753721127182e-01, 2.2209268510661475e-17,       -9.1823095629523708e-34, -5.2192875308892218e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1295
    {2.8734745954472951e-01, 1.5461117367645717e-17,       -6.3263973663444076e-34, -2.2982538416476214e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1296
    {2.9028467725446239e-01, -1.8927978707774251e-17,       1.1522953157142315e-33, 7.4738655654716596e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1297
    {2.9321916269425863e-01, 2.2385430811901833e-17,       1.3662484646539680e-33, -4.2451325253996938e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1298
    {2.9615088824362384e-01, -2.0220736360876938e-17,       -7.9252212533920413e-35, -2.8990577729572470e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1299
    {2.9907982630804048e-01, 1.6701181609219447e-18,       8.6091151117316292e-35, 3.9931286230012102e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1300
    {3.0200594931922808e-01, -1.7167666235262474e-17,       2.3336182149008069e-34, 8.3025334555220004e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1301
    {3.0492922973540243e-01, -2.2989033898191262e-17,       -1.4598901099661133e-34, 3.7760487693121827e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1302
    {3.0784964004153487e-01, 2.7074088527245185e-17,       1.2568858206899284e-33, 7.2931815105901645e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1303
    {3.1076715274961147e-01, 2.0887076364048513e-17,       -3.0130590791065942e-34, 1.3876739009935179e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1304
    {3.1368174039889146e-01, 1.4560447299968912e-17,       3.6564186898011595e-34, 1.1654264734999375e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1305
    {3.1659337555616585e-01, 2.1435292512726283e-17,       1.2338169231377316e-33, 3.3963542100989293e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1306
    {3.1950203081601569e-01, -1.3981562491096626e-17,       8.1730000697411350e-34, -7.7671096270210952e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1307
    {3.2240767880106985e-01, -4.0519039937959398e-18,       3.7438302780296796e-34, 8.7936731046639195e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1308
    {3.2531029216226293e-01, 7.9171249463765892e-18,       -6.7576622068146391e-35, 2.3021655066929538e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1309
    {3.2820984357909255e-01, -2.6693140719641896e-17,       7.8928851447534788e-34, 2.5525163821987809e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1310
    {3.3110630575987643e-01, -2.7469465474778694e-17,       -1.3401245916610206e-33, 6.5531762489976163e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1311
    {3.3399965144200938e-01, 2.2598986806288142e-17,       7.8063057192586115e-34, 2.0427600895486683e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1312
    {3.3688985339222005e-01, -4.2000940033475092e-19,       -2.9178652969985438e-36, -1.1597376437036749e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1313
    {3.3977688440682685e-01, 6.6028679499418282e-18,       1.2575009988669683e-34, 2.5569067699008304e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1314
    {3.4266071731199438e-01, 1.9261518449306319e-17,       -9.2754189135990867e-34, 8.5439996687390166e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1315
    {3.4554132496398904e-01, 2.7251143672916123e-17,       7.0138163601941737e-34, -1.4176292197454015e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1316
    {3.4841868024943456e-01, 3.6974420514204918e-18,       3.5532146878499996e-34, 1.9565462544501322e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1317
    {3.5129275608556715e-01, -2.2670712098795844e-17,       -1.6994216673139631e-34, -1.2271556077284517e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1318
    {3.5416352542049040e-01, -1.6951763305764860e-17,       1.2772331777814617e-33, -3.3703785435843310e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1319
    {3.5703096123343003e-01, -4.8218191137919166e-19,       -4.1672436994492361e-35, -7.1531167149364352e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1320
    {3.5989503653498817e-01, -1.7601687123839282e-17,       1.3375125473046791e-33, 7.9467815593584340e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1321
    {3.6275572436739723e-01, -9.1668352663749849e-18,       -7.4317843956936735e-34, -2.0199582511804564e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1322
    {3.6561299780477385e-01, 1.6217898770457546e-17,       1.1286970151961055e-33, -7.1825287318139010e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1323
    {3.6846682995337232e-01, 1.0463640796159268e-17,       2.0554984738517304e-35, 1.0441861305618769e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1324
    {3.7131719395183754e-01, 3.4749239648238266e-19,       -7.5151053042866671e-37, -2.8153468438650851e-53},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1325
    {3.7416406297145799e-01, 8.0114103761962118e-18,       5.3429599813406052e-34, 1.0351378796539210e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1326
    {3.7700741021641826e-01, -2.7255302041956930e-18,       6.3646586445018137e-35, 8.3048657176503559e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1327
    {3.7984720892405116e-01, 9.9151305855172370e-18,       4.8761409697224886e-34, 1.4025084000776705e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1328
    {3.8268343236508978e-01, -1.0050772696461588e-17,       -2.0605316302806695e-34, -1.2717724698085205e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1329
    {3.8551605384391885e-01, 1.5177665396472313e-17,       1.4198230518016535e-33, 5.8955167159904235e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1330
    {3.8834504669882630e-01, -1.0053770598398717e-17,       7.5942999255057131e-34, -3.1967974046654219e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1331
    {3.9117038430225387e-01, 1.7997787858243995e-17,       -1.0613482402609856e-33, -5.4582148817791032e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1332
    {3.9399204006104810e-01, 9.7649241641239336e-18,       -2.1233599441284617e-34, -5.5529836795340819e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1333
    {3.9680998741671031e-01, 2.0545063670840126e-17,       6.1347058801922842e-34, 1.0733788150636430e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1334
    {3.9962419984564684e-01, -1.5065497476189372e-17,       -9.9653258881867298e-34, -5.7524323712725355e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1335
    {4.0243465085941843e-01, 1.0902619339328270e-17,       7.3998528125989765e-34, 2.2745784806823499e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1336
    {4.0524131400498986e-01, 9.9111401942899884e-18,       -2.5169070895434648e-34, 9.2772984818436573e-53},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1337
    {4.0804416286497869e-01, -7.0006015137351311e-18,       -1.4108207334268228e-34, 1.5175546997577136e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1338
    {4.1084317105790397e-01, -2.4219835190355499e-17,       -1.1418902925313314e-33, -2.0996843165093468e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1339
    {4.1363831223843456e-01, -1.0393984940597871e-17,       -1.1481681174503880e-34, -2.0281052851028680e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1340
    {4.1642956009763721e-01, -2.5475580413131732e-17,       -3.4482678506112824e-34, 7.1788619351865480e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1341
    {4.1921688836322396e-01, -4.2232463750110590e-18,       -3.6053023045255790e-34, -2.2209673210025631e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1342
    {4.2200027079979968e-01, 4.3543266994128527e-18,       3.1734310272251190e-34, -1.3573247980738668e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1343
    {4.2477968120910881e-01, 2.7462312204277281e-17,       -4.6552847802111948e-34, 6.5961781099193122e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1344
    {4.2755509343028208e-01, 9.4111898162954726e-18,       -1.7446682426598801e-34, -2.2054492626480169e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1345
    {4.3032648134008261e-01, 2.2259686974092690e-17,       8.5972591314085075e-34, -2.9420897889003020e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1346
    {4.3309381885315196e-01, 1.1224283329847517e-17,       5.3223748041075651e-35, 5.3926192627014212e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1347
    {4.3585707992225547e-01, 1.6230515450644527e-17,       -6.4371449063579431e-35, -6.9102436481386757e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1348
    {4.3861623853852766e-01, -2.0883315831075090e-17,       -1.4259583540891877e-34, 6.3864763590657077e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1349
    {4.4137126873171667e-01, 2.2360783886964969e-17,       1.1864769603515770e-34, -3.8087003266189232e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1350
    {4.4412214457042926e-01, -2.4218874422178315e-17,       2.2205230838703907e-34, 9.2133035911356258e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1351
    {4.4686884016237421e-01, -1.9222136142309382e-17,       -4.4425678589732049e-35, -1.3673609292149535e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1352
    {4.4961132965460660e-01, 4.8831924232035243e-18,       2.7151084498191381e-34, -1.5653993171613154e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1353
    {4.5234958723377089e-01, -1.4827977472196122e-17,       -7.6947501088972324e-34, 1.7656856882031319e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1354
    {4.5508358712634384e-01, -1.2379906758116472e-17,       5.5289688955542643e-34, -8.5382312840209386e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1355
    {4.5781330359887723e-01, -8.4554254922295949e-18,       -6.3770394246764263e-34, 3.1778253575564249e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1356
    {4.6053871095824001e-01, 1.8488777492177872e-17,       -1.0527732154209725e-33, 3.3235593490947102e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1357
    {4.6325978355186020e-01, -7.3514924533231707e-18,       6.7175396881707035e-34, 3.9594127612123379e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1358
    {4.6597649576796618e-01, -3.3023547778235135e-18,       3.4904677050476886e-35, 3.4483855263874246e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1359
    {4.6868882203582796e-01, -2.2949251681845054e-17,       -1.1364757641823658e-33, 6.8840522501918612e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1360
    {4.7139673682599764e-01, 6.5166781360690130e-18,       2.9457546966235984e-34, -6.2159717738836630e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1361
    {4.7410021465055002e-01, -8.1451601548978075e-18,       -3.4789448555614422e-34, -1.1681943974658508e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1362
    {4.7679923006332214e-01, -1.0293515338305794e-17,       -3.6582045008369952e-34, 1.7424131479176475e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1363
    {4.7949375766015301e-01, 1.8419999662684771e-17,       -1.3040838621273312e-33, 1.0977131822246471e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1364
    {4.8218377207912277e-01, -2.5861500925520442e-17,       -6.2913197606500007e-36, 4.0802359808684726e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1365
    {4.8486924800079112e-01, -1.8034004203262245e-17,       -3.5244276906958044e-34, -1.7138318654749246e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1366
    {4.8755016014843594e-01, 1.4231090931273653e-17,       -1.8277733073262697e-34, -1.5208291790429557e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1367
    {4.9022648328829116e-01, -5.1496145643440404e-18,       -3.6903027405284104e-34, 1.5172940095151304e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1368
    {4.9289819222978404e-01, -1.0257831676562186e-18,       6.9520817760885069e-35, -2.4260961214090389e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1369
    {4.9556526182577254e-01, -9.4323241942365362e-18,       3.1212918657699143e-35, 4.2009072375242736e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1370
    {4.9822766697278187e-01, -1.6126383830540798e-17,       -1.5092897319298871e-33, 1.1049298890895917e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1371
    {5.0088538261124083e-01, -3.9604015147074639e-17,       -2.2208395201898007e-33, 1.3648202735839417e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1372
    {5.0353838372571758e-01, -1.6731308204967497e-17,       -1.0140233644074786e-33, 4.0953071937671477e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1373
    {5.0618664534515534e-01, -4.8321592986493711e-17,       9.2858107226642252e-34, 4.2699802401037005e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1374
    {5.0883014254310699e-01, 4.7836968268014130e-17,       -1.0727022928806035e-33, 2.7309374513672757e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1375
    {5.1146885043797041e-01, -1.3088001221007579e-17,       4.0929033363366899e-34, -3.7952190153477926e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1376
    {5.1410274419322177e-01, -4.5712707523615624e-17,       1.5488279442238283e-33, -2.5853959305521130e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1377
    {5.1673179901764987e-01, 8.3018617233836515e-18,       5.8251027467695202e-34, -2.2812397190535076e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1378
    {5.1935599016558964e-01, -5.5331248144171145e-17,       -3.1628375609769026e-35, -2.4091972051188571e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1379
    {5.2197529293715439e-01, -4.6555795692088883e-17,       4.6378980936850430e-34, -3.3470542934689532e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1380
    {5.2458968267846895e-01, -4.3068869040082345e-17,       -4.2013155291932055e-34, -1.5096069926700274e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1381
    {5.2719913478190139e-01, -4.2202983480560619e-17,       8.5585916184867295e-34, 7.9974339336732307e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1382
    {5.2980362468629472e-01, -4.8067841706482342e-17,       5.8309721046630296e-34, -8.9740761521756660e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1383
    {5.3240312787719801e-01, -4.1020306135800895e-17,       -1.9239996374230821e-33, -1.5326987913812184e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1384
    {5.3499761988709726e-01, -5.3683132708358134e-17,       -1.3900569918838112e-33, 2.7154084726474092e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1385
    {5.3758707629564551e-01, -2.2617365388403054e-17,       -5.9787279033447075e-34, 3.1204419729043625e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1386
    {5.4017147272989285e-01, 2.7072447965935839e-17,       1.1698799709213829e-33, -5.9094668515881500e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1387
    {5.4275078486451589e-01, 1.7148261004757101e-17,       -1.3525905925200870e-33, 4.9724411290727323e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1388
    {5.4532498842204646e-01, -4.1517817538384258e-17,       -1.5318930219385941e-33, 6.3629921101413974e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1389
    {5.4789405917310019e-01, -2.4065878297113363e-17,       -3.5639213669362606e-36, -2.6013270854271645e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1390
    {5.5045797293660481e-01, -8.3319903015807663e-18,       -2.3058454035767633e-34, -2.1611290432369010e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1391
    {5.5301670558002758e-01, -4.7061536623798204e-17,       -1.0617111545918056e-33, -1.6196316144407379e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1392
    {5.5557023301960218e-01, 4.7094109405616768e-17,       -2.0640520383682921e-33, 1.2290163188567138e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1393
    {5.5811853122055610e-01, 1.3481176324765226e-17,       -5.5016743873011438e-34, -2.3484822739335416e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1394
    {5.6066157619733603e-01, -7.3956418153476152e-18,       3.9680620611731193e-34, 3.1995952200836223e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1395
    {5.6319934401383409e-01, 2.3835775146854829e-17,       1.3511793173769814e-34, 9.3201311581248143e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1396
    {5.6573181078361323e-01, -3.4096079596590466e-17,       -1.7073289744303546e-33, 8.9147089975404507e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1397
    {5.6825895267013160e-01, -5.0935673642769248e-17,       -1.6274356351028249e-33, 9.8183151561702966e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1398
    {5.7078074588696726e-01, 2.4568151455566208e-17,       -1.2844481247560350e-33, -1.8037634376936261e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1399
    {5.7329716669804220e-01, 8.5176611669306400e-18,       -6.4443208788026766e-34, 2.2546105543273003e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1400
    {5.7580819141784534e-01, -3.7909495458942734e-17,       -2.7433738046854309e-33, 1.1130841524216795e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1401
    {5.7831379641165559e-01, -2.6237691512372831e-17,       1.3679051680738167e-33, -3.1409808935335900e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1402
    {5.8081395809576453e-01, 1.8585338586613408e-17,       2.7673843114549181e-34, 1.9605349619836937e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1403
    {5.8330865293769829e-01, 3.4516601079044858e-18,       1.8065977478946306e-34, -6.3953958038544646e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1404
    {5.8579785745643886e-01, -3.7485501964311294e-18,       2.7965403775536614e-34, -7.1816936024157202e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1405
    {5.8828154822264533e-01, -2.9292166725006846e-17,       -2.3744954603693934e-33, -1.1571631191512480e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1406
    {5.9075970185887428e-01, -4.7013584170659542e-17,       2.4808417611768356e-33, 1.2598907673643198e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1407
    {5.9323229503979980e-01, 1.2892320944189053e-17,       5.3058364776359583e-34, 4.1141674699390052e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1408
    {5.9569930449243336e-01, -1.3438641936579467e-17,       -6.7877687907721049e-35, -5.6046937531684890e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1409
    {5.9816070699634227e-01, 3.8801885783000657e-17,       -1.2084165858094663e-33, -4.0456610843430061e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1410
    {6.0061647938386897e-01, -4.6398198229461932e-17,       -1.6673493003710801e-33, 5.1982824378491445e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1411
    {6.0306659854034816e-01, 3.7323357680559650e-17,       2.7771920866974305e-33, -1.6194229649742458e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1412
    {6.0551104140432555e-01, -3.1202672493305677e-17,       1.2761267338680916e-33, -4.0859368598379647e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1413
    {6.0794978496777363e-01, 3.5160832362096660e-17,       -2.5546242776778394e-34, -1.4085313551220694e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1414
    {6.1038280627630948e-01, -2.2563265648229169e-17,       1.3185575011226730e-33, 8.2316691420063460e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1415
    {6.1281008242940971e-01, -4.2693476568409685e-18,       2.5839965886650320e-34, 1.6884412005622537e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1416
    {6.1523159058062682e-01, 2.6231417767266950e-17,       -1.4095366621106716e-33, 7.2058690491304558e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1417
    {6.1764730793780398e-01, -4.7478594510902452e-17,       -7.2986558263123996e-34, -3.0152327517439154e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1418
    {6.2005721176328921e-01, -2.7983410837681118e-17,       1.1649951056138923e-33, -5.4539089117135207e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1419
    {6.2246127937414997e-01, 5.2940728606573002e-18,       -4.8486411215945827e-35, 1.2696527641980109e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1420
    {6.2485948814238634e-01, 3.3671846037243900e-17,       -2.7846053391012096e-33, 5.6102718120012104e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1421
    {6.2725181549514408e-01, 3.0763585181253225e-17,       2.7068930273498138e-34, -1.1172240309286484e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1422
    {6.2963823891492698e-01, 4.1115334049626806e-17,       -1.9167473580230747e-33, 1.1118424028161730e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1423
    {6.3201873593980906e-01, -4.0164942296463612e-17,       -7.2208643641736723e-34, 3.7828920470544344e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1424
    {6.3439328416364549e-01, 1.0420901929280035e-17,       4.1174558929280492e-34, -1.4464152986630705e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1425
    {6.3676186123628420e-01, 3.1419048711901611e-17,       -2.2693738415126449e-33, -1.6023584204297388e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1426
    {6.3912444486377573e-01, 1.2416796312271043e-17,       -6.2095419626356605e-34, 2.7762065999506603e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1427
    {6.4148101280858316e-01, -9.9883430115943310e-18,       4.1969230376730128e-34, 5.6980543799257597e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1428
    {6.4383154288979150e-01, -3.2084798795046886e-17,       -1.2595311907053305e-33, -4.0205885230841536e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1429
    {6.4617601298331639e-01, -2.9756137382280815e-17,       -1.0275370077518259e-33, 8.0852478665893014e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1430
    {6.4851440102211244e-01, 3.9870270313386831e-18,       1.9408388509540788e-34, -5.1798420636193190e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1431
    {6.5084668499638088e-01, 3.9714670710500257e-17,       2.9178546787002963e-34, 3.8140635508293278e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1432
    {6.5317284295377676e-01, 8.5695642060026238e-18,       -6.9165322305070633e-34, 2.3873751224185395e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1433
    {6.5549285299961535e-01, 3.5638734426385005e-17,       1.2695365790889811e-33, 4.3984952865412050e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1434
    {6.5780669329707864e-01, 1.9580943058468545e-17,       -1.1944272256627192e-33, 2.8556402616436858e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1435
    {6.6011434206742048e-01, -1.3960054386823638e-19,       6.1515777931494047e-36, 5.3510498875622660e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1436
    {6.6241577759017178e-01, -2.2615508885764591e-17,       5.0177050318126862e-34, 2.9162532399530762e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1437
    {6.6471097820334490e-01, -3.6227793598034367e-17,       -9.0607934765540427e-34, 3.0917036342380213e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1438
    {6.6699992230363747e-01, 3.5284364997428166e-17,       -1.0382057232458238e-33, 7.3812756550167626e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1439
    {6.6928258834663612e-01, -5.4592652417447913e-17,       -2.5181014709695152e-33, -1.6867875999437174e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1440
    {6.7155895484701844e-01, -4.0489037749296692e-17,       3.1995835625355681e-34, -1.4044414655670960e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1441
    {6.7382900037875604e-01, 2.3091901236161086e-17,       5.7428037192881319e-34, 1.1240668354625977e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1442
    {6.7609270357531592e-01, 3.7256902248049466e-17,       1.7059417895764375e-33, 9.7326347795300652e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1443
    {6.7835004312986147e-01, 1.8302093041863122e-17,       9.5241675746813072e-34, 5.0328101116133503e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1444
    {6.8060099779545302e-01, 2.8473293354522047e-17,       4.1331805977270903e-34, 4.2579030510748576e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1445
    {6.8284554638524808e-01, -1.2958058061524531e-17,       1.8292386959330698e-34, 3.4536209116044487e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1446
    {6.8508366777270036e-01, 2.5948135194645137e-17,       -8.5030743129500702e-34, -6.9572086141009930e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1447
    {6.8731534089175916e-01, -5.5156158714917168e-17,       1.1896489854266829e-33, -7.8505896218220662e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1448
    {6.8954054473706694e-01, -1.5889323294806790e-17,       9.1242356240205712e-34, 3.8315454152267638e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1449
    {6.9175925836415775e-01, 2.7406078472410668e-17,       1.3286508943202092e-33, 1.0651869129580079e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1450
    {6.9397146088965400e-01, 7.4345076956280137e-18,       7.5061528388197460e-34, -1.5928000240686583e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1451
    {6.9617713149146299e-01, -4.1224081213582889e-17,       -3.1838716762083291e-35, -3.9625587412119131e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1452
    {6.9837624940897280e-01, 4.8988282435667768e-17,       1.9134010413244152e-33, 2.6161153243793989e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1453
    {7.0056879394324834e-01, 3.1027960192992922e-17,       9.5638250509179997e-34, 4.5896916138107048e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1454
    {7.0275474445722530e-01, 2.5278294383629822e-18,       -8.6985561210674942e-35, -5.6899862307812990e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1455
    {7.0493408037590488e-01, 2.7608725585748502e-17,       2.9816599471629137e-34, 1.1533044185111206e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1456
    {7.0710678118654757e-01, -4.8336466567264567e-17,       2.0693376543497068e-33, 2.4677734957341755e-50}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1457
};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1458
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1459
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1460
sin_table_qd(double *s0, double *s1, double *s2, double *s3, double j)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1461
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1462
    int int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1463
    s0[0]=s_table[int_j-1][0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1464
    s1[0]=s_table[int_j-1][1];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1465
    s2[0]=s_table[int_j-1][2];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1466
    s3[0]=s_table[int_j-1][3];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1467
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1468
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1469
static double c_table[265][4] = {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1470
    {9.9999529380957619e-01, -1.9668064285322189e-17,       -6.3053955095883481e-34, 5.3266110855726731e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1471
    {9.9998117528260111e-01, 3.3568103522895585e-17,       -1.4740132559368063e-35, 9.8603097594755596e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1472
    {9.9995764455196390e-01, -3.1527836866647287e-17,       2.6363251186638437e-33, 1.0007504815488399e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1473
    {9.9992470183914450e-01, 3.7931082512668012e-17,       -8.5099918660501484e-35, -4.9956973223295153e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1474
    {9.9988234745421256e-01, -3.5477814872408538e-17,       1.7102001035303974e-33, -1.0725388519026542e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1475
    {9.9983058179582340e-01, 1.8825140517551119e-17,       -5.1383513457616937e-34, -3.8378827995403787e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1476
    {9.9976940535121528e-01, 4.2681177032289012e-17,       1.9062302359737099e-33, -6.0221153262881160e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1477
    {9.9969881869620425e-01, -2.9851486403799753e-17,       -1.9084787370733737e-33, 5.5980260344029202e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1478
    {9.9961882249517864e-01, -4.1181965521424734e-17,       2.0915365593699916e-33, 8.1403390920903734e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1479
    {9.9952941750109314e-01, 2.0517917823755591e-17,       -4.7673802585706520e-34, -2.9443604198656772e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1480
    {9.9943060455546173e-01, 3.9644497752257798e-17,       -2.3757223716722428e-34, -1.2856759011361726e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1481
    {9.9932238458834954e-01, -4.2858538440845682e-17,       3.3235101605146565e-34, -8.3554272377057543e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1482
    {9.9920475861836389e-01, 9.1796317110385693e-18,       5.5416208185868570e-34, 8.0267046717615311e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1483
    {9.9907772775264536e-01, 2.1419007653587032e-17,       -7.9048203318529618e-34, -5.3166296181112712e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1484
    {9.9894129318685687e-01, -2.0610641910058638e-17,       -1.2546525485913485e-33, -7.5175888806157064e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1485
    {9.9879545620517241e-01, -1.2291693337075465e-17,       2.4468446786491271e-34, 1.0723891085210268e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1486
    {9.9864021818026527e-01, -4.8690254312923302e-17,       -2.9470881967909147e-34, -1.3000650761346907e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1487
    {9.9847558057329477e-01, -2.2002931182778795e-17,       -1.2371509454944992e-33, -2.4911225131232065e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1488
    {9.9830154493389289e-01, -5.1869402702792278e-17,       1.0480195493633452e-33, -2.8995649143155511e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1489
    {9.9811811290014918e-01, 2.7935487558113833e-17,       2.4423341255830345e-33, -6.7646699175334417e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1490
    {9.9792528619859600e-01, 1.7143659778886362e-17,       5.7885840902887460e-34, -9.2601432603894597e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1491
    {9.9772306664419164e-01, -2.6394475274898721e-17,       -1.6176223087661783e-34, -9.9924942889362281e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1492
    {9.9751145614030345e-01, 5.6007205919806937e-18,       -5.9477673514685690e-35, -1.4166807162743627e-54},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1493
    {9.9729045667869021e-01, 9.1647695371101735e-18,       6.7824134309739296e-34, -8.6191392795543357e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1494
    {9.9706007033948296e-01, 1.6734093546241963e-17,       -1.3169951440780028e-33, 1.0311048767952477e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1495
    {9.9682029929116567e-01, 4.7062820708615655e-17,       2.8412041076474937e-33, -8.0006155670263622e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1496
    {9.9657114579055484e-01, 1.1707179088390986e-17,       -7.5934413263024663e-34, 2.8474848436926008e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1497
    {9.9631261218277800e-01, 1.1336497891624735e-17,       3.4002458674414360e-34, 7.7419075921544901e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1498
    {9.9604470090125197e-01, 2.2870031707670695e-17,       -3.9184839405013148e-34, -3.7081260416246375e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1499
    {9.9576741446765982e-01, -2.3151908323094359e-17,       -1.6306512931944591e-34, -1.5925420783863192e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1500
    {9.9548075549192694e-01, 3.2084621412226554e-18,       -4.9501292146013023e-36, -2.7811428850878516e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1501
    {9.9518472667219693e-01, -4.2486913678304410e-17,       1.3315510772504614e-33, 6.7927987417051888e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1502
    {9.9487933079480562e-01, 4.2130813284943662e-18,       -4.2062597488288452e-35, 2.5157064556087620e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1503
    {9.9456457073425542e-01, 3.6745069641528058e-17,       -3.0603304105471010e-33, 1.0397872280487526e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1504
    {9.9424044945318790e-01, 4.4129423472462673e-17,       -3.0107231708238066e-33, 7.4201582906861892e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1505
    {9.9390697000235606e-01, -1.8964849471123746e-17,       -1.5980853777937752e-35, -8.5374807150597082e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1506
    {9.9356413552059530e-01, 2.9752309927797428e-17,       -4.5066707331134233e-34, -3.3548191633805036e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1507
    {9.9321194923479450e-01, 3.3096906261272262e-17,       1.5592811973249567e-33, 1.4373977733253592e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1508
    {9.9285041445986510e-01, -1.4094517733693302e-17,       -1.1954558131616916e-33, 1.8761873742867983e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1509
    {9.9247953459870997e-01, 3.1093055095428906e-17,       -1.8379594757818019e-33, -3.9885758559381314e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1510
    {9.9209931314219180e-01, -3.9431926149588778e-17,       -6.2758062911047230e-34, -1.2960929559212390e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1511
    {9.9170975366909953e-01, -2.3372891311883661e-18,       2.7073298824968591e-35, -1.2569459441802872e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1512
    {9.9131085984611544e-01, -2.5192111583372105e-17,       -1.2852471567380887e-33, 5.2385212584310483e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1513
    {9.9090263542778001e-01, 1.5394565094566704e-17,       -1.0799984133184567e-33, 2.7451115960133595e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1514
    {9.9048508425645709e-01, -5.5411437553780867e-17,       -1.4614017210753585e-33, -3.8339374397387620e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1515
    {9.9005821026229712e-01, -1.7055485906233963e-17,       1.3454939685758777e-33, 7.3117589137300036e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1516
    {9.8962201746320089e-01, -5.2398217968132530e-17,       1.3463189211456219e-33, 5.8021640554894872e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1517
    {9.8917650996478101e-01, -4.0987309937047111e-17,       -4.4857560552048437e-34, -3.9414504502871125e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1518
    {9.8872169196032378e-01, -1.0976227206656125e-17,       3.2311342577653764e-34, 9.6367946583575041e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1519
    {9.8825756773074946e-01, 2.7030607784372632e-17,       7.7514866488601377e-35, 2.1019644956864938e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1520
    {9.8778414164457218e-01, -2.3600693397159021e-17,       -1.2323283769707861e-33, 3.0130900716803339e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1521
    {9.8730141815785843e-01, -5.2332261255715652e-17,       -2.7937644333152473e-33, 1.2074160567958408e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1522
    {9.8680940181418553e-01, -5.0287214351061075e-17,       -2.2681526238144461e-33, 4.4003694320169133e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1523
    {9.8630809724459867e-01, -2.1520877103013341e-17,       1.1866528054187716e-33, -7.8532199199813836e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1524
    {9.8579750916756748e-01, -5.1439452979953012e-17,       2.6276439309996725e-33, 7.5423552783286347e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1525
    {9.8527764238894122e-01, 2.3155637027900207e-17,       -7.5275971545764833e-34, 1.0582231660456094e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1526
    {9.8474850180190421e-01, 1.0548144061829957e-17,       2.8786145266267306e-34, -3.6782210081466112e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1527
    {9.8421009238692903e-01, 4.7983922627050691e-17,       2.2597419645070588e-34, 1.7573875814863400e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1528
    {9.8366241921173025e-01, 1.9864948201635255e-17,       -1.0743046281211033e-35, 1.7975662796558100e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1529
    {9.8310548743121629e-01, 4.2170007522888628e-17,       8.2396265656440904e-34, -8.0803700139096561e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1530
    {9.8253930228744124e-01, 1.5149580813777224e-17,       -4.1802771422186237e-34, -2.2150174326226160e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1531
    {9.8196386910955524e-01, 2.1108443711513084e-17,       -1.5253013442896054e-33, -6.8388082079337969e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1532
    {9.8137919331375456e-01, 1.3428163260355633e-17,       -6.5294290469962986e-34, 2.7965412287456268e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1533
    {9.8078528040323043e-01, 1.8546939997825006e-17,       -1.0696564445530757e-33, 6.6668174475264961e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1534
    {9.8018213596811743e-01, -3.6801786963856159e-17,       6.3245171387992842e-34, 1.8600176137175971e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1535
    {9.7956976568544052e-01, 1.5573991584990420e-17,       -1.3401066029782990e-33, -1.7263702199862149e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1536
    {9.7894817531906220e-01, -2.3817727961148053e-18,       -1.0694750370381661e-34, -8.2293047196087462e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1537
    {9.7831737071962765e-01, -2.1623082233344895e-17,       1.0970403012028032e-33, 7.7091923099369339e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1538
    {9.7767735782450993e-01, 5.0514136167059628e-17,       -1.3254751701428788e-33, 7.0161254312124538e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1539
    {9.7702814265775439e-01, -4.3353875751555997e-17,       5.4948839831535478e-34, -9.2755263105377306e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1540
    {9.7636973133002114e-01, 9.3093931526213780e-18,       -4.1184949155685665e-34, -3.1913926031393690e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1541
    {9.7570213003852857e-01, -2.5572556081259686e-17,       -9.3174244508942223e-34, -8.3675863211646863e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1542
    {9.7502534506699412e-01, 2.6642660651899135e-17,       1.7819392739353853e-34, -3.3159625385648947e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1543
    {9.7433938278557586e-01, 2.3041221476151512e-18,       1.0758686005031430e-34, 5.1074116432809478e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1544
    {9.7364424965081198e-01, -5.1729808691005871e-17,       -1.5508473005989887e-33, -1.6505125917675401e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1545
    {9.7293995220556018e-01, -3.1311211122281800e-17,       -2.6874087789006141e-33, -2.1652434818822145e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1546
    {9.7222649707893627e-01, 3.6461169785938221e-17,       3.0309636883883133e-33, -1.2702716907967306e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1547
    {9.7150389098625178e-01, -7.9865421122289046e-18,       -4.3628417211263380e-34, 3.4307517798759352e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1548
    {9.7077214072895035e-01, -4.7992163325114922e-17,       3.0347528910975783e-33, 8.5989199506479701e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1549
    {9.7003125319454397e-01, 1.8365300348428844e-17,       -1.4311097571944918e-33, 8.5846781998740697e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1550
    {9.6928123535654853e-01, -4.5663660261927896e-17,       9.6147526917239387e-34, 8.1267605207871330e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1551
    {9.6852209427441727e-01, 4.9475074918244771e-17,       2.8558738351911241e-33, 6.2948422316507461e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1552
    {9.6775383709347551e-01, -4.5512132825515820e-17,       -1.4127617988719093e-33, -8.4620609089704578e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1553
    {9.6697647104485207e-01, 3.8496228837337864e-17,       -5.3881631542745647e-34, -3.5221863171458959e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1554
    {9.6619000344541250e-01, 5.1298840401665493e-17,       1.4564075904769808e-34, 1.0095973971377432e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1555
    {9.6539444169768940e-01, -2.3745389918392156e-17,       5.9221515590053862e-34, -3.8811192556231094e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1556
    {9.6458979328981276e-01, -3.4189470735959786e-17,       2.2982074155463522e-33, -4.5128791045607634e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1557
    {9.6377606579543984e-01, 2.6463950561220029e-17,       -2.9073234590199323e-36, -1.2938328629395601e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1558
    {9.6295326687368388e-01, 8.9341960404313634e-18,       -3.9071244661020126e-34, 1.6212091116847394e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1559
    {9.6212140426904158e-01, 1.5236770453846305e-17,       -1.3050173525597142e-33, 7.9016122394092666e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1560
    {9.6128048581132064e-01, 2.0933955216674039e-18,       1.0768607469015692e-34, -5.9453639304361774e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1561
    {9.6043051941556579e-01, 2.4653904815317185e-17,       -1.3792169410906322e-33, -4.7726598378506903e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1562
    {9.5957151308198452e-01, 1.1000640085000957e-17,       -4.2036030828223975e-34, 4.0023704842606573e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1563
    {9.5870347489587160e-01, -4.3685014392372053e-17,       2.2001800662729131e-33, -1.0553721324358075e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1564
    {9.5782641302753291e-01, -1.7696710075371263e-17,       1.9164034110382190e-34, 8.1489235071754813e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1565
    {9.5694033573220882e-01, 4.0553869861875701e-17,       -1.7147013364302149e-33, 2.5736745295329455e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1566
    {9.5604525134999641e-01, 3.7705045279589067e-17,       1.9678699997347571e-33, 8.5093177731230180e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1567
    {9.5514116830577067e-01, 5.0088652955014668e-17,       -2.6983181838059211e-33, 1.0102323575596493e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1568
    {9.5422809510910567e-01, -3.7545901690626874e-17,       1.4951619241257764e-33, -8.2717333151394973e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1569
    {9.5330604035419386e-01, -2.5190738779919934e-17,       -1.4272239821134379e-33, -4.6717286809283155e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1570
    {9.5237501271976588e-01, -2.0269300462299272e-17,       -1.0635956887246246e-33, -3.5514537666487619e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1571
    {9.5143502096900834e-01, 3.1350584123266695e-17,       -2.4824833452737813e-33, 9.5450335525380613e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1572
    {9.5048607394948170e-01, 1.9410097562630436e-17,       -8.1559393949816789e-34, -1.0501209720164562e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1573
    {9.4952818059303667e-01, -7.5544151928043298e-18,       -5.1260245024046686e-34, 1.8093643389040406e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1574
    {9.4856134991573027e-01, 2.0668262262333232e-17,       -5.9440730243667306e-34, 1.4268853111554300e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1575
    {9.4758559101774109e-01, 4.3417993852125991e-17,       -2.7728667889840373e-34, 5.5709160196519968e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1576
    {9.4660091308328353e-01, 3.5056800210680730e-17,       9.8578536940318117e-34, 6.6035911064585197e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1577
    {9.4560732538052128e-01, 4.6019102478523738e-17,       -6.2534384769452059e-34, 1.5758941215779961e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1578
    {9.4460483726148026e-01, 8.8100545476641165e-18,       5.2291695602757842e-34, -3.3487256018407123e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1579
    {9.4359345816196039e-01, -2.4093127844404214e-17,       1.0283279856803939e-34, -2.3398232614531355e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1580
    {9.4257319760144687e-01, 1.3235564806436886e-17,       -5.7048262885386911e-35, 3.9947050442753744e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1581
    {9.4154406518302081e-01, -2.7896379547698341e-17,       1.6273236356733898e-33, -5.3075944708471203e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1582
    {9.4050607059326830e-01, 2.8610421567116268e-17,       2.9261501147538827e-33, -2.6849867690896925e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1583
    {9.3945922360218992e-01, -7.0152867943098655e-18,       -5.6395693818011210e-34, 3.5568142678987651e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1584
    {9.3840353406310806e-01, 5.4242545044795490e-17,       -1.9039966607859759e-33, -1.5627792988341215e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1585
    {9.3733901191257496e-01, -3.6570926284362776e-17,       -1.1902940071273247e-33, -1.1215082331583223e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1586
    {9.3626566717027826e-01, -1.3013766145497654e-17,       5.2229870061990595e-34, -3.3972777075634108e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1587
    {9.3518350993894761e-01, -3.2609395302485065e-17,       -8.1813015218875245e-34, 5.5642140024928139e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1588
    {9.3409255040425887e-01, 4.4662824360767511e-17,       -2.5903243047396916e-33, 8.1505209004343043e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1589
    {9.3299279883473885e-01, 4.2041415555384355e-17,       9.0285896495521276e-34, 5.3019984977661259e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1590
    {9.3188426558166815e-01, -4.0785944377318095e-17,       1.7631450298754169e-33, 2.5776403305507453e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1591
    {9.3076696107898371e-01, 1.9703775102838329e-17,       6.5657908718278205e-34, -1.9480347966259524e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1592
    {9.2964089584318121e-01, 5.1282530016864107e-17,       2.3719739891916261e-34, -1.7230065426917127e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1593
    {9.2850608047321559e-01, -2.3306639848485943e-17,       -7.7799084333208503e-34, -5.8597558009300305e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1594
    {9.2736252565040111e-01, -2.7677111692155437e-17,       2.2110293450199576e-34, 2.0349190819680613e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1595
    {9.2621024213831138e-01, -3.7303754586099054e-17,       2.0464457809993405e-33, 1.3831799631231817e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1596
    {9.2504924078267758e-01, 6.0529447412576159e-18,       -8.8256517760278541e-35, 1.8285462122388328e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1597
    {9.2387953251128674e-01, 1.7645047084336677e-17,       -5.0442537321586818e-34, -4.0478677716823890e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1598
    {9.2270112833387852e-01, 5.2963798918539814e-17,       -5.7135699628876685e-34, 3.0163671797219087e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1599
    {9.2151403934204190e-01, 4.1639843390684644e-17,       1.1891485604702356e-33, 2.0862437594380324e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1600
    {9.2031827670911059e-01, -2.7806888779036837e-17,       2.7011013677071274e-33, 1.1998578792455499e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1601
    {9.1911385169005777e-01, -2.6496484622344718e-17,       6.5403604763461920e-34, -2.8997180201186078e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1602
    {9.1790077562139050e-01, -3.9074579680849515e-17,       2.3004636541490264e-33, 3.9851762744443107e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1603
    {9.1667905992104270e-01, -4.1733978698287568e-17,       1.2094444804381172e-33, 4.9356916826097816e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1604
    {9.1544871608826783e-01, -1.3591056692900894e-17,       5.9923027475594735e-34, 2.1403295925962879e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1605
    {9.1420975570353069e-01, -3.6316182527814423e-17,       -1.9438819777122554e-33, 2.8340679287728316e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1606
    {9.1296219042839821e-01, -4.7932505228039469e-17,       -1.7753551889428638e-33, 4.0607782903868160e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1607
    {9.1170603200542988e-01, -2.6913273175034130e-17,       -5.1928101916162528e-35, 1.1338175936090630e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1608
    {9.1044129225806725e-01, -5.0433041673313820e-17,       1.0938746257404305e-33, 9.5378272084170731e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1609
    {9.0916798309052238e-01, -3.6878564091359894e-18,       2.9951330310507693e-34, -1.2225666136919926e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1610
    {9.0788611648766626e-01, -4.9459964301225840e-17,       -1.6599682707075313e-33, -5.1925202712634716e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1611
    {9.0659570451491533e-01, 3.0506718955442023e-17,       -1.4478836557141204e-33, 1.8906373784448725e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1612
    {9.0529675931811882e-01, -4.1153099826889901e-17,       2.9859368705184223e-33, 5.1145293917439211e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1613
    {9.0398929312344334e-01, -6.6097544687484308e-18,       1.2728013034680357e-34, -4.3026097234014823e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1614
    {9.0267331823725883e-01, -1.9250787033961483e-17,       1.3242128993244527e-33, -5.2971030688703665e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1615
    {9.0134884704602203e-01, -1.3524789367698682e-17,       6.3605353115880091e-34, 3.6227400654573828e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1616
    {9.0001589201616028e-01, -5.0639618050802273e-17,       1.0783525384031576e-33, 2.8130016326515111e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1617
    {8.9867446569395382e-01, 2.6316906461033013e-17,       3.7003137047796840e-35, -2.3447719900465938e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1618
    {8.9732458070541832e-01, -3.6396283314867290e-17,       -2.3611649895474815e-33, 1.1837247047900082e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1619
    {8.9596624975618511e-01, 4.9025099114811813e-17,       -1.9440489814795326e-33, -1.7070486667767033e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1620
    {8.9459948563138270e-01, -1.7516226396814919e-17,       -1.3200670047246923e-33, -1.5953009884324695e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1621
    {8.9322430119551532e-01, -4.1161239151908913e-18,       2.5380253805715999e-34, 4.2849455510516192e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1622
    {8.9184070939234272e-01, 4.6690228137124547e-18,       1.6150254286841982e-34, -3.9617448820725012e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1623
    {8.9044872324475788e-01, 1.1781931459051803e-17,       -1.3346142209571930e-34, -9.4982373530733431e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1624
    {8.8904835585466457e-01, -1.1164514966766675e-17,       -3.4797636107798736e-34, -1.5605079997040631e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1625
    {8.8763962040285393e-01, 1.2805091918587960e-17,       3.9948742059584459e-35, 3.8940716325338136e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1626
    {8.8622253014888064e-01, -6.7307369600274315e-18,       1.2385593432917413e-34, 2.0364014759133320e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1627
    {8.8479709843093779e-01, -9.4331469628972690e-18,       -5.7106541478701439e-34, 1.8260134111907397e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1628
    {8.8336333866573158e-01, 1.5822643380255127e-17,       -7.8921320007588250e-34, -1.4782321016179836e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1629
    {8.8192126434835505e-01, -1.9843248405890562e-17,       -7.0412114007673834e-34, -1.0636770169389104e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1630
    {8.8047088905216075e-01, 1.6311096602996350e-17,       -5.7541360594724172e-34, -4.0128611862170021e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1631
    {8.7901222642863353e-01, -4.7356837291118011e-17,       1.4388771297975192e-33, -2.9085554304479134e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1632
    {8.7754529020726124e-01, 5.0113311846499550e-17,       2.8382769008739543e-34, 1.5550640393164140e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1633
    {8.7607009419540660e-01, 5.8729024235147677e-18,       2.7941144391738458e-34, -1.8536073846509828e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1634
    {8.7458665227817611e-01, -5.7216617730397065e-19,       -2.9705811503689596e-35, 8.7389593969796752e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1635
    {8.7309497841829009e-01, 7.8424672990129903e-18,       -4.8685015839797165e-34, -2.2815570587477527e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1636
    {8.7159508665595109e-01, -5.5272998038551050e-17,       -2.2104090204984907e-33, -9.7749763187643172e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1637
    {8.7008699110871146e-01, -4.1888510868549968e-17,       7.0900185861878415e-34, 3.7600251115157260e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1638
    {8.6857070597134090e-01, 2.7192781689782903e-19,       -1.6710140396932428e-35, -1.2625514734637969e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1639
    {8.6704624551569265e-01, 3.0267859550930567e-18,       -1.1559438782171572e-34, -5.3580556397808012e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1640
    {8.6551362409056909e-01, -6.3723113549628899e-18,       2.3725520321746832e-34, 1.5911880348395175e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1641
    {8.6397285612158670e-01, 4.1486355957361607e-17,       2.2709976932210266e-33, -8.1228385659479984e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1642
    {8.6242395611104050e-01, 3.7008992527383130e-17,       5.2128411542701573e-34, 2.6945600081026861e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1643
    {8.6086693863776731e-01, -3.0050048898573656e-17,       -8.8706183090892111e-34, 1.5005320558097301e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1644
    {8.5930181835700836e-01, 4.2435655816850687e-17,       7.6181814059912025e-34, -3.9592127850658708e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1645
    {8.5772861000027212e-01, -4.8183447936336620e-17,       -1.1044130517687532e-33, -8.7400233444645562e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1646
    {8.5614732837519447e-01, 9.1806925616606261e-18,       5.6328649785951470e-34, 2.3326646113217378e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1647
    {8.5455798836540053e-01, -1.2991124236396092e-17,       1.2893407722948080e-34, -3.6506925747583053e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1648
    {8.5296060493036363e-01, 2.7152984251981370e-17,       7.4336483283120719e-34, 4.2162417622350668e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1649
    {8.5135519310526520e-01, -5.3279874446016209e-17,       2.2281156380919942e-33, -4.0281886404138477e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1650
    {8.4974176800085244e-01, 5.1812347659974015e-17,       3.0810626087331275e-33, -2.5931308201994965e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1651
    {8.4812034480329723e-01, 1.8762563415239981e-17,       1.4048773307919617e-33, -2.4915221509958691e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1652
    {8.4649093877405213e-01, -4.7969419958569345e-17,       -2.7518267097886703e-33, -7.3518959727313350e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1653
    {8.4485356524970712e-01, -4.3631360296879637e-17,       -2.0307726853367547e-33, 4.3097229819851761e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1654
    {8.4320823964184544e-01, 9.6536707005959077e-19,       2.8995142431556364e-36, 9.6715076811480284e-53},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1655
    {8.4155497743689844e-01, -3.4095465391321557e-17,       -8.4130208607579595e-34, -4.9447283960568686e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1656
    {8.3989379419599952e-01, -1.6673694881511411e-17,       -1.4759184141750289e-33, -7.5795098161914058e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1657
    {8.3822470555483808e-01, -3.5560085052855026e-17,       1.1689791577022643e-33, -5.8627347359723411e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1658
    {8.3654772722351201e-01, -2.0899059027066533e-17,       -9.8104097821002585e-35, -3.1609177868229853e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1659
    {8.3486287498638001e-01, 4.6048430609159657e-17,       -5.1827423265239912e-34, -7.0505343435504109e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1660
    {8.3317016470191319e-01, 1.3275129507229764e-18,       4.8589164115370863e-35, 4.5422281300506859e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1661
    {8.3146961230254524e-01, 1.4073856984728024e-18,       4.6951315383980830e-35, 5.1431906049905658e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1662
    {8.2976123379452305e-01, -2.9349109376485597e-18,       1.1496917934149818e-34, 3.5186665544980233e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1663
    {8.2804504525775580e-01, -4.4196593225871532e-17,       2.7967864855211251e-33, 1.0030777287393502e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1664
    {8.2632106284566353e-01, -5.3957485453612902e-17,       6.8976896130138550e-34, 3.8106164274199196e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1665
    {8.2458930278502529e-01, -2.6512360488868275e-17,       1.6916964350914386e-34, 6.7693974813562649e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1666
    {8.2284978137582632e-01, 1.5193019034505495e-17,       9.6890547246521685e-34, 5.6994562923653264e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1667
    {8.2110251499110465e-01, 3.0715131609697682e-17,       -1.7037168325855879e-33, -1.1149862443283853e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1668
    {8.1934752007679701e-01, -4.8200736995191133e-17,       -1.5574489646672781e-35, -9.5647853614522216e-53},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1669
    {8.1758481315158371e-01, -1.4883149812426772e-17,       -7.8273262771298917e-34, 4.1332149161031594e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1670
    {8.1581441080673378e-01, 8.2652693782130871e-18,       -2.3028778135179471e-34, 1.5102071387249843e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1671
    {8.1403632970594841e-01, -5.2127351877042624e-17,       -1.9047670611316360e-33, -1.6937269585941507e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1672
    {8.1225058658520388e-01, 3.1054545609214803e-17,       2.2649541922707251e-34, -7.4221684154649405e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1673
    {8.1045719825259477e-01, 2.3520367349840499e-17,       -7.7530070904846341e-34, -7.2792616357197140e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1674
    {8.0865618158817498e-01, 9.3251597879721674e-18,       -7.1823301933068394e-34, 2.3925440846132106e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1675
    {8.0684755354379922e-01, 4.9220603766095546e-17,       2.9796016899903487e-33, 1.5220754223615788e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1676
    {8.0503133114296355e-01, 5.1368289568212149e-17,       6.3082807402256524e-34, 7.3277646085129827e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1677
    {8.0320753148064494e-01, -3.3060609804814910e-17,       -1.2242726252420433e-33, 2.8413673268630117e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1678
    {8.0137617172314024e-01, -2.0958013413495834e-17,       -4.3798162198006931e-34, 2.0235690497752515e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1679
    {7.9953726910790501e-01, 2.0356723822005431e-17,       -9.7448513696896360e-34, 5.3608109599696008e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1680
    {7.9769084094339116e-01, -4.6730759884788944e-17,       2.3075897077191757e-33, 3.1605567774640253e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1681
    {7.9583690460888357e-01, -3.0062724851910721e-17,       -2.2496210832042235e-33, -6.5881774117183040e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1682
    {7.9397547755433717e-01, -7.4194631759921416e-18,       2.4124341304631069e-34, -4.9956808616244972e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1683
    {7.9210657730021239e-01, -3.7087850202326467e-17,       -1.4874457267228264e-33, 2.9323097289153505e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1684
    {7.9023022143731003e-01, 2.3056905954954492e-17,       1.4481080533260193e-33, -7.6725237057203488e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1685
    {7.8834642762660623e-01, 3.4396993154059708e-17,       1.7710623746737170e-33, 1.7084159098417402e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1686
    {7.8645521359908577e-01, -9.7841429939305265e-18,       3.3906063272445472e-34, 5.7269505320382577e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1687
    {7.8455659715557524e-01, -8.5627965423173476e-18,       -2.1106834459001849e-34, -1.6890322182469603e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1688
    {7.8265059616657573e-01, 9.0745866975808825e-18,       6.7623847404278666e-34, -1.7173237731987271e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1689
    {7.8073722857209449e-01, -9.9198782066678806e-18,       -2.1265794012162715e-36, 3.0772165598957647e-54},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1690
    {7.7881651238147598e-01, -2.4891385579973807e-17,       6.7665497024807980e-35, -6.5218594281701332e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1691
    {7.7688846567323244e-01, 7.7418602570672864e-18,       -5.9986517872157897e-34, 3.0566548232958972e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1692
    {7.7495310659487393e-01, -5.2209083189826433e-17,       -9.6653593393686612e-34, 3.7027750076562569e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1693
    {7.7301045336273699e-01, -3.2565907033649772e-17,       1.3860807251523929e-33, -3.9971329917586022e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1694
    {7.7106052426181382e-01, -4.4558442347769265e-17,       -2.9863565614083783e-33, -6.8795262083596236e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1695
    {7.6910333764557959e-01, 5.1546455184564817e-17,       2.6142829553524292e-33, -1.6199023632773298e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1696
    {7.6713891193582040e-01, -1.8885903683750782e-17,       -1.3659359331495433e-33, -2.2538834962921934e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1697
    {7.6516726562245896e-01, -3.2707225612534598e-17,       1.1177117747079528e-33, -3.7005182280175715e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1698
    {7.6318841726338127e-01, 2.6314748416750748e-18,       1.4048039063095910e-34, 8.9601886626630321e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1699
    {7.6120238548426178e-01, 3.5315510881690551e-17,       1.2833566381864357e-33, 8.6221435180890613e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1700
    {7.5920918897838807e-01, -3.8558842175523123e-17,       2.9720241208332759e-34, -1.2521388928220163e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1701
    {7.5720884650648457e-01, -1.9909098777335502e-17,       3.9409283266158482e-34, 2.0744254207802976e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1702
    {7.5520137689653655e-01, -1.9402238001823017e-17,       -3.7756206444727573e-34, -2.1212242308178287e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1703
    {7.5318679904361252e-01, -3.7937789838736540e-17,       -6.7009539920231559e-34, -6.7128562115050214e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1704
    {7.5116513190968637e-01, 4.3499761158645868e-17,       2.5227718971102212e-33, -6.5969709212757102e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1705
    {7.4913639452345937e-01, -4.4729078447011889e-17,       -2.4206025249983768e-33, 1.1336681351116422e-49},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1706
    {7.4710060598018013e-01, 1.1874824875965430e-17,       2.1992523849833518e-34, 1.1025018564644483e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1707
    {7.4505778544146595e-01, 1.5078686911877863e-17,       8.0898987212942471e-34, 8.2677958765323532e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1708
    {7.4300795213512172e-01, -2.5144629669719265e-17,       7.1128989512526157e-34, 3.0181629077821220e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1709
    {7.4095112535495911e-01, -1.4708616952297345e-17,       -4.9550433827142032e-34, 3.1434132533735671e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1710
    {7.3888732446061511e-01, 3.4324874808225091e-17,       -1.3706639444717610e-33, -3.3520827530718938e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1711
    {7.3681656887736990e-01, -2.8932468101656295e-17,       -3.4649887126202378e-34, -1.8484474476291476e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1712
    {7.3473887809596350e-01, -3.4507595976263941e-17,       -2.3718000676666409e-33, -3.9696090387165402e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1713
    {7.3265427167241282e-01, 1.8918673481573520e-17,       -1.5123719544119886e-33, -9.7922152011625728e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1714
    {7.3056276922782759e-01, -2.9689959904476928e-17,       -1.1276871244239744e-33, -3.0531520961539007e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1715
    {7.2846439044822520e-01, 1.1924642323370718e-19,       5.9001892316611011e-36, 1.2178089069502704e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1716
    {7.2635915508434601e-01, -3.1917502443460542e-17,       7.7047912412039396e-34, 4.1455880160182123e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1717
    {7.2424708295146689e-01, 2.9198471334403004e-17,       2.3027324968739464e-33, -1.2928820533892183e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1718
    {7.2212819392921535e-01, -2.3871262053452047e-17,       1.0636125432862273e-33, -4.4598638837802517e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1719
    {7.2000250796138165e-01, -2.5689658854462333e-17,       -9.1492566948567925e-34, 4.4403780801267786e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1720
    {7.1787004505573171e-01, 2.7006476062511453e-17,       -2.2854956580215348e-34, 9.1726903890287867e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1721
    {7.1573082528381871e-01, -5.1581018476410262e-17,       -1.3736271349300259e-34, -1.2734611344111297e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1722
    {7.1358486878079364e-01, -4.2342504403133584e-17,       -4.2690366101617268e-34, -2.6352370883066522e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1723
    {7.1143219574521643e-01, 7.9643298613856813e-18,       2.9488239510721469e-34, 1.6985236437666356e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1724
    {7.0927282643886569e-01, -3.7597359110245730e-17,       1.0613125954645119e-34, 8.9465480185486032e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1725
    {7.0710678118654757e-01, -4.8336466567264567e-17,       2.0693376543497068e-33, 2.4677734957341755e-50}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1726
};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1727
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1728
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1729
cos_table_qd(double *c0, double *c1, double *c2, double *c3, double j)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1730
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1731
    int int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1732
    c0[0]=c_table[int_j-1][0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1733
    c1[0]=c_table[int_j-1][1];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1734
    c2[0]=c_table[int_j-1][2];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1735
    c3[0]=c_table[int_j-1][3];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1736
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1737
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1738
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1739
static double inv_fact[15][4] = {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1740
    {1.66666666666666657e-01,  9.25185853854297066e-18,  5.13581318503262866e-34,  2.85094902409834186e-50},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1741
    {4.16666666666666644e-02,  2.31296463463574266e-18,  1.28395329625815716e-34,  7.12737256024585466e-51},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1742
    {8.33333333333333322e-03,  1.15648231731787138e-19,  1.60494162032269652e-36,  2.22730392507682967e-53},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1743
    {1.38888888888888894e-03, -5.30054395437357706e-20, -1.73868675534958776e-36, -1.63335621172300840e-52},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1744
    {1.98412698412698413e-04,  1.72095582934207053e-22,  1.49269123913941271e-40,  1.29470326746002471e-58},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1745
    {2.48015873015873016e-05,  2.15119478667758816e-23,  1.86586404892426588e-41,  1.61837908432503088e-59},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1746
    {2.75573192239858925e-06, -1.85839327404647208e-22,  8.49175460488199287e-39, -5.72661640789429621e-55},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1747
    {2.75573192239858883e-07,  2.37677146222502973e-23, -3.26318890334088294e-40,  1.61435111860404415e-56},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1748
    {2.50521083854417202e-08, -1.44881407093591197e-24,  2.04267351467144546e-41, -8.49632672007163175e-58},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1749
    {2.08767569878681002e-09, -1.20734505911325997e-25,  1.70222792889287100e-42,  1.41609532150396700e-58},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1750
    {1.60590438368216133e-10,  1.25852945887520981e-26, -5.31334602762985031e-43,  3.54021472597605528e-59},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1751
    {1.14707455977297245e-11,  2.06555127528307454e-28,  6.88907923246664603e-45,  5.72920002655109095e-61},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1752
    {7.64716373181981641e-13,  7.03872877733453001e-30, -7.82753927716258345e-48,  1.92138649443790242e-64},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1753
    {4.77947733238738525e-14,  4.39920548583408126e-31, -4.89221204822661465e-49,  1.20086655902368901e-65},
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1754
    {2.81145725434552060e-15,  1.65088427308614326e-31, -2.87777179307447918e-50,  4.27110689256293549e-67}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1755
};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1756
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1757
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1758
sin_taylor_qd(double *s0, double *s1, double *s2, double *s3, double x0, double x1, double x2, double x3)
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1759
{
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1760
        double eps = 1.21543267145725e-63; // = 2^-209
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1761
        double thresh = 0.5*fabs(x0)*eps;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1762
        double y0,y1,y2,y3,r0,r1,r2,r3,t0,t1,t2,t3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1763
        int i;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1764
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1765
        if(x0==0.0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1766
            s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1767
            return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1768
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1769
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1770
        i=0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1771
        qd_mul_qd(&y0,&y1,&y2,&y3,x0,x1,x2,x3,x0,x1,x2,x3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1772
        y0 = -y0;   y1 = -y1;   y2 = -y2;   y3 = -y3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1773
        s0[0]=x0;   s1[0]=x1;   s2[0]=x2;   s3[0]=x3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1774
        r0=x0;      r1=x1;      r2=x2;      r3=x3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1775
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1776
        qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1777
        qd_mul_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,inv_fact[i][0],inv_fact[i][1],inv_fact[i][2],inv_fact[i][3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1778
        qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],s0[0],s1[0],s2[0],s3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1779
        i=i+2;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1780
        while ((i<=15)||(fabs(t0)>thresh)) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1781
            qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1782
            qd_mul_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,inv_fact[i][0],inv_fact[i][1],inv_fact[i][2],inv_fact[i][3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1783
            qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],s0[0],s1[0],s2[0],s3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1784
            i=i+2;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1785
        }
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1786
}
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1787
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1788
static void
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1789
cos_taylor_qd(double *c0, double *c1, double *c2, double *c3, double x0, double x1, double x2, double x3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1790
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1791
    double eps = 1.21543267145725e-63; // = 2^-209
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1792
    double thresh = 0.5*eps;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1793
    double y0,y1,y2,y3,r0,r1,r2,r3,t0,t1,t2,t3,p0,p1,p2,p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1794
    int i;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1795
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1796
    if(x0==0.0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1797
        c0[0]=1.0; c1[0]=0.0; c2[0]=0.0; c3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1798
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1799
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1800
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1801
    i=1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1802
    qd_mul_qd(&y0,&y1,&y2,&y3,x0,x1,x2,x3,x0,x1,x2,x3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1803
    y0 = -y0;   y1 = -y1;   y2 = -y2;   y3 = -y3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1804
    r0=y0; r1=y1; r2=y2; r3=y3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1805
    s_mul_qd(&p0,&p1,&p2,&p3,0.5,r0,r1,r2,r3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1806
    qd_add_s(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,1.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1807
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1808
    qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1809
    qd_mul_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,inv_fact[i][0],inv_fact[i][1],inv_fact[i][2],inv_fact[i][3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1810
    qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],c0[0],c1[0],c2[0],c3[0],t0,t1,t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1811
    i=i+2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1812
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1813
    while((i<=15)||(fabs(t0)>thresh)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1814
        qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1815
        qd_mul_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r2,inv_fact[i][0],inv_fact[i][1],inv_fact[i][2],inv_fact[i][3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1816
        qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],c0[0],c1[0],c2[0],c3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1817
        i=i+2;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1818
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1819
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1820
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1821
static void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1822
sincos_taylor_qd(double *s0, double *s1, double *s2, double *s3, double *c0, double *c1, double *c2, double *c3, double x0, double x1, double x2, double x3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1823
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1824
    double eps = 1.21543267145725e-63; // = 2^-209
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1825
    double thresh = 0.5 * fabs(x0)*eps;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1826
    double y0,y1,y2,y3,r0,r1,r2,r3,t0,t1,t2,t3,p0,p1,p2,p3,q0,q1,q2,q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1827
    int i;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1828
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1829
    if(x0==0.0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1830
        s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1831
        c0[0]=1.0; c1[0]=0.0; c2[0]=0.0; c3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1832
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1833
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1834
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1835
    i=0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1836
    qd_mul_qd(&y0,&y1,&y2,&y3,x0,x1,x2,x3,x0,x1,x2,x3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1837
    y0 = -y0;   y1 = -y1;   y2 = -y2;   y3 = -y3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1838
    s0[0]=x0; s1[0]=x1; s2[0]=x2; s3[0]=x3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1839
    r0=x0; r1=x1; r2=x2; r3=x3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1840
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1841
    qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1842
    qd_mul_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,inv_fact[i][0],inv_fact[i][1],inv_fact[i][2],inv_fact[i][3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1843
    qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],s0[0],s1[0],s2[0],s3[0],t0,t1,t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1844
    i=i+2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1845
    while ((i<=15)||((int)fabs(t0)>thresh)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1846
        qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1847
        qd_mul_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,inv_fact[i][0],inv_fact[i][1],inv_fact[i][2],inv_fact[i][3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1848
        qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],s0[0],s1[0],s2[0],s3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1849
        i=i+2;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1850
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1851
    qd_mul_qd(&p0,&p1,&p2,&p3,s0[0],s1[0],s2[0],s3[0],s0[0],s1[0],s2[0],s3[0]); // Modified,2012/01/16 Saito
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1852
    s_sub_qd(&q0,&q1,&q2,&q3,1.0,p0,p1,p2,p3);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1853
    qd_sqrt(&c0[0],&c1[0],&c2[0],&c3[0],q0,q1,q2,q3);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1854
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1855
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1856
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1857
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1858
// quad-double sine
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1859
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1860
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1861
// a0, a1, a2, a3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1862
// a0 + a1 + a2 + a3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1863
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1864
// return (s0,s1,s2,s3) for qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1865
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1866
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1867
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1868
qd_sin(double *s0, double *s1, double *s2, double *s3, double *a0, double *a1, double *a2, double *a3)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1869
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1870
    double p0,p1,p2,p3, q0,q1,q2,q3, z0,z1,z2,z3, r0,r1,r2,r3, j, t0,t1,t2,t3, k,abs_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1871
    double _2pi[4] = {6.283185307179586232e+00,2.449293598294706414e-16,-5.989539619436679332e-33,2.224908441726730563e-49};  // 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1872
    double _pi2[4] = {1.570796326794896558e+00,6.123233995736766036e-17,-1.497384904859169833e-33,5.562271104316826408e-50};  // pi/2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1873
    double _pi1024[4] = {3.067961575771282340e-03,1.195944139792337116e-19,-2.924579892303066080e-36,1.086381075061880158e-52};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1874
    double u0,u1,u2,u3,v0,v1,v2,v3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1875
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1876
    int int_j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1877
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1878
    if(a0[0]==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1879
        s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1880
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1881
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1882
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1883
    //approximately reduce modulo 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1884
    qd_div_qd(&p0,&p1,&p2,&p3,a0[0],a1[0],a2[0],a3[0],_2pi[0],_2pi[1],_2pi[2],_2pi[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1885
    nint_qd(&z0,&z1,&z2,&z3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1886
    qd_mul_qd(&q0,&q1,&q2,&q3,_2pi[0],_2pi[1],_2pi[2],_2pi[3],z0,z1,z2,z3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1887
    qd_sub_qd(&r0,&r1,&r2,&r3,a0[0],a1[0],a2[0],a3[0],q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1888
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1889
    //approximately reduce modulo pi/2 and then modulo pi/1024
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1890
    j=floor(r0/_pi2[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1891
    s_mul_qd(&p0, &p1, &p2, &p3, j, _pi2[0], _pi2[1], _pi2[2], _pi2[3]); // Modified,2012/01/16 Saito
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1892
    qd_sub_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1893
    k=floor(t0/_pi1024[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1894
    s_mul_qd(&q0, &q1, &q2, &q3, k, _pi1024[0], _pi1024[1], _pi1024[2], _pi1024[3]); // Modified,2012/01/16 Saito
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1895
    qd_sub_qd(&t0,&t1,&t2,&t3,t0,t1,t2,t3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1896
    abs_k=(int)fabs(k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1897
    int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1898
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1899
    //checking errors
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1900
    if(j<-2 || j>2) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1901
        s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1902
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1903
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1904
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1905
    if(abs_k >256) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1906
        s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1907
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1908
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1909
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1910
    if(k==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1911
        switch(int_j) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1912
            case 0:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1913
                sin_taylor_qd(&s0[0],&s1[0],&s2[0],&s3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1914
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1915
            case 1:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1916
                cos_taylor_qd(&s0[0],&s1[0],&s2[0],&s3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1917
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1918
            case -1:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1919
                cos_taylor_qd(&s0[0],&s1[0],&s2[0],&s3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1920
                s0[0]=-s0[0]; s1[0]=-s1[0]; s2[0]=-s2[0]; s3[0]=-s3[0];
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1921
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1922
            case 2:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1923
            case -2:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1924
                sin_taylor_qd(&s0[0],&s1[0],&s2[0],&s3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1925
                s0[0]=-s0[0]; s1[0]=-s1[0]; s2[0]=-s2[0]; s3[0]=-s3[0];
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1926
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1927
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1928
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1929
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1930
    cos_table_qd(&u0,&u1,&u2,&u3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1931
    sin_table_qd(&v0,&v1,&v2,&v3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1932
    sincos_taylor_qd(&sin0,&sin1,&sin2,&sin3,&cos0,&cos1,&cos2,&cos3,t0,t1,t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1933
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1934
    if(j==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1935
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1936
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1937
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1938
            qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1939
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1940
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1941
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1942
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1943
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1944
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1945
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1946
    else if(j==1) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1947
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1948
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1949
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1950
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1951
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1952
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1953
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1954
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1955
            qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1956
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1957
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1958
    else if(j==-1) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1959
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1960
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1961
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1962
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1963
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1964
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1965
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1966
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1967
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1968
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1969
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1970
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1971
    else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1972
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1973
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1974
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1975
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1976
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1977
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1978
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1979
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1980
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1981
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  1982
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1983
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1984
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1985
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1986
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1987
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1988
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1989
// quad-double cosine
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1990
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1991
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1992
// a0, a1, a2, a3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1993
// a0 + a1 + a2 + a3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1994
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1995
// return (c0,c1,c2,c3) for qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1996
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1997
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1998
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1999
qd_cos(double *c0, double *c1, double *c2, double *c3, double *a0, double *a1, double *a2, double *a3)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2000
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2001
    double p0,p1,p2,p3, q0,q1,q2,q3, z0,z1,z2,z3, r0,r1,r2,r3, j, t0,t1,t2,t3, k,abs_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2002
    double _2pi[4] = {6.283185307179586232e+00,2.449293598294706414e-16,-5.989539619436679332e-33,2.224908441726730563e-49};  // 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2003
    double _pi2[4] = {1.570796326794896558e+00,6.123233995736766036e-17,-1.497384904859169833e-33,5.562271104316826408e-50};    // pi/2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2004
    double _pi1024[4] = {3.067961575771282340e-03,1.195944139792337116e-19,-2.924579892303066080e-36,1.086381075061880158e-52};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2005
    double u0,u1,u2,u3,v0,v1,v2,v3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2006
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2007
    int int_j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2008
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2009
    if(a0[0]==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2010
        c1[0]=1.0; c1[0]=0.0; c2[0]=0.0; c3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2011
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2012
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2013
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2014
    //approximately reduce modulo 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2015
    qd_div_qd(&p0,&p1,&p2,&p3,a0[0],a1[0],a2[0],a3[0],_2pi[0],_2pi[1],_2pi[2],_2pi[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2016
    nint_qd(&z0,&z1,&z2,&z3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2017
    qd_mul_qd(&q0,&q1,&q2,&q3,_2pi[0],_2pi[1],_2pi[2],_2pi[3],z0,z1,z2,z3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2018
    qd_sub_qd(&r0,&r1,&r2,&r3,a0[0],a1[0],a2[0],a3[0],q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2019
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2020
    //approximately reduce modulo pi/2 and then modulo pi/1024
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2021
    j=floor(r0/_pi2[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2022
    s_mul_qd(&p0, &p1, &p2, &p3, j, _pi2[0], _pi2[1], _pi2[2], _pi2[3]); // Modified,2012/01/16 Saito
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2023
    qd_sub_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2024
    k=floor(t0/_pi1024[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2025
    s_mul_qd(&q0, &q1, &q2, &q3, k, _pi1024[0], _pi1024[1], _pi1024[2], _pi1024[3]); // Modified,2012/01/16 Saito
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2026
    qd_sub_qd(&t0,&t1,&t2,&t3,t0,t1,t2,t3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2027
    abs_k=(int)fabs(k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2028
    int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2029
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2030
    //checking errors
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2031
    if(j<-2 || j>2) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2032
        c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2033
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2034
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2035
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2036
    if(abs_k >256) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2037
        c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2038
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2039
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2040
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2041
    if(k==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2042
        switch(int_j) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2043
            case 0:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2044
                cos_taylor_qd(&c0[0],&c1[0],&c2[0],&c3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2045
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2046
            case 1:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2047
                sin_taylor_qd(&c0[0],&c1[0],&c2[0],&c3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2048
                c0[0]=-c0[0]; c1[0]=-c1[0]; c2[0]=-c2[0]; c3[0]=-c3[0];
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2049
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2050
            case -1:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2051
                sin_taylor_qd(&c0[0],&c1[0],&c2[0],&c3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2052
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2053
            case 2:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2054
            case -2:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2055
                cos_taylor_qd(&c0[0],&c1[0],&c2[2],&c3[0],t0,t1,t2,t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2056
                c0[0]=-c0[0]; c1[0]=-c1[0]; c2[0]=-c2[0]; c3[0]=-c3[0];
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2057
                return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2058
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2059
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2060
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2061
    cos_table_qd(&u0,&u1,&u2,&u3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2062
    sin_table_qd(&v0,&v1,&v2,&v3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2063
    sincos_taylor_qd(&sin0,&sin1,&sin2,&sin3,&cos0,&cos1,&cos2,&cos3,t0,t1,t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2064
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2065
    if(j==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2066
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2067
            //u * cos_t - v * sin_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2068
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2069
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2070
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2071
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2072
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2073
            //u * cos_t + v * sin_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2074
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2075
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2076
            qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2077
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2078
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2079
    else if(j==1) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2080
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2081
            //-u * sin_t - v * cos_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2082
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2083
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2084
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2085
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2086
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2087
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2088
            //v * cos_t - u * sin_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2089
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2090
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2091
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2092
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2093
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2094
    else if(j==-1) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2095
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2096
            //u * sin_t + v * cos_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2097
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2098
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2099
            qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2100
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2101
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2102
            //u * sin_t - v * cos_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2103
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2104
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2105
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2106
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2107
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2108
    else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2109
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2110
            //v * sin_t - u * cos_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2111
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2112
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2113
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2114
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2115
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2116
            //-u * cos_t - v * sin_t;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2117
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2118
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2119
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2120
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2121
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2122
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2123
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2124
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2125
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2126
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2127
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2128
// quad-double sine and cosine
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2129
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2130
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2131
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2132
sincos_qd(double *s0, double *s1, double *s2, double *s3, double *c0, double *c1, double *c2, double *c3, double a0, double a1, double a2, double a3)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2133
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2134
    double p0,p1,p2,p3, q0,q1,q2,q3, z0,z1,z2,z3, r0,r1,r2,r3, j, t0,t1,t2,t3, k,abs_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2135
    double _2pi[4] = {6.283185307179586232e+00,2.449293598294706414e-16,-5.989539619436679332e-33,2.224908441726730563e-49};  // 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2136
    double _pi2[4] = {1.570796326794896558e+00,6.123233995736766036e-17,-1.497384904859169833e-33,5.562271104316826408e-50};    // pi/2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2137
    double _pi1024[4] = {3.067961575771282340e-03,1.195944139792337116e-19,-2.924579892303066080e-36,1.086381075061880158e-52};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2138
    double u0,u1,u2,u3,v0,v1,v2,v3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2139
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2140
    int int_j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2141
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2142
    if(a0==0.0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2143
        s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2144
        c0[0]=1.0; c1[0]=0.0; c2[0]=0.0; c3[0]=0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2145
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2146
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2147
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2148
    //approximately reduce modulo 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2149
    qd_div_qd(&p0,&p1,&p2,&p3,a0,a1,a2,a3,_2pi[0],_2pi[1],_2pi[2],_2pi[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2150
    nint_qd(&z0,&z1,&z2,&z3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2151
    qd_mul_qd(&q0,&q1,&q2,&q3,_2pi[0],_2pi[1],_2pi[2],_2pi[3],z0,z1,z2,z3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2152
    qd_sub_qd(&r0,&r1,&r2,&r3,a0,a1,a2,a3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2153
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2154
    //approximately reduce modulo pi/2 and then modulo pi/1024
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2155
    j=floor(r0/_pi2[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2156
    s_mul_qd(&p0, &p1, &p2, &p3, j, _pi2[0], _pi2[1], _pi2[2], _pi2[3]); // Modified,2012/01/16 Saito
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2157
    qd_sub_qd(&t0,&t1,&t2,&t3,r0,r1,r2,r3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2158
    k=floor(t0/_pi1024[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2159
    s_mul_qd(&q0, &q1, &q2, &q3, k, _pi1024[0], _pi1024[1], _pi1024[2], _pi1024[3]); // Modified,2012/01/16 Saito
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2160
    qd_sub_qd(&t0,&t1,&t2,&t3,t0,t1,t2,t3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2161
    abs_k=(int)fabs(k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2162
    int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2163
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2164
    //checking errors
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2165
    if(j<-2 || j>2) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2166
        s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2167
        c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2168
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2169
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2170
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2171
    if(abs_k >256) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2172
        s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2173
        c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2174
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2175
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2176
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2177
    sincos_taylor_qd(&sin0,&sin1,&sin2,&sin3,&cos0,&cos1,&cos2,&cos3,t0,t1,t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2178
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2179
    if(k==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2180
        if(j==0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2181
            s0[0]=sin0; s1[0]=sin1; s2[0]=sin2; s3[0]=sin3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2182
            c0[0]=cos0; c1[0]=cos1; c2[0]=cos2; c3[0]=cos3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2183
            return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2184
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2185
        else if(j==1) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2186
            s0[0]=cos0; s1[0]=cos1; s2[0]=cos2; s3[0]=cos3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2187
            c0[0]=-sin0; c1[0]=-sin1; c2[0]=-sin2; c3[0]=-sin3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2188
            return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2189
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2190
        else if(j==-1) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2191
            s0[0]=-cos0; s1[0]=-cos1; s2[0]=-cos2; s3[0]=-cos3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2192
            c0[0]=sin0; c1[0]=sin1; c2[0]=sin2; c3[0]=sin3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2193
            return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2194
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2195
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2196
            s0[0]=-sin0; s1[0]=-sin1; s2[0]=-sin2; s3[0]=-sin3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2197
            c0[0]=-cos0; c1[0]=-cos1; c2[0]=-cos2; c3[0]=-cos3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2198
            return;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2199
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2200
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2201
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2202
    cos_table_qd(&u0,&u1,&u2,&u3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2203
    sin_table_qd(&v0,&v1,&v2,&v3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2204
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2205
    if(j==0) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2206
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2207
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2208
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2209
            qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2210
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2211
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2212
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2213
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2214
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2215
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2216
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2217
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2218
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2219
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2220
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2221
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2222
            qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2223
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2224
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2225
    else if(j==1) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2226
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2227
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2228
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2229
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2230
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2231
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2232
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2233
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2234
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2235
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2236
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2237
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2238
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2239
            qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2240
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2241
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2242
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2243
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2244
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2245
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2246
    else if(j==-1) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2247
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2248
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2249
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2250
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2251
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2252
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2253
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2254
            qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2255
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2256
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2257
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2258
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2259
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2260
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2261
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2262
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2263
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2264
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2265
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2266
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2267
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2268
    else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2269
        if(k>0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2270
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2271
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2272
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2273
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2274
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2275
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2276
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2277
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2278
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2279
        else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2280
            qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2281
            qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2282
            qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2283
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2284
            qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2285
            qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2286
            p0=-p0; p1=-p1; p2=-p2; p3=-p3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2287
            qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2288
        }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2289
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2290
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2291
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2292
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2293
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2294
// quad-double tangent
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2295
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2296
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2297
// a0, a1, a2, a3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2298
// a0 + a1 + a2 + a3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2299
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2300
// return (t0,t1,t2,t3) for qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2301
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2302
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2303
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2304
qd_tan(double *t0, double *t1, double *t2, double *t3, double *a0, double *a1, double *a2, double *a3)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2305
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2306
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2307
    sincos_qd(&sin0,&sin1,&sin2,&sin3,&cos0,&cos1,&cos2,&cos3,a0[0],a1[0],a2[0],a3[0]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2308
    qd_div_qd(&t0[0],&t1[0],&t2[0],&t3[0],sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2309
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2310
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2311
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2312
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2313
// quad-double exponent
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2314
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2315
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2316
// x0, x1, x2, x3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2317
// x0 + x1 + x2 + x3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2318
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2319
// return (e0, e1, e2, e3) for qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2320
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2321
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2322
static void
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2323
qd_exp(double *e0, double *e1, double *e2, double *e3, double x0, double x1, double x2, double x3) {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2324
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2325
    double k = ldexp(1.0,16);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2326
    double inv_k = 1.0 / k;
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2327
    double log_2[4] = { 6.931471805599452862e-01, 2.319046813846299558e-17, 5.707708438416212066e-34, -3.582432210601811423e-50 };
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2328
    double m, p0,p1,p2,p3, q0,q1,q2,q3, r0,r1,r2,r3, s0,s1,s2,s3, t0,t1,t2,t3, v0,v1,v2,v3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2329
    int i;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2330
    double t=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2331
    double eps = 1.21543267145725e-63; // = 2^-209
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2332
    double thresh = inv_k * eps;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2333
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2334
    if((x0==0.0) && (x1==0.0) && (x2==0.0) && (x3==0.0)) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2335
        e0[0] = 1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2336
        e1[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2337
        e2[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2338
        e3[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2339
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2340
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2341
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2342
    if((x0==1.0) && (x1==0.0) && (x2==0.0) && (x3==0.0)) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2343
        e0[0] = 2.7182818284590451;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2344
        e1[0] = 1.4456468917292502e-16;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2345
        e2[0] = -2.127717108038176765e-33;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2346
        e3[0] = 1.515630159841218954e-49;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2347
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2348
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2349
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2350
    if(x0 <= -709) {               // underflow return zero
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2351
        e0[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2352
        e1[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2353
        e2[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2354
        e3[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2355
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2356
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2357
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2358
    if(x0 >= 709) {                // overflow return INF
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2359
        e0[0] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2360
        e1[0] = 1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2361
        e2[0] = 2.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2362
        e3[0] = 3.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2363
        return;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2364
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2365
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2366
    m = floor(x0 / log_2[0] + 0.5);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2367
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2368
    s_mul_qd(&p0, &p1, &p2, &p3, m, log_2[0], log_2[1], log_2[2], log_2[3]);  // p := m * log2
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2369
    qd_sub_qd(&q0, &q1, &q2, &q3, x0, x1, x2, x3, p0, p1, p2, p3);            // q := x - p;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2370
    r0 = q0 * inv_k;                                                          // r := q / k;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2371
    r1 = q1 * inv_k;                                                          // same as mul_pwr2
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2372
    r2 = q2 * inv_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2373
    r3 = q3 * inv_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2374
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2375
    qd_sqr(&p0, &p1, &p2, &p3, r0, r1, r2, r3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2376
    qd_add_qd(&s0, &s1, &s2, &s3, r0, r1, r2, r3, 0.5*p0, 0.5*p1, 0.5*p2, 0.5*p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2377
    i = 0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2378
    do {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2379
        qd_mul_qd(&p0, &p1, &p2, &p3, p0, p1, p2, p3, r0, r1, r2, r3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2380
        qd_mul_qd(&t0, &t1, &t2, &t3, p0, p1, p2, p3, inv_fact[i][0], inv_fact[i][1], inv_fact[i][2], inv_fact[i][3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2381
        i = i+1;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2382
        qd_add_qd(&s0, &s1, &s2, &s3, s0, s1, s2, s3, t0, t1, t2, t3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2383
    } while ((i < 9 /* <=17 */) && (fabs(t0)>thresh));
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2384
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2385
    // s := s*2 + s^2
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2386
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2387
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2388
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2389
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2390
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2391
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //3
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2392
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2393
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //4
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2394
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2395
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //5
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2396
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2397
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //6
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2398
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2399
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //7
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2400
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2401
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //8
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2402
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2403
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //9
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2404
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2405
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //10
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2406
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2407
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //11
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2408
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2409
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //12
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2410
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2411
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //13
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2412
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2413
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //14
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2414
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2415
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //15
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2416
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2417
    qd_add_qd(&s0, &s1, &s2, &s3, 2.0*s0, 2.0*s1, 2.0*s2, 2.0*s3, v0, v1, v2, v3);    //16
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2418
    qd_add_s(&s0, &s1, &s2, &s3, s0, s1, s2, s3, 1.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2419
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2420
    // ldexp(s, m)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2421
    // i.e. s *= 2^m
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2422
    t = ldexp(1.0, m);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2423
    // t = 1.0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2424
    // for (i=0; i<m; i++) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2425
    //     t=t*2;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2426
    // }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2427
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2428
    e0[0] = s0*t;    e1[0] = s1*t;    e2[0] = s2*t;    e3[0] = s3*t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2429
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2430
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2431
#if 0
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2432
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2433
/*********** Basic Functions ************/
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2434
/* Computes fl(a+b) and err(a+b).  Assumes |a| >= |b|. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2435
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2436
quick_two_sum(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2437
  double s = a + b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2438
  *errPtr = b - (s - a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2439
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2440
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2441
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2442
/* Computes fl(a-b) and err(a-b).  Assumes |a| >= |b| */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2443
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2444
quick_two_diff(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2445
  double s = a - b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2446
  *errPtr = (a - s) - b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2447
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2448
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2449
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2450
/* Computes fl(a+b) and err(a+b).  */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2451
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2452
two_sum(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2453
  double s = a + b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2454
  double bb = s - a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2455
  *errPtr = (a - (s - bb)) + (b - bb);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2456
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2457
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2458
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2459
/* Computes fl(a-b) and err(a-b).  */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2460
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2461
two_diff(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2462
  double s = a - b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2463
  double bb = s - a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2464
  *errPtr = (a - (s - bb)) - (b + bb);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2465
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2466
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2467
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2468
#ifndef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2469
/* Computes high word and lo word of a */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2470
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2471
split(double a, double *hiPtr, double *loPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2472
  double temp;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2473
  if (a > _QD_SPLIT_THRESH || a < -_QD_SPLIT_THRESH) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2474
    a *= 3.7252902984619140625e-09;  // 2^-28
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2475
    temp = _QD_SPLITTER * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2476
    *hiPtr = temp - (temp - a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2477
    *loPtr = a - *hiPtr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2478
    *hiPtr *= 268435456.0;          // 2^28
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2479
    *loPtr *= 268435456.0;          // 2^28
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2480
  } else {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2481
    temp = _QD_SPLITTER * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2482
    *hiPtr = temp - (temp - a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2483
    *loPtr = a - *hiPtr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2484
  }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2485
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2486
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2487
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2488
/* Computes fl(a*b) and err(a*b). */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2489
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2490
two_prod(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2491
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2492
  double p = a * b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2493
  *errPtr = QD_FMS(a, b, p);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2494
  return p;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2495
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2496
  double a_hi, a_lo, b_hi, b_lo;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2497
  double p = a * b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2498
  split(a, &a_hi, &a_lo);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2499
  split(b, &b_hi, &b_lo);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2500
  *errPtr = ((a_hi * b_hi - p) + a_hi * b_lo + a_lo * b_hi) + a_lo * b_lo;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2501
  return p;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2502
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2503
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2504
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2505
/* Computes fl(a*a) and err(a*a).  Faster than the above method. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2506
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2507
two_sqr(double a, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2508
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2509
  double p = a * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2510
  *errPtr = QD_FMS(a, a, p);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2511
  return p;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2512
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2513
  double hi, lo;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2514
  double q = a * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2515
  split(a, &hi, &lo);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2516
  *errPtr = ((hi * hi - q) + 2.0 * hi * lo) + lo * lo;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2517
  return q;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2518
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2519
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2520
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2521
/* Computes the nearest integer to d. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2522
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2523
nint(double d) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2524
  if (d == floor(d))
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2525
    return d;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2526
  return floor(d + 0.5);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2527
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2528
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2529
/* Computes the truncated integer. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2530
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2531
aint(double d) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2532
  return (d >= 0.0) ? floor(d) : ceil(d);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2533
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2534
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2535
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2536
renorm4(double *c0Ptr, double *c1Ptr, double *c2Ptr, double *c3Ptr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2537
  double s0, s1, s2 = 0.0, s3 = 0.0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2538
  double c0 = *c0Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2539
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2540
  if (isinf(c0)) return;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2541
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2542
  s0 = quick_two_sum(*c2Ptr, *c3Ptr, c3Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2543
  s0 = quick_two_sum(*c1Ptr, s0, c2Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2544
  c0 = quick_two_sum(c0, s0, c1Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2545
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2546
  s0 = c0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2547
  s1 = *c1Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2548
  if (s1 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2549
    s1 = quick_two_sum(s1, *c2Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2550
    if (s2 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2551
      s2 = quick_two_sum(s2, *c3Ptr, &s3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2552
    else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2553
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2554
  } else {
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2555
    s0 = quick_two_sum(s0, *c2Ptr, &s1);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2556
    if (s1 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2557
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2558
    else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2559
      s0 = quick_two_sum(s0, *c3Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2560
  }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2561
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2562
  *c0Ptr = s0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2563
  *c1Ptr = s1;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2564
  *c2Ptr = s2;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2565
  *c3Ptr = s3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2566
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2567
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2568
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2569
renorm5(double *c0Ptr, double *c1Ptr, double *c2Ptr, double *c3Ptr, double *c4Ptr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2570
  double s0, s1, s2 = 0.0, s3 = 0.0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2571
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2572
  if (isinf(*c0Ptr)) return;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2573
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2574
  s0 = quick_two_sum(*c3Ptr, *c4Ptr, c4Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2575
  s0 = quick_two_sum(*c2Ptr, s0, c3Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2576
  s0 = quick_two_sum(*c1Ptr, s0, c2Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2577
  *c0Ptr = quick_two_sum(*c0Ptr, s0, c1Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2578
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2579
  s0 = *c0Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2580
  s1 = *c1Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2581
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2582
  s0 = quick_two_sum(*c0Ptr, *c1Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2583
  if (s1 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2584
    s1 = quick_two_sum(s1, *c2Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2585
    if (s2 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2586
      s2 =quick_two_sum(s2, *c3Ptr, &s3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2587
      if (s3 != 0.0)
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2588
        s3 += *c4Ptr;
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2589
      else
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2590
        s2 += *c4Ptr;
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2591
    } else {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2592
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2593
      if (s2 != 0.0)
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2594
        s2 = quick_two_sum(s2, *c4Ptr, &s3);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2595
      else
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2596
        s1 = quick_two_sum(s1, *c4Ptr, &s2);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2597
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2598
  } else {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2599
    s0 = quick_two_sum(s0, *c2Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2600
    if (s1 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2601
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2602
      if (s2 != 0.0)
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2603
        s2 = quick_two_sum(s2, *c4Ptr, &s3);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2604
      else
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2605
        s1 = quick_two_sum(s1, *c4Ptr, &s2);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2606
    } else {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2607
      s0 = quick_two_sum(s0, *c3Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2608
      if (s1 != 0.0)
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2609
        s1 = quick_two_sum(s1, *c4Ptr, &s2);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2610
      else
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2611
        s0 = quick_two_sum(s0, *c4Ptr, &s1);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2612
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2613
  }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2614
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2615
  *c0Ptr = s0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2616
  *c1Ptr = s1;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2617
  *c2Ptr = s2;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2618
  *c3Ptr = s3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2619
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2620
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2621
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2622
three_sum(double *aPtr, double *bPtr, double *cPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2623
  double t1, t2, t3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2624
  t1 = two_sum(*aPtr, *bPtr, &t2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2625
  *aPtr  = two_sum(*cPtr, t1, &t3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2626
  *bPtr  = two_sum(t2, t3, cPtr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2627
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2628
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2629
INLINE void three_sum2(double *aPtr, double *bPtr, double *cPtr) {
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2630
  double t1, t2, t3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2631
  t1 = two_sum(*aPtr, *bPtr, &t2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2632
  *aPtr  = two_sum(*cPtr, t1, &t3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2633
  *bPtr = t2 + t3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2634
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2635
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2636
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2637
#if 0
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2638
/* These are provided to give consistent
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2639
   interface for double with double-double and quad-double. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2640
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2641
sincosh(double t, double &sinh_t, double &cosh_t) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2642
  sinh_t = sinh(t);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2643
  cosh_t = cosh(t);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2644
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2645
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2646
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2647
sqr(double t) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2648
  return t * t;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2649
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2650
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2651
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2652
to_double(double a) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2653
    return a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2654
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2655
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2656
INLINE int
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2657
to_int(double a)    {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2658
    return static_cast<int>(a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2659
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2660
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2661
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2662
%}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2663
! !
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2664
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2665
!QDouble class methodsFor:'documentation'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2666
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2667
copyright
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2668
"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2669
 COPYRIGHT (c) 2017 by eXept Software AG
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2670
              All Rights Reserved
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2671
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2672
 This software is furnished under a license and may be used
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2673
 only in accordance with the terms of that license and with the
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2674
 inclusion of the above copyright notice.   This software may not
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2675
 be provided or otherwise made available to, or used by, any
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2676
 other person.  No title to or ownership of the software is
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2677
 hereby transferred.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2678
"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2679
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2680
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2681
documentation
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2682
"
4391
f2ece85e1ae3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4390
diff changeset
  2683
    ATTENTION: ongoing, unfinished work.
4450
c832d7890dda #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4447
diff changeset
  2684
    No warranty that this works correctly...
4391
f2ece85e1ae3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4390
diff changeset
  2685
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2686
    QDoubles represent rational numbers with extended, but still limited precision.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2687
4451
1550f45dc062 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4450
diff changeset
  2688
    In contrast to Floats (which use the C-compiler's native 64bit 'double' format),
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  2689
    QDoubles give you roughly 200 bit or approx. 60 decimal digits of precision.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2690
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2691
    Representation:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2692
        QDoubles use 4 IEEE doubles, each keeping 53 bits of precision.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2693
        A qDouble's value is the sum of those 4 doubles,
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2694
        and a qDouble keeps this unevaluated sum as its state.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2695
        (due to overlap and rounding, the final precision is less than 53*4)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2696
        The exponent range is still the double exponent range,
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2697
        but the number of mantissa bits is rougly multiplied by 4.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2698
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2699
    Range and Precision of Storage Formats: see LimitedPrecisionReal >> documentation
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  2700
    The number of decmal digits:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2701
        QDouble decimalPrecision     -> 61
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2702
        LongFloat decimalPrecision   -> 19
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2703
        Float decimalPrecision       -> 16
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2704
        ShortFloat decimalPrecision  -> 7
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  2705
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  2706
    The number of bits:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2707
        QDouble precision            -> 204
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2708
        LongFloat precision          -> 64
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2709
        Float precision              -> 53
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2710
        ShortFloat precision         -> 24
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2711
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2712
    Notice:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2713
        when assigning a converted double precision number as in:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2714
            qd := 1.0 asQDouble.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2715
        you still get only a regular double precision approximation to 0.1
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2716
        because the error is already inherit in the double.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2717
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2718
        For a full precision constant, you (currently) need to convert from a string
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2719
        (because the compilers do not know about them, yet):
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2720
            qd := QDouble readFrom:'0.1'.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2721
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2722
        To see the error of the double precision version, compute:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2723
            (0.1 asQDouble) - (QDouble readFrom:'0.1')
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2724
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2725
    [author:]
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2726
        Claus Gittinger
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2727
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2728
    [see also:]
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2729
        Number
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2730
        Float ShortFloat LongFloat
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2731
        Fraction FixedPoint Integer Complex
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2732
        FloatArray DoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2733
"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2734
!
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2735
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2736
examples
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2737
"
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2738
  Floats, LongFloats suffer from loosing bits:
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2739
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2740
     (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2741
    -(Float readFrom:'0.333333333333333333333333333333333333333333333333333333333')
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2742
        -> 0.0
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2743
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2744
       (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2745
     = (Float readFrom:'0.333333333333333333333333333333333333333333333333333333333')
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2746
        -> true
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2747
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2748
       (Float readFrom:'0.33333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2749
     = (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333333333333')
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2750
        -> true
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2751
1000 0110 1000 0101 1000 0101 1000 0101 1000 0101 1000 0101 1101 0101 0011 1111
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2752
       (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2753
     = (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2754
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2755
     (LongFloat readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2756
    -(LongFloat readFrom:'0.333333333333333333333333333333333333333333333333333333333')
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2757
        -> 0.0
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2758
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2759
      (LongFloat readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2760
    = (LongFloat readFrom:'0.333333333333333333333333333333333333333333333333333333333')
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2761
        -> 0.0
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2762
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2763
 (QDouble readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2764
-(QDouble readFrom:'0.333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2765
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2766
 (QDouble readFrom:'0.33333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2767
-(QDouble readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2768
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2769
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2770
 (QDouble readFrom:'0.33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2771
-(QDouble readFrom:'0.3333333333333333333333333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2772
"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2773
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2774
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2775
!QDouble class methodsFor:'instance creation'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2776
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2777
basicNew
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2778
    "return a new quad-precision double - here we return 0.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2779
     Notice that numbers are usually NOT created this way ...
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2780
     It's implemented here to allow things like binary store & load
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2781
     of floats. (but even this support will go away eventually, it's not
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2782
     a good idea to store the bits of a float - the reader might have a
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2783
     totally different representation - so floats should be
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2784
     binary stored in a device independent format."
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2785
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2786
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2787
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2788
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2789
#else
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2790
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2791
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2792
    __qNew_qdReal(newQD, 0.0, 0.0, 0.0, 0.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2793
    RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2794
#endif /* not SCHTEAM */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2795
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2796
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2797
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2798
     self basicNew
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2799
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2800
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2801
    "Created: / 12-06-2017 / 16:00:38 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2802
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2803
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2804
d0:d0 d1:d1 d2:d2 d3:d3
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2805
    "return a new quad-precision double from individual double components"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2806
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2807
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2808
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2809
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2810
#else
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2811
    OBJ newQD;
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2812
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2813
    if (__isFloatLike(d0)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2814
     && __isFloatLike(d1)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2815
     && __isFloatLike(d2)
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2816
     && __isFloatLike(d3)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2817
        __qNew_qdReal(newQD, __floatVal(d0), __floatVal(d1),
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2818
                             __floatVal(d2), __floatVal(d3));
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2819
        RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2820
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2821
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2822
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2823
    self error:'invalid argument'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2824
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2825
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2826
     self d0: 3.141592653589793116e+00
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2827
          d1: 1.224646799147353207e-16
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2828
          d2: -2.994769809718339666e-33
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2829
          d3: 1.112454220863365282e-49
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2830
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2831
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2832
    "Created: / 12-06-2017 / 20:17:14 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2833
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2834
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2835
fromDoubleArray:aDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2836
    "return a new quad-precision double from coercing a double array"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2837
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2838
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2839
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2840
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2841
#else
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2842
    OBJ newQD;
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2843
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2844
    if (__isDoubleArray(aDoubleArray)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2845
        double* __d__ =  __DoubleArrayInstPtr(aDoubleArray)->d_element;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2846
        __qNew_qdReal(newQD, __d__[0], __d__[1], __d__[2], __d__[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2847
        RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2848
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2849
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2850
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2851
    self error:'invalid argument'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2852
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2853
    "
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2854
     self fromDoubleArray(DoubleArray
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2855
                                with: 3.141592653589793116e+00
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2856
                                with: 1.224646799147353207e-16
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2857
                                with: -2.994769809718339666e-33
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2858
                                with: 1.112454220863365282e-49)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2859
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2860
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2861
    "Created: / 12-06-2017 / 18:25:32 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2862
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2863
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2864
fromFloat:aFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2865
    "return a new quad-precision double from coercing aFloat"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2866
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2867
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2868
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2869
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2870
#else
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2871
    double dVal;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2872
    OBJ newQD;
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2873
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2874
    if (__isFloatLike(aFloat)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2875
        dVal = __floatVal(aFloat);
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2876
    } else if (__isShortFloat(aFloat)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2877
        dVal = __shortFloatVal(aFloat);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2878
    } else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2879
        goto badArg;
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2880
    }
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2881
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2882
    __qNew_qdReal(newQD, dVal, 0.0, 0.0, 0.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2883
    RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2884
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2885
badArg: ;
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2886
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2887
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2888
%}.
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2889
    self argumentError:'invalid (non-float) argument'
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2890
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2891
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2892
     self fromFloat:1.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2893
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2894
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2895
    "Created: / 12-06-2017 / 16:06:54 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2896
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2897
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2898
fromInteger:anInteger
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2899
    "return a new quad-precision double from coercing anInteger"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2900
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2901
%{  /* NOCONTEXT */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2902
#ifdef __SCHTEAM__
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2903
    ERROR("trying to instantiate a qDouble");
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2904
#else
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2905
    OBJ newQD;
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2906
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2907
    if (__isSmallInteger(anInteger)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2908
        INT iVal = __smallIntegerVal(anInteger);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2909
        double *d;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2910
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2911
        __qNew(newQD, sizeof(struct __qDoubleStruct));
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2912
        __stx_setClass(newQD, QDouble);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2913
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2914
        d = __QDoubleInstPtr(newQD)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2915
        d[1] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2916
        d[2] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2917
        d[3] = 0.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2918
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2919
        // need more than 52bits?
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2920
        if ((sizeof(INT) > 52)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2921
         && ((iVal > 0xFFFFFFFFFFFFF) || (iVal < -0xFFFFFFFFFFFFF))) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2922
            d[0] = (double)(iVal & ~0xFFFFFFFF);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2923
            d[1] = (double)(iVal & 0xFFFFFFFF);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2924
            renorm(&(d[0]), &(d[1]), &(d[2]), &(d[3]), d[0], d[1], 0.0, 0.0, 0.0);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2925
            // renorm4(&(a[0]), &(a[1]), &(a[2]), &(a[3]));
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2926
        } else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2927
            d[0] = (double)iVal;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2928
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2929
        RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2930
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2931
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2932
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2933
    ^ super fromInteger:anInteger
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2934
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2935
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2936
     self fromInteger:2
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2937
     self fromInteger:16rFFFFFFFF            -- 32bit 4294967295.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2938
     self fromInteger:16rFFFFFFFFFFFF        -- 48bit 281474976710655.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2939
     self fromInteger:16rFFFFFFFFFFFFF       -- 52bit 4503599627370495.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2940
     self fromInteger:16rFFFFFFFFFFFFFF      -- 56bit 72057594037927935.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2941
     self fromInteger:16rFFFFFFFFFFFFFFF     -- 60bit 1152921504606846975.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2942
     self fromInteger:16r1FFFFFFFFFFFFFFF    -- 61bit 2305843009213693951.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2943
     self fromInteger:16r3FFFFFFFFFFFFFFF    -- 62bit 4611686018427387903.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2944
     self fromInteger:16r7FFFFFFFFFFFFFFF    -- 63bit 9223372036854775807.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2945
     self fromInteger:16rFFFFFFFFFFFFFFFF    -- 64bit 18446744073709551615.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2946
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2947
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2948
    "Created: / 12-06-2017 / 16:10:10 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2949
    "Modified: / 04-07-2017 / 12:51:52 / cg"
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2950
!
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2951
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2952
fromLongFloat:aFloat
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2953
    "return a new quad-precision double from coercing aFloat"
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2954
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2955
%{  /* NOCONTEXT */
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2956
#ifdef __SCHTEAM__
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2957
    ERROR("trying to instantiate a qDouble");
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2958
#else
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2959
    if (__isLongFloat(aFloat)) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2960
        LONGFLOAT_t lVal;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2961
        double l0, l1, l2, l3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2962
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2963
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2964
        lVal = __longFloatVal(aFloat);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2965
        l0 = (double)lVal;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2966
        lVal -= l0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2967
        l1 = (double)lVal;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2968
        renorm(&l0, &l1, &l2, &l3, l0, l1, 0.0, 0.0, 0.0);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2969
        __qNew_qdReal(newQD, l0, l1, l2, l3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2970
        RETURN (newQD);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2971
    }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2972
badArg: ;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2973
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2974
#endif
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2975
%}.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2976
    self argumentError:'invalid (non-float) argument'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2977
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2978
    "
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2979
     self fromLongFloat:1.0 asLongFloat
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2980
     1.0 asLongFloat asQDouble     1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2981
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2982
     (1.0 + 1e-16) - 1.0                -> 0.0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2983
     (1.0 asLongFloat + 1e-16) - 1.0    -> 9.996344030316350881E-17
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2984
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2985
     (1.0 asLongFloat + 1e-16) asQDouble - 1.0 
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2986
                                        -> 9.99634403031635016638603121124e-17
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  2987
    "
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2988
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2989
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2990
!QDouble class methodsFor:'coercing & converting'!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2991
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2992
coerce:aNumber
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2993
    "convert the argument aNumber into an instance of the receiver's class and return it."
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2994
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2995
    ^ aNumber asQDouble
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2996
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2997
    "Created: / 12-06-2017 / 17:13:47 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2998
    "Modified: / 12-06-2017 / 21:09:06 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2999
! !
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3000
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3001
!QDouble class methodsFor:'constants'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3002
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3003
NaN
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3004
    "return a QDouble which represents not-a-Number (i.e. an invalid number)"
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3005
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3006
    NaN isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3007
        NaN := self d0:(Float NaN) d1:(Float NaN) d2:(Float NaN) d3:(Float NaN)
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3008
    ].
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3009
    ^ NaN
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3010
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3011
    "Created: / 21-06-2017 / 20:44:57 / cg"
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3012
!
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3013
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3014
e
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3015
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  3016
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3017
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3018
    E isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3019
        E := self d0: 2.718281828459045091e+00
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3020
                  d1: 1.445646891729250158e-16
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3021
                  d2: -2.127717108038176765e-33
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3022
                  d3: 1.515630159841218954e-49
4388
742f099741bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4387
diff changeset
  3023
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3024
    ^ E
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3025
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3026
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3027
     self e printfPrintString:'%.61f'
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3028
       -> '2.7182818284590452353602874713526624977572470936999595749669676'
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3029
     Wolfram says:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3030
           2.71828182845904523536028747135266249775724709369995957496696762772407663035354759457138217852516642742746
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3031
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3032
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3033
    "Created: / 12-06-2017 / 18:29:36 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3034
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3035
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3036
fmax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3037
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  3038
     (returns approx. 200 bits of precision)"
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3039
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3040
    FMax isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3041
        FMax := self d0: 1.797693134862314E+308
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3042
                     d1: 9.97920154767359795037e+291
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3043
                     d2: 5.53956966280111259858e+275
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3044
                     d3: 3.07507889307840487279e+259
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3045
    ].
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3046
    ^ FMax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3047
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3048
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3049
     Float fmax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3050
     self fmax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3051
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3052
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3053
    "Created: / 14-06-2017 / 19:14:18 / cg"
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3054
!
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3055
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3056
fmin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3057
    "return the smallest representable instance of this class"
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3058
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3059
    FMin isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3060
        FMin := Float fmin asQDouble. "/ 1.6259745436952323e-260 asQDouble
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3061
    ].
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3062
    ^ FMin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3063
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3064
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3065
     QDouble fmin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3066
     Float fmin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3067
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3068
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3069
    "Created: / 14-06-2017 / 19:14:49 / cg"
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3070
!
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3071
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3072
infinity
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3073
    ^ Infinity positive
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3074
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3075
    "Created: / 18-06-2017 / 23:41:07 / cg"
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3076
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3077
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3078
ln10
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3079
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  3080
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3081
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3082
    Ln10 isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3083
        Ln10 := self d0: 2.302585092994045901e+00
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3084
                     d1: -2.170756223382249351e-16
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3085
                     d2: -9.984262454465776570e-33
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3086
                     d3: -4.023357454450206379e-49
4388
742f099741bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4387
diff changeset
  3087
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3088
    ^ Ln10
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3089
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3090
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3091
     self ln10 printfPrintString:'%.61f'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3092
        -> '2.3025850929940456840179914546843642076011014886287729760333279'
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3093
     Wolfram says:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3094
            2.30258509299404568401799145468436420760110148862877297603332790096757260967735248023599720508959829834196778404228...
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3095
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3096
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3097
    "Created: / 12-06-2017 / 18:32:29 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3098
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3099
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3100
ln2
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3101
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  3102
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3103
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3104
    Ln2 isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3105
        Ln2 := self d0: 6.931471805599452862e-01
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3106
                    d1: 2.319046813846299558e-17
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3107
                    d2: 5.707708438416212066e-34
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3108
                    d3: -3.582432210601811423e-50
4388
742f099741bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4387
diff changeset
  3109
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3110
    ^ Ln2
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3111
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3112
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3113
     self ln2 printfPrintString:'%.61f'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3114
        -> '0.6931471805599452709398341558750792990469129794959648865081141'
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3115
     Wolfram says:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3116
            0.69314718055994530941723212145817656807550013436025525412068000949339362196969471560586332699641868754200148102057...
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3117
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3118
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3119
    "Created: / 12-06-2017 / 18:31:34 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3120
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3121
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3122
negativeInfinity
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3123
    ^ Infinity negative
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3124
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3125
    "Created: / 18-06-2017 / 23:40:47 / cg"
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3126
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3127
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3128
pi
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3129
    "return the constant pi as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  3130
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3131
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3132
    Pi isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3133
        Pi := self d0: 3.141592653589793116e+00
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3134
                   d1: 1.224646799147353207e-16
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3135
                   d2: -2.994769809718339666e-33
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3136
                   d3: 1.112454220863365282e-49
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3137
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3138
    ^ Pi
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3139
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3140
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3141
     self pi printfPrintString:'%.60f'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3142
          '3.141592653589793238462643383279502884197169399375105820974945'
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3143
     Wolfram says:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3144
           3.141592653589793238462643383279502884197169399375105820974944592307816406286208998628034825342117068
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3145
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3146
     (QDouble readFrom:'3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253')
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3147
     printfPrintString:'%.60f'
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3148
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3149
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3150
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3151
    "Created: / 12-06-2017 / 18:27:13 / cg"
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3152
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3153
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3154
unity
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3155
    "return the neutral element for multiplication (1.0) as QDouble"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3156
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3157
    QDoubleOne isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3158
        QDoubleOne := 1.0 asQDouble.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3159
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3160
    ^ QDoubleOne
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3161
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3162
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3163
     self unity
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3164
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3165
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3166
    "Created: / 15-06-2017 / 11:45:22 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3167
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3168
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3169
zero
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3170
    "return the neutral element for addition (0.0) as QDouble"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3171
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3172
    QDoubleZero isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3173
        QDoubleZero := 0.0 asQDouble
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3174
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3175
    ^ QDoubleZero
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3176
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3177
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3178
     self zero
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3179
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3180
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3181
    "Created: / 15-06-2017 / 11:44:13 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3182
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3183
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3184
!QDouble class methodsFor:'queries'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3185
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3186
defaultPrintPrecision
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3187
    "return the number of decimal digits printed by default"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3188
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3189
    ^ 30
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3190
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3191
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3192
     ShortFloat defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3193
     Float defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3194
     LongFloat defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3195
     QDouble defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3196
     QuadFloat defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3197
     OctaFloat defaultPrintPrecision
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3198
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3199
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3200
    "Created: / 17-06-2017 / 02:58:51 / cg"
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3201
    "Modified: / 21-06-2017 / 13:39:08 / cg"
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3202
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3203
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3204
epsilon
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3205
    "return the maximum relative spacing of instances of mySelf
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  3206
     (i.e. the value-delta of the least significant bit)
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  3207
     see https://en.wikipedia.org/wiki/Machine_epsilon"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3208
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3209
    "/ ^ 1.2154326714572500565324311366323150942261000827598106963711353e-63
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3210
    Epsilon isNil ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3211
        Epsilon := self computeEpsilon.
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3212
    ].
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3213
    ^ Epsilon
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3214
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3215
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3216
     Float epsilon       -> 2.22044604925031E-16
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3217
     ShortFloat epsilon  -> 1.19209289550781E-07
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3218
     LongFloat epsilon   -> 1.0842021724855E-19
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3219
     QDouble epsilon     -> 7.77876909732643E-62 / (1.215432671457250056532e-63 read comment in precision)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3220
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3221
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3222
    "Created: / 12-06-2017 / 18:52:44 / cg"
4443
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  3223
    "Modified: / 22-06-2017 / 15:34:56 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3224
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3225
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3226
numBitsInExponent
5275
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3227
    "answer the number of bits in the exponent.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3228
     I use regular IEEE doubles to store the value,
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3229
     thus my exponent bits are the same as double's exponent bits"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3230
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3231
    ^ Float numBitsInExponent
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3232
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3233
    "
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3234
     1.0 asQDouble numBitsInExponent
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3235
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3236
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3237
    "Created: / 12-06-2017 / 11:11:04 / cg"
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3238
    "Modified (comment): / 28-05-2019 / 08:55:04 / Claus Gittinger"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3239
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3240
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3241
numBitsInMantissa
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3242
    "answer the number of bits in the mantissa.
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3243
     Here, a fake number is returned"
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3244
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3245
    ^ (Float numBitsInMantissa - 1) * 4
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3246
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3247
    "
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3248
     1.0 asFloat numBitsInMantissa
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3249
     1.0 asShortFloat numBitsInMantissa
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3250
     1.0 asLongFloat numBitsInMantissa
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3251
     1.0 asQDouble numBitsInMantissa
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3252
     1.0 asQDouble class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3253
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3254
     Float numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3255
     ShortFloat numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3256
     QDouble numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3257
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3258
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3259
    "Created: / 12-06-2017 / 11:13:44 / cg"
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3260
    "Modified (comment): / 20-06-2017 / 11:05:26 / cg"
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3261
    "Modified (comment): / 28-05-2019 / 09:07:07 / Claus Gittinger"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3262
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3263
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3264
precision
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3265
    "answer the number of bits in the mantissa"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3266
4431
a7e1399f418e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4430
diff changeset
  3267
    "/ subtract some due to overlap in the component numbers
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3268
    "/ actual precision seems to be more like:
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3269
    "/ ^ (Float precision) * 4 - 3 + 1.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3270
    "/ but I am a bit conservative here:
4431
a7e1399f418e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4430
diff changeset
  3271
    ^ (Float precision - 2) * 4
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3272
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3273
    "
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3274
     ShortFloat precision  -> 24
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3275
     Float precision       -> 53
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3276
     LongFloat precision   -> 64
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3277
     QDouble precision     -> 204
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3278
     QuadFloat precision   -> 113
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3279
     OctaFloat precision   -> 237
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3280
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3281
     1.0 class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3282
     1.0 asShortFloat class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3283
     1.0 asLongFloat class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3284
     1.0 asQDouble class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3285
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3286
     Float numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3287
     ShortFloat numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3288
     QDouble numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3289
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3290
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3291
    "Created: / 12-06-2017 / 18:49:11 / cg"
4431
a7e1399f418e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4430
diff changeset
  3292
    "Modified (comment): / 20-06-2017 / 12:59:00 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3293
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3294
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3295
radix
5057
cc72e91af490 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 4981
diff changeset
  3296
    "answer the radix of a QDouble's exponent
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3297
     This is an IEEE float, which is represented as binary"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3298
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3299
    ^ Float radix
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3300
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3301
    "Created: / 12-06-2017 / 18:50:04 / cg"
5057
cc72e91af490 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 4981
diff changeset
  3302
    "Modified (comment): / 19-07-2019 / 17:28:25 / Claus Gittinger"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3303
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3304
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3305
!QDouble methodsFor:'arithmetic'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3306
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3307
* aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3308
    "return the product of the receiver and the argument, aNumber"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3309
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3310
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3311
    if (__isFloatLike(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3312
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3313
        double b = __floatVal(aNumber);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3314
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3315
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3316
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3317
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3318
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3319
        s_mul_qd(&c0, &c1, &c2, &c3, b, a[0], a[1], a[2], a[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3320
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3321
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3322
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3323
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3324
    if (__isQDouble(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3325
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3326
        double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3327
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3328
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3329
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3330
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3331
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3332
        qd_mul_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3333
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3334
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3335
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3336
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3337
%}.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3338
    ^ aNumber productFromQDouble:self
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3339
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3340
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3341
     (QDouble fromFloat:1e20) * 2.0
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3342
     (QDouble fromFloat:1e20) * 1e20
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3343
     (QDouble fromFloat:1e20) * (QDouble fromFloat:1e20)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3344
     ((QDouble fromFloat:1e20) * (QDouble fromFloat:2.0)) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3345
     ((QDouble fromFloat:1e-20) * (QDouble fromFloat:2.0)) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3346
     ((QDouble fromFloat:2.0) * (QDouble fromFloat:2.0)) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3347
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3348
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3349
    "Created: / 12-06-2017 / 23:41:39 / cg"
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3350
    "Modified (comment): / 15-06-2017 / 00:34:41 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3351
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3352
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3353
+ aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3354
    "return the sum of the receiver and the argument, aNumber"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3355
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3356
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3357
    if (__isFloatLike(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3358
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3359
        double b = __floatVal(aNumber);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3360
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3361
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3362
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3363
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3364
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3365
        qd_add_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3366
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3367
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3368
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3369
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3370
    if (__isQDouble(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3371
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3372
        double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3373
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3374
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3375
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3376
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3377
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3378
        qd_add_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3379
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3380
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3381
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3382
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3383
%}.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3384
    ^ aNumber sumFromQDouble:self
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3385
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3386
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3387
     ((QDouble fromFloat:1e20) + 1.0) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3388
     ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3389
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3390
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3391
    "Created: / 12-06-2017 / 16:17:46 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3392
    "Modified: / 12-06-2017 / 23:06:22 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3393
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3394
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3395
- aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3396
    "return the sum of the receiver and the argument, aNumber"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3397
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3398
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3399
    if (__isFloatLike(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3400
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3401
        double b = __floatVal(aNumber);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3402
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3403
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3404
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3405
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3406
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3407
        qd_add_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], -b);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3408
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3409
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3410
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3411
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3412
    if (__isQDouble(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3413
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3414
        double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3415
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3416
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3417
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3418
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3419
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3420
        qd_sub_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3421
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3422
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3423
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3424
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3425
%}.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3426
    ^ self + (aNumber negated)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3427
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3428
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3429
     (QDouble fromFloat:1e20) - 1.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3430
     ((QDouble fromFloat:1e20) - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3431
     (QDouble fromFloat:1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3432
     ((QDouble fromFloat:1e-20) - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3433
     ((QDouble fromFloat:2.0) - (QDouble fromFloat:1.0)) asDoubleArray
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3434
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3435
     ((QDouble fromFloat:2.0) - (QDouble fromFloat:1.0) + (QDouble fromFloat:1.0)) asDoubleArray
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3436
     ((QDouble fromFloat:1e-20) - (QDouble fromFloat:1.0) + (QDouble fromFloat:1.0)) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3437
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3438
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3439
    "Created: / 12-06-2017 / 23:41:39 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3440
    "Modified (comment): / 15-06-2017 / 00:34:41 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3441
!
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3442
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3443
/ aNumber
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3444
    "return the quotient of the receiver and the argument, aNumber"
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3445
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3446
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3447
    if (__isFloatLike(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3448
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3449
        double b = __floatVal(aNumber);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3450
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3451
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3452
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3453
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3454
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3455
        qd_div_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3456
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3457
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3458
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3459
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3460
    if (__isQDouble(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3461
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3462
        double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3463
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3464
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3465
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3466
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3467
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3468
        qd_div_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3469
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3470
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3471
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3472
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3473
%}.
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3474
    ^ aNumber quotientFromQDouble:self
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3475
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3476
    "
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3477
     ((QDouble fromFloat:1e20) / (QDouble fromFloat:2.0)) asDoubleArray
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3478
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3479
     ((QDouble fromFloat:1.2345) / (QDouble fromFloat:10.0)) asDoubleArray
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3480
     ((QDouble fromFloat:1.2345) / 10.0) asDoubleArray
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3481
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3482
    "
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3483
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3484
    "Created: / 13-06-2017 / 17:59:09 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3485
    "Modified (comment): / 15-06-2017 / 00:14:26 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3486
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3487
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3488
!QDouble methodsFor:'coercing & converting'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3489
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3490
asDoubleArray
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3491
    ^ DoubleArray
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3492
            with:self d0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3493
            with:self d1
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3494
            with:self d2
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3495
            with:self d3.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3496
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3497
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3498
     (QDouble fromFloat:1.0) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3499
     (1.0 asQDouble + 1e-40) asDoubleArray
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3500
     (QDouble fromFloat:2.0) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3501
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3502
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3503
    "Created: / 12-06-2017 / 18:19:19 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3504
    "Modified (comment): / 13-06-2017 / 17:58:09 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3505
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3506
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3507
asFloat
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3508
    ^ self d0 + self d1
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3509
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3510
    "
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3511
     (QDouble fromFloat:1.0) asFloat  -> 1.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3512
     (QDouble fromFloat:2.0) asFloat  -> 2.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3513
     (2.0 asQDouble + 1e-14) asFloat  -> 2.00000000000001
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3514
     (2.0 + 1e-14) - 2.0              -> 1.02140518265514E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3515
     (2.0 + 1e-15) - 2.0              -> 8.88178419700125E-16
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3516
     (2.0 + 1e-16) - 2.0              -> 0.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3517
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3518
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3519
    "Created: / 12-06-2017 / 18:15:27 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3520
    "Modified: / 13-06-2017 / 17:56:50 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3521
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3522
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3523
asInteger
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3524
    ^ self d0 asInteger
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3525
    + self d1 asInteger
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3526
    + self d2 asInteger
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3527
    + self d3 asInteger
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3528
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3529
    "Created: / 19-06-2017 / 18:07:17 / cg"
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3530
!
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3531
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3532
asLargeFloat
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3533
    ^ (self d0 asLargeFloat precision:self precision) + self d1 + self d2 + self d3
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3534
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3535
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3536
     (QDouble fromFloat:1.0) asLargeFloat    -> 1.000000000000000000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3537
     (QDouble fromFloat:2.0) asLargeFloat    -> 2.000000000000000000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3538
     (2.0 asQDouble + 1e-14) asLargeFloat    -> 2.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3539
     (2.0 asLargeFloat + 1e-14) - 2.0        -> 0.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3540
     (2.0  + 1e-14) - 2.0                   -> 1.02140518265514E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3541
     (2.0 asLargeFloat + 1e-14) - 2.0       -> 0.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3542
     (2.0 asLargeFloat + 1e-15) - 2.0       -> 0.000000000000000888178419700125
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3543
     (2.0 asLargeFloat + 1e-16) - 2.0       -> 0.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3544
     (2QL + 1QL-14) - 2QL                   -> 0.000000000000010000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3545
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3546
!
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3547
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3548
asLongFloat
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3549
    ^ self d0 asLongFloat + self d1
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3550
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3551
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3552
     (QDouble fromFloat:1.0) asLongFloat    -> 1.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3553
     (QDouble fromFloat:2.0) asLongFloat    -> 2.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3554
     (2.0 asQDouble + 1e-14) asLongFloat    -> 2.00000000000001
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3555
     (2.0 asLongFloat + 1e-14) - 2.0        -> 1.00000303177028016E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3556
     (2.0  + 1e-14) - 2.0                   -> 1.02140518265514E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3557
     (2.0 asLargeFloat + 1e-14) - 2.0       -> 0.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3558
     (2.0 asLargeFloat + 1e-15) - 2.0       -> 0.000000000000000888178419700125
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3559
     (2.0 asLargeFloat + 1e-16) - 2.0       -> 0.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3560
     (2QL + 1QL-14) - 2QL                   -> 0.000000000000010000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3561
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3562
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3563
    "Created: / 12-06-2017 / 18:15:27 / cg"
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3564
    "Modified: / 13-06-2017 / 17:56:50 / cg"
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3565
!
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3566
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3567
asQDouble
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3568
    "return a QDouble with same value as myself."
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3569
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3570
    ^ self
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3571
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3572
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3573
asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3574
    ^ self d0 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3575
    + self d1 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3576
    + self d2 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3577
    + self d3 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3578
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3579
    "
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3580
     1e10 asTrueFraction        -> 10000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3581
     1e20 asTrueFraction        -> 100000000000000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3582
     (1e20 + 1) asTrueFraction  -> 100000000000000000000 ouch!!
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3583
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3584
     1e10 asQDouble asTrueFraction       -> 10000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3585
     1e20 asQDouble asTrueFraction       -> 100000000000000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3586
     (1e20 asQDouble + 1) asTrueFraction -> 100000000000000000001
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3587
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3588
     (1e40 asQDouble + 1e20 + 1) asTrueFraction -> 10000000000000000303886028427003666890753
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3589
     (1e40 asQDouble + 1e20) asTrueFraction
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3590
    "
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3591
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3592
    "Created: / 20-06-2017 / 11:09:03 / cg"
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3593
!
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3594
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3595
coerce:aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3596
    "convert the argument aNumber into an instance of the receiver's class and return it."
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3597
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3598
    ^ aNumber asQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3599
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3600
    "Created: / 12-06-2017 / 17:13:47 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3601
    "Modified: / 12-06-2017 / 21:09:06 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3602
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3603
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3604
exponent
5275
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3605
    "extract a normalized float's (unbiased) exponent.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3606
     The returned value depends on the float-representation of
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3607
     the underlying machine and is therefore highly unportable.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3608
     This is not for general use.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3609
     This assumes that the mantissa is normalized to
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3610
     0.5 .. 1.0 and the float's value is: mantissa * 2^exp"
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3611
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3612
    ^ self d0 exponent
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3613
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3614
    "Created: / 20-06-2017 / 11:06:02 / cg"
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3615
!
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3616
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3617
generality
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3618
    "return the generality value - see ArithmeticValue>>retry:coercing:"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3619
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3620
    ^ 95
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3621
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3622
    "Created: / 12-06-2017 / 17:13:14 / cg"
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3623
!
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3624
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3625
mantissa
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3626
    "extract a normalized float's mantissa.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3627
     The returned value depends on the float-representation of
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3628
     the underlying machine and is therefore highly unportable.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3629
     This is not for general use.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3630
     This assumes that the mantissa is normalized to
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3631
     0.5 .. 1.0 and the float's value is mantissa * 2^exp"
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3632
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3633
    "/ fake it here
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3634
    ^ self / (2 raisedTo:self exponent)
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3635
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3636
    "
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3637
     1.0 exponent        -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3638
     1.0 mantissa        -> 0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3639
     12345.0 exponent    -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3640
     12345.0 mantissa    -> 0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3641
     -1.0 exponent       -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3642
     -1.0 mantissa       -> -0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3643
     -12345.0 exponent   -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3644
     -12345.0 mantissa   -> -0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3645
     (1e40 + 1e-40) exponent   -> 133
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3646
     (1e40 + 1e-40) mantissa   -> 0.918354961579912
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3647
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3648
     1.0 asQDouble exponent        -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3649
     1.0 asQDouble mantissa        -> 0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3650
     12345.0 asQDouble exponent    -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3651
     12345.0 asQDouble mantissa    -> 0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3652
     -1.0 asQDouble exponent       -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3653
     -1.0 asQDouble mantissa       -> -0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3654
     -12345.0 asQDouble exponent   -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3655
     -12345.0 asQDouble mantissa   -> -0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3656
     (1e40 + 1e-40) asQDouble exponent   -> 133
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3657
     (1e40 + 1e-40) asQDouble mantissa   -> 0.918354961579912
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3658
    "
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3659
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3660
    "Created: / 20-06-2017 / 11:06:02 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3661
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3662
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3663
!QDouble methodsFor:'comparing'!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3664
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3665
< aNumber
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3666
    "return true, if the argument, aNumber is greater than the receiver"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3667
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3668
    ^ aNumber lessFromQDouble:self
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3669
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3670
    "Created: / 13-06-2017 / 16:58:53 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3671
!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3672
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3673
= aNumber
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3674
    "return true, if the argument, aNumber has the same value as than the receiver"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3675
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3676
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3677
    if (__isSmallInteger(aNumber)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3678
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3679
        double b = (double)(__intVal(aNumber));
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3680
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3681
        RETURN ((a[0] == b
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3682
                && a[1] == 0.0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3683
                && a[2] == 0.0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3684
                && a[3] == 0.0) ? true : false);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3685
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3686
    if (aNumber == nil) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3687
        RETURN(false);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3688
    }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3689
    if (__qClass(aNumber) == QDouble) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3690
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3691
        double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3692
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3693
        RETURN ((a[0] == b[0]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3694
                && a[1] == b[1]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3695
                && a[2] == b[2]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3696
                && a[3] == b[3]) ? true : false);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3697
    }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3698
    if (__qClass(aNumber) == Float) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3699
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3700
        double b = __floatVal(aNumber);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3701
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3702
        RETURN ((a[0] == b
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3703
                && a[1] == 0.0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3704
                && a[2] == 0.0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3705
                && a[3] == 0.0) ? true : false);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3706
    }
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3707
%}.
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3708
    ^ aNumber equalFromQDouble:self
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3709
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3710
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3711
     1.0 asQDouble = 1.0 asQDouble
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3712
     1.0 asQDouble = 1.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3713
     1.0 asQDouble = 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3714
     1.0 asQDouble = 2
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3715
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3716
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3717
    "Created: / 13-06-2017 / 17:12:09 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3718
! !
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3719
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3720
!QDouble methodsFor:'double dispatching'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3721
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3722
differenceFromFloat:aFloat
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3723
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3724
    if (__isFloatLike(aFloat)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3725
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3726
        double b = __floatVal(aFloat);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3727
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3728
        double e;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3729
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3730
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3731
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3732
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3733
        s_sub_qd(&c0, &c1, &c2, &c3, b, a[0], a[1], a[2], a[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3734
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3735
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3736
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3737
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3738
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3739
    ^ super differenceFromFloat:aFloat.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3740
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3741
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3742
     1.0 - (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3743
     1e20 - (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3744
     (1.0 - (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3745
     (1e20 - (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3746
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3747
     (1.0 - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3748
     (1e20 - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3749
     (1e20 - (QDouble fromFloat:1.0) + 1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3750
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3751
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3752
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3753
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3754
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3755
differenceFromQDouble:aQDouble
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3756
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3757
    if (__isQDouble(aQDouble)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3758
        double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3759
        double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3760
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3761
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3762
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3763
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3764
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3765
        qd_sub_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3766
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3767
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3768
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3769
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3770
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3771
    ^ super differenceFromQDouble:aQDouble
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3772
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3773
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3774
     (QDouble fromFloat:1.0) - (QDouble fromFloat:1.0)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3775
     (QDouble fromFloat:1.0) - 1.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3776
     1.0 - (QDouble fromFloat:1.0)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3777
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3778
     ((QDouble fromFloat:1.0) - (QDouble fromFloat:1.0)) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3779
     ((QDouble fromFloat:1.0) - 1.0) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3780
     (1.0 - (QDouble fromFloat:1.0)) asDoubleArray
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3781
     (1e-20 - (QDouble fromFloat:1.0)) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3782
     (1e20 - (QDouble fromFloat:1.0)) asDoubleArray
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3783
   "
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3784
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3785
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3786
equalFromQDouble:aQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3787
%{
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3788
    if (__Class(aQDouble) == QDouble) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3789
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3790
        double *b = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3791
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3792
        RETURN ((a[0] == b[0]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3793
                && a[1] == b[1]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3794
                && a[2] == b[2]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3795
                && a[3] == b[3]) ? true : false);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3796
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3797
%}.
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3798
    ^ (aQDouble d0 = self d0)
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3799
    and:[ (aQDouble d1 = self d1)
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3800
    and:[ (aQDouble d2 = self d2)
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3801
    and:[ (aQDouble d3 = self d3) ]]]
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3802
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3803
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3804
     (QDouble fromFloat:1.0) = (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3805
     (QDouble fromFloat:1.0) = 1.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3806
     1.0 = (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3807
   "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3808
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3809
    "Created: / 13-06-2017 / 03:01:19 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3810
    "Modified: / 13-06-2017 / 18:01:52 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3811
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3812
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3813
lessFromQDouble:aQDouble
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3814
    "sent when aQDouble does not know how to compare to the receiver..
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3815
     Return true if aQDouble < self"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3816
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3817
%{
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3818
    if (__Class(aQDouble) == QDouble) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3819
        double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3820
        double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3821
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3822
        // now compare if a < b!
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3823
        RETURN
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3824
            ((a[0] < b[0] ||
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3825
              (a[0] == b[0] && (a[1] < b[1] ||
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3826
                (a[1] == b[1] && (a[2] < b[2] ||
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3827
                  (a[2] == b[2] && a[3] < b[3])))))) ? true : false);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3828
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3829
%}.
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3830
    ^ super lessFromQDouble:aQDouble
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3831
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3832
    "
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3833
     (1.0 + 1e-40) > 1.0
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3834
     ((QDouble fromFloat:1.0) + (QDouble fromFloat:1e-40)) > (QDouble fromFloat:1.0)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3835
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3836
     (QDouble fromFloat:1.0) > (QDouble fromFloat:1.0)
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3837
     (QDouble fromFloat:1.1) > (QDouble fromFloat:1.0)
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3838
     (QDouble fromFloat:1.0) > 1.0
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3839
     (QDouble fromFloat:1.1) > 1.0
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3840
     1.0 > (QDouble fromFloat:1.0)
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3841
   "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3842
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3843
    "Created: / 13-06-2017 / 17:07:47 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3844
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3845
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3846
productFromFloat:aFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3847
%{
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3848
    if (__isFloatLike(aFloat)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3849
        double a  = __floatVal(aFloat);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3850
        double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3851
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3852
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3853
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3854
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3855
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3856
        s_mul_qd(&c0, &c1, &c2, &c3, a, b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3857
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3858
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3859
        RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3860
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3861
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3862
    ^ super productFromFloat:aFloat.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3863
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3864
    "
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3865
     loosing bits here:
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3866
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3867
     (1e20+1.0)*2.0    - 2E20  -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3868
     (1e20+1.0)*100.0  - 1E+22 -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3869
     (1e20+1.0)*1000.0 - 1E+23 -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3870
     (1e20+1.0)*1e20   - 1E+40 -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3871
     (1e40+1.0)*2.0    - 2E+40 -> 0.0
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3872
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3873
     but not here:
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3874
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3875
     ((1e20 asQDouble) + (1.0)) * 2.0    - 2E20  -> 2.0
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3876
     ((1e20 asQDouble) + (1.0)) * 100.0  - 1E+22 -> 100.0
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3877
     ((1e20 asQDouble) + (1.0)) * 1000.0 - 1E+23 -> 8389608.0  WRONG
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3878
     ((1e20 asQDouble) + (1.0)) * 1e20   - 1E+40 ->
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3879
     ((1e40 asQDouble) + (1.0)) * 2.0    - 2E+40 ->
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3880
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3881
     2.0 * (QDouble fromFloat:1.0)
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3882
     2.0 * (QDouble fromFloat:3.0)
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3883
     (QDouble fromFloat:2.0) * (QDouble fromFloat:3.0)
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3884
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3885
     QDouble ln2       DoubleArray(0.693147180559945 2.3190468138463E-17 5.70770843841621E-34 -3.58243221060181E-50)
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3886
     2.0 * QDouble ln2 DoubleArray(1.38629436111989 4.6380936276926E-17 1.14154168768324E-33 -7.16486442120362E-50)
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3887
     QDouble ln2 * 2.0
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3888
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3889
     2.0 * ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) DoubleArray(2E+20 2.0 0.0 0.0)
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3890
     ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) * 2.0 DoubleArray(2E+20 4E+20 0.0 0.0)
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3891
     ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) * (QDouble fromFloat:2.0) DoubleArray(2E+20 4E+20 0.0 0.0)
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3892
     (QDouble fromFloat:2.0) * ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) DoubleArray(2E+20 4E+20 0.0 0.0)
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3893
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3894
     (2.0 * ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0))) - (QDouble fromFloat:1e20) - (QDouble fromFloat:1e20)
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3895
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3896
     (2.0 * (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3897
     (1e20 * (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3898
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3899
     (1e20 * (QDouble fromFloat:1.0) * 1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3900
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3901
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3902
    "Created: / 13-06-2017 / 00:58:56 / cg"
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3903
    "Modified: / 19-06-2017 / 16:48:18 / cg"
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3904
    "Modified (comment): / 19-06-2017 / 18:11:43 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3905
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3906
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3907
productFromQDouble:aQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3908
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3909
    if (__isQDouble(aQDouble)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3910
        double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3911
        double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3912
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3913
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3914
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3915
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3916
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3917
        qd_mul_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3918
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3919
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3920
        RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3921
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3922
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3923
    ^ super productFromQDouble:aQDouble.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3924
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3925
    "
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3926
     (QDouble fromFloat:1.0) * 2.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3927
     2.0 * (QDouble fromFloat:1.0)
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3928
     (QDouble fromFloat:1.0) * (QDouble fromFloat:2.0)
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3929
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3930
     1e20 * (QDouble fromFloat:2.0)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3931
     2.0 * (QDouble fromFloat:1e20)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3932
     (QDouble fromFloat:1e20) * (QDouble fromFloat:1e20)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3933
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3934
     (1e20 * (QDouble fromFloat:1.0) * 1e-20) asDoubleArray
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3935
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3936
     ( ((QDouble fromFloat:1.0) + (QDouble fromFloat:1e20)) * (QDouble fromFloat:2.0)) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3937
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3938
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3939
    "Created: / 13-06-2017 / 01:06:22 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3940
    "Modified: / 05-07-2017 / 11:07:16 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3941
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3942
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3943
quotientFromFloat:aFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3944
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3945
    if (__isFloatLike(aFloat)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3946
        double a  = __floatVal(aFloat);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3947
        double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3948
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3949
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3950
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3951
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3952
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3953
        s_div_qd(&c0, &c1, &c2, &c3, a, b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3954
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3955
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3956
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3957
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3958
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3959
    ^ super quotientFromFloat:aFloat.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3960
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3961
    "
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3962
     2.0 / (QDouble fromFloat:2.0)
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3963
     2.0 / (QDouble fromFloat:1.0)
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3964
     1e20 / (QDouble fromFloat:1.0)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3965
     1e20 / (QDouble fromFloat:2.0)
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3966
     (2.0 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3967
     (1e20 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3968
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3969
     (QDouble fromFloat:2.0) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3970
     (QDouble fromFloat:1e20) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3971
     ((QDouble fromFloat:1.0) / 2.0) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3972
     ((QDouble fromFloat:1e20 / 2.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3973
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3974
     ((1e20 + (QDouble fromFloat:1.0) + 1e-20) / 2.0) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3975
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3976
     ((QDouble fromFloat:10.0) quotientFromQDouble: (QDouble fromFloat:1.234)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3977
     ((QDouble fromFloat:1.234) / (QDouble fromFloat:10.0)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3978
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3979
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3980
    "Created: / 13-06-2017 / 17:50:35 / cg"
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3981
    "Modified (comment): / 15-06-2017 / 01:02:05 / cg"
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3982
!
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3983
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3984
quotientFromQDouble:aQDouble
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3985
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3986
    if (__isQDouble(aQDouble)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3987
        double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3988
        double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3989
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3990
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3991
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3992
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3993
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3994
        qd_div_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3995
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3996
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  3997
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3998
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3999
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4000
    ^ super quotientFromQDouble:aQDouble.
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4001
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4002
    "
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4003
     2.0 / (QDouble fromFloat:2.0)
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4004
     2.0 / (QDouble fromFloat:1.0)
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4005
     1e20 / (QDouble fromFloat:1.0)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4006
     1e20 / (QDouble fromFloat:2.0)
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4007
     (2.0 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4008
     (1e20 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4009
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4010
     (QDouble fromFloat:2.0) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4011
     (QDouble fromFloat:1e20) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4012
     ((QDouble fromFloat:1.0) / 2.0) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4013
     ((QDouble fromFloat:1e20 / 2.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4014
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4015
     ((1e20 + (QDouble fromFloat:1.0) + 1e-20) / 2.0) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4016
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4017
     ((QDouble fromFloat:10.0) quotientFromQDouble: (QDouble fromFloat:1.234)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4018
     ((QDouble fromFloat:1.234) / (QDouble fromFloat:10.0)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4019
    "
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4020
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4021
    "Created: / 13-06-2017 / 17:50:35 / cg"
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4022
    "Modified (comment): / 15-06-2017 / 01:02:05 / cg"
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4023
!
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  4024
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4025
sumFromFloat:aFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4026
%{
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4027
    if (__isFloatLike(aFloat)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4028
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4029
        double b = __floatVal(aFloat);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4030
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4031
        double e;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4032
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4033
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4034
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4035
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4036
        qd_add_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4037
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4038
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4039
        RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4040
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4041
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4042
    ^ super sumFromFloat:aFloat.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4043
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4044
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4045
     1.0 + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4046
     1e20 + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4047
     (1.0 + (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4048
     (1e20 + (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4049
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4050
     (1.0 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4051
     (1e20 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4052
     (1e20 + (QDouble fromFloat:1.0) + 1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4053
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4054
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4055
    "Created: / 12-06-2017 / 17:16:41 / cg"
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  4056
    "Modified: / 14-06-2017 / 11:43:47 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4057
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4058
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4059
sumFromInteger:anInteger
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4060
    ^ self sumFromFloat:(anInteger asFloat)
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4061
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4062
    "
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4063
     1 + (QDouble fromFloat:1.0)
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4064
     1e20 asInteger + (QDouble fromFloat:1.0)
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4065
     (1 + (QDouble fromFloat:1.0)) asFloat
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4066
     (1e20 asInteger + (QDouble fromFloat:1.0)) asFloat
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4067
    "
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4068
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4069
    "Created: / 03-07-2017 / 10:35:46 / cg"
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4070
!
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4071
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4072
sumFromQDouble:aQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4073
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4074
    if (__isQDouble(aQDouble)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4075
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4076
        double *b = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4077
        double c0, c1, c2, c3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4078
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4079
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4080
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4081
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4082
        qd_add_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4083
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4084
        __qNew_qdReal(newQD, c0, c1, c2, c3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4085
        RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4086
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4087
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4088
    ^ super sumFromQDouble:aQDouble
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4089
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4090
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4091
     (QDouble fromFloat:1.0) + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4092
     (QDouble fromFloat:1.0) + 1.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4093
     1.0 + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4094
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4095
     ((QDouble fromFloat:1.0) + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4096
     ((QDouble fromFloat:1.0) + 1.0) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4097
     (1.0 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4098
     (1e-20 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4099
     (1e20 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4100
   "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4101
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4102
    "Created: / 12-06-2017 / 21:15:43 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4103
    "Modified: / 03-07-2017 / 23:09:11 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4104
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4105
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4106
!QDouble methodsFor:'inspecting'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4107
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4108
inspectorExtraAttributes
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4109
    "extra (pseudo instvar) entries to be shown in an inspector."
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4110
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4111
    ^ super inspectorExtraAttributes
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4112
        add:'-{doubles}' -> [ self asDoubleArray printString ];
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4113
        yourself
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4114
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4115
    "Created: / 12-06-2017 / 23:43:05 / cg"
4478
010c2cd47df3 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4454
diff changeset
  4116
    "Modified (format): / 18-07-2017 / 19:54:48 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4117
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4118
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4119
!QDouble methodsFor:'mathematical functions'!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4120
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4121
cos
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4122
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4123
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4124
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4125
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4126
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4127
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4128
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4129
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4130
    qd_cos(&q0, &q1, &q2, &q3, &a[0], &a[1], &a[2], &a[3]);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4131
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4132
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4133
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4134
%}.
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4135
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  4136
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4137
     1.0 cos
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4138
     (QDouble fromFloat:1.0) cos
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4139
    "
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  4140
!
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  4141
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4142
exp
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4143
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4144
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4145
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4146
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4147
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4148
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4149
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4150
    fpu_fix_start(&savedCV);
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4151
    qd_exp(&q0, &q1, &q2, &q3, a[0], a[1], a[2], a[3]);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4152
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4153
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4154
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4155
%}.
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4156
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4157
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4158
     1.0 exp
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4159
     (QDouble fromFloat:1.0) exp
5313
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4160
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4161
     3.0 exp
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4162
     (QDouble fromFloat:3.0) exp
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4163
    "
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4164
!
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4165
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4166
ldexp:exp
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4167
    "multiply the receiver by an integral power of 2.
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  4168
     I.e. return self * (2 ^ exp).
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  4169
     This is also the operation to reconstruct the original float from its
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  4170
     mantissa and exponent: (f mantissa ldexp:f exponent) = f"
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4171
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4172
    ^ self class
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4173
        d0:(self d0 ldexp:exp)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4174
        d1:(self d1 ldexp:exp)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4175
        d2:(self d2 ldexp:exp)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4176
        d3:(self d3 ldexp:exp)
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4177
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4178
     |f| f := 1 asQDouble. (f mantissa ldexp:f exponent) -> 1.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4179
     |f| f := (1e40 asQDouble + 1e-40). (f mantissa ldexp:f exponent) -> (1e40 asQDouble + 1e-40)
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  4180
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4181
     1.0 ldexp:16            -> 65536.0
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4182
     1.0 asQDouble ldexp:16  -> 65536.0
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4183
     1.0 ldexp:100           -> 1.26765060022823E+30
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4184
     1.0 asQDouble ldexp:100 -> 1.26765060022823E+30
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4185
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4186
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4187
    "Created: / 19-06-2017 / 01:43:35 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4188
!
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4189
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4190
ln
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4191
    "return the natural logarithm of myself.
4445
5267aa3922e4 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4444
diff changeset
  4192
     Raises an exception, if the receiver is less or equal to zero.
5267aa3922e4 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4444
diff changeset
  4193
5267aa3922e4 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4444
diff changeset
  4194
     Not sure if this is really faster than using a taylor right away:
5267aa3922e4 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4444
diff changeset
  4195
     the three exp-computations at the end are done in qDouble and are tailors themself..."
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4196
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4197
    |d0 x|
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4198
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4199
    "/ ^ super ln.
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4200
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4201
    d0 := self d0.
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4202
    d0 = 1.0 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4203
        "/ note: d0 checking alone is not sufficient - there could still be more in d1...
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4204
        self isOne ifTrue:[ ^ self class zero ].
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4205
    ].
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4206
    d0 > 0.0 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4207
        "/ initial approx.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4208
        x := d0 ln asQDouble.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4209
        "/ three more iterations of newton...
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4210
        x := x + (self * (x negated exp)) - 1.0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4211
        x := x + (self * (x negated exp)) - 1.0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4212
        x := x + (self * (x negated exp)) - 1.0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4213
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4214
        ^ x
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4215
    ].
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4216
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4217
    "/ now done via trapInfinity; was:
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4218
    "/ d0 = 0.0 ifTrue:[
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4219
    "/     ^ Infinity negative
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4220
    "/ ].
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4221
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4222
    "/ if you need -INF for a zero receiver, try Number trapInfinity:[...]
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4223
    ^ self class
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4224
        raise:(self = 0 ifTrue:[#infiniteResultSignal] ifFalse:[#domainErrorSignal])
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4225
        receiver:self
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4226
        selector:#ln
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4227
        arguments:#()
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4228
        errorString:'bad receiver in ln (not strictly positive)'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4229
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4230
    "                                 
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4231
     inaccurate:
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4232
     (1e-100 asQDouble log10 + 100.0) < (2*QDouble epsilon).       
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4233
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4234
     -1 ln
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4235
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4236
     -1.0 asQDouble ln
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4237
     0.0 asQDouble ln
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4238
     1.0 asQDouble ln
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4239
     0.5 ln
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4240
     0.5 asQDouble ln
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4241
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4242
     3.0 ln printfPrintString:'%60.58lf'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4243
            -> 1.0986122886681097821082175869378261268138885498046875000000'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4244
                                ^
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4245
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4246
     3.0 asQDouble ln printfPrintString:'%60.58f'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4247
            -> 1.0986122886681096913952452369225257046474905578227494517347
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4248
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4249
     3.0 asQDouble ln printfPrintString:'%70.68f'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4250
            -> 1.09861228866810969139524523692252570464749055782274945173469433364779
4443
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  4251
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  4252
     (3.0 asQDouble ln_withAccuracy:1e-64) printfPrintString:'%70.68f'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4253
               1.09861228866810969139524523692252570464749055782274945173469433364475
4443
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  4254
     (3.0 asQDouble ln_withAccuracy:1e-100) printfPrintString:'%70.68f'
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4255
              '1.098612288668109691395245236922525704647490557822749451734694333656909'
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4256
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4257
     actual result:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4258
            -> 1.0986122886681096913952452369225257046474905578227494517346943336374942932186089668736157548137320887879700290659...
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4259
    "
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4260
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4261
    "Created: / 18-06-2017 / 23:32:54 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4262
    "Modified: / 04-07-2017 / 11:46:27 / cg"
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4263
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4264
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4265
negated
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4266
    ^ self class
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4267
        d0:(self d0) negated
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4268
        d1:(self d1) negated
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4269
        d2:(self d2) negated
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4270
        d3:(self d3) negated
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4271
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4272
    "
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4273
     (QDouble fromFloat:1.0) negated
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4274
     ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) negated asDoubleArray
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4275
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4276
     (((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0))
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4277
     + ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0))) asDoubleArray
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4278
    "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4279
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4280
    "Created: / 12-06-2017 / 20:14:55 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4281
    "Modified (comment): / 12-06-2017 / 23:46:57 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4282
!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4283
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4284
raisedToInteger:n
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4285
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4286
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4287
    if (__isSmallInteger(n)) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4288
        double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4289
        double q0, q1, q2, q3;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4290
        OBJ newQD;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4291
        int savedCV;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4292
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4293
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4294
        qd_pow(&q0, &q1, &q2, &q3, a[0], a[1], a[2], a[3], __intVal(n));
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4295
        fpu_fix_end(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4296
        __qNew_qdReal(newQD, q0, q1, q2, q3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4297
        RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4298
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4299
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4300
    ^ super raisedToInteger:n.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4301
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4302
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4303
     (QDouble fromFloat:4.0) raisedToInteger:4
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4304
     (QDouble fromFloat:10.0) raisedToInteger:10
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4305
     (QDouble fromFloat:10.0000000000001) raisedToInteger:10
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4306
     10.0000000000001 raisedToInteger:10
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4307
    "
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4308
!
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4309
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4310
sin
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4311
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4312
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4313
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4314
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4315
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4316
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4317
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4318
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4319
    qd_sin(&q0, &q1, &q2, &q3, &a[0], &a[1], &a[2], &a[3]);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4320
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4321
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4322
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4323
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4324
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4325
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4326
     1.0 sin
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4327
     (QDouble fromFloat:1.0) sin
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4328
    "
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4329
!
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4330
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4331
sqrt
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4332
    "Return the square root of the receiver"
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4333
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4334
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4335
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4336
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4337
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4338
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4339
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4340
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4341
    qd_sqrt(&q0, &q1, &q2, &q3, a[0], a[1], a[2], a[3]);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4342
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4343
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4344
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4345
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4346
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4347
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4348
     (QDouble fromFloat:4.0) sqrt
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4349
     (QDouble fromFloat:2.0) sqrt
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4350
     (QDouble fromFloat:1e20) sqrt
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4351
    "
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4352
!
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4353
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4354
squared
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4355
    "return receiver * receiver"
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4356
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4357
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4358
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4359
    double q0, q1, q2, q3;
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4360
    OBJ newQD;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4361
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4362
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4363
    fpu_fix_start(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4364
    qd_sqr(&q0, &q1, &q2, &q3, a[0], a[1], a[2], a[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4365
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4366
    __qNew_qdReal(newQD, q0, q1, q2, q3);
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4367
    RETURN( newQD );
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4368
%}.
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4369
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4370
    "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4371
     (QDouble fromFloat:4.0) squared
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4372
     (1e20 + (QDouble fromFloat:1.0)) squared
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4373
    "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4374
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4375
    "Created: / 13-06-2017 / 01:27:58 / cg"
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4376
    "Modified: / 22-06-2017 / 14:08:31 / cg"
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4377
!
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4378
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4379
tan
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4380
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4381
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4382
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4383
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4384
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4385
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4386
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4387
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4388
    qd_tan(&q0, &q1, &q2, &q3, &a[0], &a[1], &a[2], &a[3]);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4389
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4390
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4391
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4392
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4393
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4394
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4395
     1.0 tan
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4396
     (QDouble fromFloat:1.0) tan
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4397
    "
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4398
! !
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4399
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4400
!QDouble methodsFor:'printing & storing'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4401
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4402
digitsWithPrecision:precision
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4403
    <resource: #obsolete>
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4404
    "generate digits and exponent.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4405
     if precision is >0, that many digits are generated.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4406
     If it is 0 the required number of digits is generated
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4407
     (but never more than the decimalPrecision, which is 65)"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4408
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4409
    |numDigits r exp i d out str|
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4410
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4411
    numDigits := precision+1. "/ number of digits
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4412
    r := self abs.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4413
    self d0 = 0.0 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4414
        ^ { String new:(precision max:1) withAll:$0 . 0 }
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4415
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4416
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4417
    out := WriteStream on:(String new:precision+5).
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4418
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4419
    "/ determine approx. exponent
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4420
    exp := self d0 abs log10 floor.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4421
    exp < -300 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4422
        "/ 1e-305 asQDouble
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4423
        r := r * (10.0 raisedToInteger:300).
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4424
        r := r / (10.0 raisedToInteger:(exp+300)).
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4425
    ] ifFalse:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4426
        exp > 300 ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4427
            "/ 1e305 asQDouble
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4428
            "/ lexpr(x,exp) = x * 2 ^ exp
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4429
self halt.
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4430
            r := r * (2 raisedTo:-53).
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4431
            r := r / (10.0 asQDouble raisedTo: exp).
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4432
            r := r * (2 raisedTo:53).
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4433
        ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4434
            r := r / (10.0 asQDouble raisedTo:exp).
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4435
        ]
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4436
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4437
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4438
    "/ Fix exponent if we are off by one
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4439
    (r >= 10.0) ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4440
        r := r / 10.0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4441
        exp := exp + 1.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4442
    ] ifFalse:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4443
        (r < 1.0) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4444
            r := r * 10.0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4445
            exp := exp - 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4446
        ]
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4447
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4448
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4449
    ((r >= 10.0) or:[ r < 1.0 ]) ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4450
        self error:'can''t compute exponent.'.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4451
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4452
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4453
    "/
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4454
    "/ Extract the digits
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4455
    "/ notice, that the d1,d2 and d3 components might
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4456
    "/ be negative; therefore characters out of the 0..9 range
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4457
    "/ might be produced here
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4458
    "/
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4459
    i := 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4460
    [ (precision ~~ 0 and:[ i <= numDigits ])
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4461
    or:[ (precision == 0 and:[r d0 ~= 0.0])  ]] whileTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4462
        d := r d0 truncated.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4463
        r := r - d.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4464
        r := r * 10.0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4465
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4466
        out nextPut:($0 + d).
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4467
        i := i + 1.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4468
    ].
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4469
    numDigits := i-1.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4470
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4471
    str := out contents.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4472
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4473
    "/ Fix out-of-range digits.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4474
    numDigits to:2 by:-1 do:[:i |
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4475
        (str at:i) < $0 ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4476
            str at:i-1 put:(str at:i-1) - 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4477
            str at:i put:(str at:i) + 10.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4478
        ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4479
            (str at:i) > $9 ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4480
                str at:i-1 put:(str at:i-1) + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4481
                str at:i put:(str at:i) - 10.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4482
            ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4483
        ].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4484
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4485
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4486
    str first <= $0 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4487
        self error:'non-positive leading digit'
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4488
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4489
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4490
    "/ Round, handle carry
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4491
    (str at:numDigits) >= $5 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4492
        str at:numDigits-1 put:(str at:numDigits-1) + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4493
        i := numDigits-1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4494
        [i > 1 and:[(str at:i) > $9]] whileTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4495
            str at:i put:(str at:i) - 10.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4496
            i := i - 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4497
            str at:i put:(str at:i) + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4498
        ]
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4499
    ].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4500
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4501
    "/ If first digit is 10, shift everything.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4502
    str first > $9 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4503
        exp := exp + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4504
        str at:1 put:$0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4505
        str := '1',str
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4506
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4507
    ^ { (str copyTo:numDigits-1) . exp }
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4508
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4509
    "
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4510
     0 asQDouble digitsWithPrecision:1      -> #('0' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4511
     0 asQDouble digitsWithPrecision:0      -> #('0' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4512
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4513
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4514
     1.2345 printfPrintString:'%.4f'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4515
     1.2345 asQDouble digitsWithPrecision:5 -> #('12345' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4516
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4517
     --- but 1.2345 is not really what you think:
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4518
     1.2345 printfPrintString:'%.20f'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4519
     1.2345 asQDouble digitsWithPrecision:20 -> #('12344999999999999307' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4520
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4521
     12.345 asQDouble digitsWithPrecision:5 -> #('12345' 1)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4522
     12345 asQDouble digitsWithPrecision:5 -> #('12345' 4)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4523
     12345.1 asQDouble digitsWithPrecision:5 -> #('12345' 4)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4524
     12345.9 asQDouble digitsWithPrecision:5 -> #('12346' 4)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4525
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4526
     1.2345 asQDouble / 10.0 asQDouble
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4527
     1.2345 asQDouble / 10.0
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4528
    "
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4529
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4530
    "Created: / 15-06-2017 / 09:10:01 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4531
    "Modified: / 16-06-2017 / 10:01:03 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4532
!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4533
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4534
printOn:aStream
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4535
    "return a printed representation of the receiver.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4536
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4537
     Notice:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4538
        this code was adapted from an ugly piece of c++ code,
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4539
        which was obviously hacked.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4540
        It does need a rework.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4541
        As an alternative, use the printf functions, which should also deal wth QDoubles"
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4542
5313
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4543
"/    self d1 = 0.0 ifTrue:[
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4544
"/        self d0 printOn:aStream.
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4545
"/        ^ self
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4546
"/    ].
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4547
    thisContext isRecursive ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4548
        aStream nextPutAll:'aQDouble (error while printing)'.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4549
        ^ self.
4978
99f7c90223f2 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4963
diff changeset
  4550
    ].
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4551
4438
e5665b676a65 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4437
diff changeset
  4552
    PrintfScanf printf:'%g' on:aStream argument:self.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4553
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4554
"/    self
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4555
"/        printOn:aStream precision:40 width:0
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4556
"/        fixed:true showPositive:false uppercase:false fillChar:(Character space)
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4557
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4558
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4559
     (1.2345 asQDouble) printString
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4560
     (2 asQDouble squared) printString
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4561
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4562
     (1.2345 asQDouble) printString.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4563
     (1.2345 asFloat) printString.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4564
     (1.2345 asLongFloat) printString.
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4565
     (1.2345 asShortFloat) printString.
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4566
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4567
     ((QDouble fromFloat:1.2345) / 10.0) printString
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4568
     ((QDouble fromFloat:1.2345) / 10000.0) printString
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4569
     ((QDouble fromFloat:1.2345) / 1000000000.0) printString -> '0.0000123449999999999987156270014193593714e-4'
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4570
     (1.2345 / 1000000000.0) printString                     -> '1.2345E-09'
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4571
    "
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4572
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4573
    "Created: / 15-06-2017 / 01:51:36 / cg"
4439
4c6520416d7d #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4438
diff changeset
  4574
    "Modified (comment): / 21-06-2017 / 09:55:10 / cg"
4978
99f7c90223f2 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4963
diff changeset
  4575
    "Modified: / 05-06-2019 / 20:38:58 / Claus Gittinger"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4576
!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4577
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4578
printOn:aStream precision:precisionIn width:width
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4579
    fixed:fixed showPositive:showPositive uppercase:uppercase fillChar:fillChar
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4580
    <resource: #obsolete>
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4581
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4582
    "return a printed representation of the receiver.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4583
     This is a parametrized entry, which can be used by printf-like functions.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4584
     Notice:
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4585
        this code was adapted from an ugly piece of c++ code,
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4586
        which was obviously hacked.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4587
        It does need a rework.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4588
        As an alternative, use the printf functions, which should also deal wth QDoubles
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4589
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4590
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4591
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4592
     1.2345 asQDouble printString
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4593
     12.345 asQDouble printString
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4594
     12345 asQDouble printString
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4595
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4596
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4597
    |sgn count delta exp precision|
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4598
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4599
"/    self d1 = 0.0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4600
"/        self d0 printOn:aStream.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4601
"/        ^ self.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4602
"/    ].
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4603
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4604
    count := 0.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4605
    sgn := true.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4606
    exp := 0.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4607
    precision := precisionIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4608
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4609
    self isInfinite ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4610
        self < 0 ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4611
            aStream nextPut:$-.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4612
            count := 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4613
        ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4614
            showPositive ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4615
                aStream nextPut:$+.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4616
                count := 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4617
            ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4618
                sgn := false.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4619
            ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4620
        ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4621
        uppercase ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4622
            aStream nextPutAll:'INF'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4623
        ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4624
            aStream nextPutAll:'inf'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4625
        ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4626
        count := count + 3.
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4627
    ] ifFalse:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4628
        self isNaN ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4629
            uppercase ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4630
                aStream nextPutAll:'NAN'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4631
            ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4632
                aStream nextPutAll:'nan'
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4633
            ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4634
            count := count + 3.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4635
        ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4636
            self < 0 ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4637
                aStream nextPut:$-.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4638
                count := count + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4639
            ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4640
                showPositive ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4641
                    aStream nextPut:$+.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4642
                    count := count + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4643
                ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4644
                    sgn := false.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4645
                ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4646
            ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4647
            self = 0.0 ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4648
                aStream nextPut:$0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4649
                count := count + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4650
                precision > 0 ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4651
                    aStream nextPut:$..
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4652
                    count := count + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4653
                    precision timesRepeat:[ aStream nextPut:$0 ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4654
                    count := count + precision.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4655
                ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4656
                self halt.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4657
            ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4658
                |off d d_width_extra|
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4659
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4660
                "/ non-zero case
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4661
                off := fixed
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4662
                        ifTrue:[ 1 + self asFloat abs log10 floor asInteger ]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4663
                        ifFalse:[1].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4664
                d := precision + off.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4665
                d_width_extra := d.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4666
                fixed ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4667
                    d_width_extra := 40 max:d.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4668
                ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4669
                "/ highly special case - fixed mode, precision is zero, abs(*this) < 1.0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4670
                "/ without this trap a number like 0.9 printed fixed with 0 precision prints as 0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4671
                "/ should be rounded to 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4672
                (fixed and:[ (precision == 0) and:[ (self abs < 1.0) ]]) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4673
                    (self abs >= 0.5) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4674
                        aStream nextPut:$1
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4675
                    ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4676
                        aStream nextPut:$0
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4677
                    ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4678
                    ^ self
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4679
                ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4680
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4681
                "/ handle near zero to working precision (but not exactly zero)
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4682
                (fixed and:[ d <= 0 ]) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4683
                    aStream nextPut:$0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4684
                    (precision > 0) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4685
                        aStream nextPut:$. .
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4686
                        aStream next:precision put:$0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4687
                    ]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4688
                ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4689
                    "/ default
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4690
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4691
                    |t j|
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4692
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4693
                    t := self digitsWithPrecision:(fixed ifTrue:[d_width_extra] ifFalse:[d])+1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4694
                    exp := t second.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4695
                    t := t first.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4696
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4697
                    fixed ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4698
                        "/ fix the string if it's been computed incorrectly
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4699
                        "/ round here in the decimal string if required
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4700
                        t := self round_string_qd:t at:(d + 1) offset:off.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4701
                        precision := t at:3.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4702
                        off := t at:2.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4703
                        t := t at:1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4704
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4705
                        (off > 0) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4706
                            aStream next:off putAll:t startingAt:1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4707
                            (precision > 0) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4708
                                aStream nextPut:$. .
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4709
                                aStream next:precision-1 putAll:t startingAt:off+1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4710
                            ]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4711
                        ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4712
                            aStream nextPutAll:'0.'.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4713
                            (off < 0) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4714
                                aStream next:off negated put:$0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4715
                            ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4716
                            aStream next:d putAll:t startingAt:0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4717
                        ]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4718
                    ] ifFalse:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4719
                        aStream nextPut:(t at:1).
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4720
                        (precision > 0) ifTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4721
                            aStream nextPut:$. .
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4722
                        ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4723
                        aStream next:precision putAll:t startingAt:2.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4724
                    ]
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4725
                ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4726
            ].
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4727
        ]
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4728
    ].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4729
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4730
    "/ trap for improper offset with large values
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4731
    "/ without this trap, output of values of the for 10^j - 1 fail for j > 28
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4732
    "/ and are output with the point in the wrong place, leading to a dramatically off value
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4733
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4734
"/    (fixed and:[ (precision > 0) ]) ifTrue:[
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4735
"/        "/ make sure that the value isn't dramatically larger
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4736
"/        from_string = atof(s.c_str());
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4737
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4738
"/        // if this ratio is large, then we've got problems
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4739
"/        if( fabs( from_string / this->x[0] ) > 3.0 ){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4740
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4741
"/                int point_position;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4742
"/                char temp;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4743
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4744
"/                // loop on the string, find the point, move it up one
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4745
"/                // don't act on the first character
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4746
"/                for(i=1; i < s.length(); i++){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4747
"/                        if(s[i] == '.'){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4748
"/                                s[i] = s[i-1] ;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4749
"/                                s[i-1] = '.' ;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4750
"/                                break;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4751
"/                        }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4752
"/                }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4753
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4754
"/                from_string = atof(s.c_str());
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4755
"/                // if this ratio is large, then the string has not been fixed
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4756
"/                if( fabs( from_string / this->x[0] ) > 3.0 ){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4757
"/                        dd_real::error("Re-rounding unsuccessful in large number fixed point trap.") ;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4758
"/                }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4759
"/        }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4760
"/    }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4761
"/
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4762
    fixed ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4763
      "/ Fill in exponent part
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4764
      aStream nextPut:(uppercase ifTrue:[$E] ifFalse:[$e]).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4765
      aStream print:exp.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4766
    ].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4767
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4768
    "/ fill in the blanks
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4769
    (delta := width-count) > 0 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4770
        self halt.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4771
"/    if (fmt & ios_base::internal) {
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4772
"/      if (sgn)
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4773
"/        s.insert(static_cast<string::size_type>(1), delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4774
"/      else
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4775
"/        s.insert(static_cast<string::size_type>(0), delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4776
"/    } else if (fmt & ios_base::left) {
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4777
"/      s.append(delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4778
"/    } else {
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4779
"/      s.insert(static_cast<string::size_type>(0), delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4780
"/    }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4781
"/  }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4782
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4783
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4784
    "Created: / 15-06-2017 / 02:37:31 / cg"
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4785
    "Modified (comment): / 16-06-2017 / 14:48:30 / cg"
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4786
!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4787
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4788
round_string_qd:str at:precisionIn offset:offsetIn
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4789
    <resource: #obsolete>
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4790
    "returns a triple of: { new-str . new-offset . new-precision }"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4791
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4792
    "/
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4793
    "/ Input string must be all digits or errors will occur.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4794
    "/
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4795
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4796
    |i numDigits offsetOut precisionOut|
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4797
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4798
    numDigits := precisionIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4799
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4800
    offsetOut := offsetIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4801
    precisionOut := precisionIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4802
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4803
    "/ Round, handle carry
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4804
    ((str at:numDigits) >= $5) ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4805
        str at:numDigits-1 put:(str at:numDigits-1)+1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4806
        i := numDigits-1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4807
        [ i > 1 and:[ (str at:i) > $9] ] whileTrue:[
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4808
            str at:i put:(str at:i)-10.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4809
            i := i - 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4810
            str at:i put:(str at:i)+1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4811
        ]
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4812
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4813
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4814
    "/ If first digit is 10, shift everything.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4815
    (str at:1) > $9 ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4816
        "/ e++; // don't modify exponent here
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4817
        str replaceFrom:2 with:str startingAt:1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4818
        str at:1 put:$1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4819
        str at:2 put:$0.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4820
        offsetOut := offsetOut + 1.
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4821
        precisionOut := precisionOut + 1.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4822
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4823
    ^ { (str copyTo:precisionOut) . offsetOut . precisionOut }
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4824
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4825
    "Created: / 16-06-2017 / 10:12:39 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4826
    "Modified (comment): / 16-06-2017 / 11:22:03 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4827
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4828
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4829
!QDouble methodsFor:'private'!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4830
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4831
nintAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4832
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4833
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4834
%{
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4835
    /* Computes the nearest integer to d. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4836
#define nint(d) (((d) == floor(d)) ? (d) : floor((d) + 0.5))
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4837
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4838
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4839
    OBJ newQD;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4840
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4841
    double x0, x1, x2, x3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4842
    x0 = nint(a[0]);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4843
    x1 = x2 = x3 = 0.0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4844
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4845
    if (x0 == a[0]) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4846
        /* First double is already an integer. */
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4847
        x1 = nint(a[1]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4848
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4849
        if (x1 == a[1]) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4850
            /* Second double is already an integer. */
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4851
            x2 = nint(a[2]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4852
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4853
            if (x2 == a[2]) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4854
                /* Third double is already an integer. */
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4855
                x3 = nint(a[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4856
            } else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4857
                if (abs(x2 - a[2]) == 0.5 && a[3] < 0.0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4858
                    x2 -= 1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4859
                }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4860
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4861
        } else {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4862
            if (abs(x1 - a[1]) == 0.5 && a[2] < 0.0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4863
                x1 -= 1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4864
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4865
        }
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4866
    } else {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4867
        /* First double is not an integer. */
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4868
        if (abs(x0 - a[0]) == 0.5 && a[1] < 0.0) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4869
            x0 -= 1.0;
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4870
        }
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4871
    }
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4872
    renorm(&x0, &x1, &x2, &x3, x0, x1, x2, x3, 0.0);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4873
    // m_renorm4(x0, x1, x2, x3);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4874
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4875
    __qNew_qdReal(newQD, x0, x1, x2, x3);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4876
    RETURN( newQD );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4877
%}.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4878
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4879
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4880
     (QDouble fromFloat:4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4881
     (QDouble fromFloat:4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4882
     (QDouble fromFloat:4.50000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4883
     (QDouble fromFloat:4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4884
     (QDouble fromFloat:4.49999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4885
     (QDouble fromFloat:4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4886
     (QDouble fromFloat:4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4887
     (QDouble fromFloat:0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4888
     (QDouble fromFloat:0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4889
     (QDouble fromFloat:0.49999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4890
     (QDouble fromFloat:0.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4891
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4892
     (QDouble fromFloat:-4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4893
     (QDouble fromFloat:-4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4894
     (QDouble fromFloat:-4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4895
     (QDouble fromFloat:-4.499999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4896
     (QDouble fromFloat:-4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4897
     (QDouble fromFloat:-4.5000000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4898
     (QDouble fromFloat:-4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4899
     (QDouble fromFloat:-0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4900
     (QDouble fromFloat:-0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4901
     (QDouble fromFloat:-0.4) roundedAsFloat
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4902
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4903
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4904
    "Created: / 13-06-2017 / 01:52:44 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4905
    "Modified (comment): / 13-06-2017 / 17:33:19 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4906
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4907
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4908
renorm
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4909
    "destructive renormalization"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4910
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4911
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4912
    double c0, c1, c2, c3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4913
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  4914
    renorm(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], 0.0);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4915
    a[0] = c0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4916
    a[1] = c1;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4917
    a[2] = c2;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4918
    a[3] = c3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4919
    RETURN( self );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4920
%}.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4921
    ^ self error.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4922
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4923
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4924
     (QDouble fromFloat:1.0) renorm
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4925
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4926
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4927
    "Created: / 13-06-2017 / 18:05:33 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4928
    "Modified: / 15-06-2017 / 00:12:59 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4929
! !
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4930
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4931
!QDouble methodsFor:'private accessing'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4932
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4933
d0
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4934
    "the most significant (and highest valued) 53 bits of precision"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4935
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4936
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[0]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4937
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4938
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4939
    "Created: / 12-06-2017 / 20:15:12 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4940
    "Modified (comment): / 13-06-2017 / 17:59:47 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4941
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4942
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4943
d1
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4944
    "the next most significant (and next highest valued) 53 bits of precision"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4945
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4946
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[1]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4947
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4948
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4949
    "Created: / 12-06-2017 / 20:15:12 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4950
    "Modified (comment): / 13-06-2017 / 18:00:00 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4951
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4952
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4953
d2
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4954
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4955
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[2]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4956
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4957
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4958
    "Created: / 12-06-2017 / 20:15:29 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4959
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4960
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4961
d3
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4962
    "the least significant (and smallest valued) 53 bits of precision"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4963
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4964
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[3]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4965
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4966
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4967
    "Created: / 12-06-2017 / 20:15:32 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4968
    "Modified (comment): / 13-06-2017 / 18:00:18 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4969
! !
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4970
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4971
!QDouble methodsFor:'testing'!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4972
4404
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4973
isFinite
5195
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4974
    "return true, if the receiver is a finite float (not NaN and not +/-INF)"
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4975
4404
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4976
    ^ self d0 isFinite
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4977
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4978
    "Created: / 17-06-2017 / 03:40:30 / cg"
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4979
!
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4980
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4981
isInfinite
5195
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4982
    "return true, if the receiver is an infinite float (+Inf or -Inf)."
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4983
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4984
    ^ self d0 isInfinite
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4985
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4986
    "Created: / 15-06-2017 / 01:57:57 / cg"
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4987
!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4988
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4989
isNaN
5195
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4990
     "return true, if the receiver is an invalid float (NaN - not a number)"
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4991
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4992
   ^ self d0 isNaN
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4993
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4994
    "Created: / 15-06-2017 / 01:57:35 / cg"
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4995
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4996
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4997
isOne
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4998
    ^ self d0 = 1.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4999
    and:[ self d1 = 0.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5000
    and:[ self d2 = 0.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5001
    and:[ self d3 = 0.0 ]]]
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5002
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5003
    "Created: / 18-06-2017 / 23:29:07 / cg"
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5004
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5005
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5006
isZero
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5007
    ^ self d0 = 0.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5008
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  5009
    "Created: / 18-06-2017 / 23:29:25 / cg"
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5010
!
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5011
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5012
negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5013
    ^ self d0 negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5014
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5015
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5016
     (QDouble fromFloat:0.0) negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5017
     (QDouble fromFloat:1.0) negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5018
     (QDouble fromFloat:-1.0) negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5019
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5020
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5021
    "Created: / 13-06-2017 / 01:57:39 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5022
    "Modified: / 13-06-2017 / 17:58:26 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5023
!
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5024
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5025
positive
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5026
    "return true, if the receiver is greater or equal to zero (not negative)"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5027
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5028
    ^ self d0 positive
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5029
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5030
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5031
     (QDouble fromFloat:1.0) positive
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5032
     (QDouble fromFloat:-1.0) positive
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5033
     (1.0 asQDouble + 1e-100) positive
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5034
     (0.0 asQDouble + 1e-100) positive
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5035
     (0.0 asQDouble - 1e-100) positive
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5036
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5037
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5038
    "Created: / 13-06-2017 / 01:56:53 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5039
    "Modified: / 13-06-2017 / 17:58:41 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  5040
    "Modified (comment): / 28-05-2019 / 05:55:55 / Claus Gittinger"
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5041
!
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5042
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5043
sign
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5044
    "return the sign of the receiver"
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5045
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5046
    ^ self d0 sign
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5047
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5048
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5049
     Float nan isNaN
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5050
     Float nan sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5051
     Float infinity sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5052
     Float infinity negated sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5053
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5054
     ShortFloat nan isNaN
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5055
     ShortFloat nan sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5056
     ShortFloat infinity sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5057
     ShortFloat infinity negated sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5058
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5059
     QDouble nan isNaN
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5060
     QDouble nan sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5061
     QDouble infinity sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5062
     QDouble infinity negated sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5063
     0 asQDouble sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5064
     1 asQDouble sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5065
     -1 asQDouble sign
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  5066
    "
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5067
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5068
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5069
!QDouble methodsFor:'truncation & rounding'!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5070
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5071
ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5072
    "return the smallest integer which is greater or equal to the receiver."
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5073
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5074
    |f|
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5075
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5076
    f := self ceilingAsFloat.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5077
    ^ f d0 asInteger + f d1 asInteger + f d2 asInteger + f d3 asInteger
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5078
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5079
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5080
     (QDouble fromFloat:4.0) ceiling
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5081
     (QDouble fromFloat:4.1) ceiling
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5082
     (QDouble fromFloat:0.1) ceiling
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5083
     (0.1 + (QDouble fromFloat:1.0)) ceiling
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5084
     (1e20 + (QDouble fromFloat:1.0)) ceiling
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5085
     (1e20 + (QDouble fromFloat:1.1)) ceiling
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5086
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5087
     (QDouble fromFloat:1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5088
     (QDouble fromFloat:0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5089
     (QDouble fromFloat:-0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5090
     (QDouble fromFloat:-1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5091
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5092
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5093
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5094
ceilingAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5095
    "return the smallest integer-valued float greater or equal to the receiver.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5096
     This is much like #ceiling, but avoids a (possibly expensive) conversion
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5097
     of the result to an integer.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5098
     It may be useful, if the result is to be further used in another float-operation."
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5099
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5100
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5101
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5102
    OBJ newQD;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5103
    int savedCV;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5104
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5105
    double x0, x1, x2, x3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5106
    x1 = x2 = x3 = 0.0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5107
    x0 = ceil(a[0]);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5108
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5109
    if (x0 == a[0]) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5110
        x1 = ceil(a[1]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5111
        if (x1 == a[1]) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5112
            x2 = ceil(a[2]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5113
            if (x2 == a[2]) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5114
                x3 = ceil(a[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5115
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5116
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5117
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5118
        renorm(&x0, &x1, &x2, &x3, x0, x1, x2, x3, 0.0);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5119
        // m_renorm4(x0, x1, x2, x3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5120
        fpu_fix_end(&savedCV);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5121
    }
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5122
    __qNew_qdReal(newQD, x0, x1, x2, x3);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5123
    RETURN( newQD );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5124
%}.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5125
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5126
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5127
     (QDouble fromFloat:4.0) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5128
     (QDouble fromFloat:4.1) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5129
     (QDouble fromFloat:0.1) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5130
     (0.1 + (QDouble fromFloat:1.0)) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5131
     (1e20 + (QDouble fromFloat:1.0)) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5132
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5133
     (QDouble fromFloat:1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5134
     (QDouble fromFloat:0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5135
     (QDouble fromFloat:-0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5136
     (QDouble fromFloat:-1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5137
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5138
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5139
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5140
floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5141
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5142
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5143
    |f|
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5144
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5145
    f := self floorAsFloat.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5146
    ^ f d0 asInteger + f d1 asInteger + f d2 asInteger + f d3 asInteger
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5147
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5148
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5149
     (QDouble fromFloat:4.0) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5150
     (QDouble fromFloat:4.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5151
     (QDouble fromFloat:0.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5152
     (0.1 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5153
     (1e20 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5154
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5155
     (QDouble fromFloat:1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5156
     (QDouble fromFloat:0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5157
     (QDouble fromFloat:-0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5158
     (QDouble fromFloat:-1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5159
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5160
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5161
    "Created: / 13-06-2017 / 01:52:44 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5162
    "Modified (comment): / 13-06-2017 / 17:33:19 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5163
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5164
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5165
floorAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5166
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5167
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5168
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5169
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5170
    OBJ newQD;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5171
    int savedCV;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5172
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5173
    double x0, x1, x2, x3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5174
    x1 = x2 = x3 = 0.0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5175
    x0 =floor(a[0]);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5176
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5177
    if (x0 == a[0]) {
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5178
        x1 = floor(a[1]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5179
        if (x1 == a[1]) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5180
            x2 = floor(a[2]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5181
            if (x2 == a[2]) {
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5182
                x3 = floor(a[3]);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5183
            }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5184
        }
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5185
        fpu_fix_start(&savedCV);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5186
        renorm(&x0, &x1, &x2, &x3, x0, x1, x2, x3, 0.0);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5187
        // m_renorm4(x0, x1, x2, x3);
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5188
        fpu_fix_end(&savedCV);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5189
    }
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5190
    __qNew_qdReal(newQD, x0, x1, x2, x3);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5191
    RETURN( newQD );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5192
%}.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5193
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5194
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5195
     (QDouble fromFloat:4.0) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5196
     (QDouble fromFloat:4.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5197
     (QDouble fromFloat:0.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5198
     (0.1 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5199
     (1e20 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5200
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5201
     (QDouble fromFloat:1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5202
     (QDouble fromFloat:0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5203
     (QDouble fromFloat:-0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5204
     (QDouble fromFloat:-1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5205
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5206
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5207
    "Created: / 13-06-2017 / 01:52:44 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5208
    "Modified (comment): / 13-06-2017 / 17:33:19 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5209
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5210
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5211
rounded
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5212
    "return the smallest integer which is greater or equal to the receiver."
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5213
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5214
    |f|
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5215
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5216
    f := self roundedAsFloat.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5217
    "/ ^ (f d0 + f d1 + f d2 + f d3) asInteger
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5218
    ^ f d0 asInteger + f d1 asInteger + f d2 asInteger + f d3 asInteger
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5219
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5220
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5221
     (QDouble fromFloat:4.0) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5222
     (QDouble fromFloat:4.6) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5223
     (QDouble fromFloat:4.50000001) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5224
     (QDouble fromFloat:4.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5225
     (QDouble fromFloat:4.49999999) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5226
     (QDouble fromFloat:4.4) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5227
     (QDouble fromFloat:4.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5228
     (QDouble fromFloat:0.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5229
     (QDouble fromFloat:0.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5230
     (QDouble fromFloat:0.49999) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5231
     (QDouble fromFloat:0.4) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5232
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5233
     (QDouble fromFloat:-4.0) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5234
     (QDouble fromFloat:-4.6) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5235
     (QDouble fromFloat:-4.4) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5236
     (QDouble fromFloat:-4.499999999) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5237
     (QDouble fromFloat:-4.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5238
     (QDouble fromFloat:-4.5000000001) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5239
     (QDouble fromFloat:-4.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5240
     (QDouble fromFloat:-0.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5241
     (QDouble fromFloat:-0.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5242
     (QDouble fromFloat:-0.4) rounded
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5243
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5244
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5245
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5246
roundedAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5247
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5248
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5249
    self positive ifTrue:[
5315
2d4dfaeac032 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 5314
diff changeset
  5250
        ^ self nintAsFloat
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5251
    ].
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5252
    ^ self negated nintAsFloat negated
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5253
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5254
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5255
     (QDouble fromFloat:4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5256
     (QDouble fromFloat:4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5257
     (QDouble fromFloat:4.50000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5258
     (QDouble fromFloat:4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5259
     (QDouble fromFloat:4.49999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5260
     (QDouble fromFloat:4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5261
     (QDouble fromFloat:4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5262
     (QDouble fromFloat:0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5263
     (QDouble fromFloat:0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5264
     (QDouble fromFloat:0.49999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5265
     (QDouble fromFloat:0.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5266
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5267
     (QDouble fromFloat:-4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5268
     (QDouble fromFloat:-4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5269
     (QDouble fromFloat:-4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5270
     (QDouble fromFloat:-4.499999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5271
     (QDouble fromFloat:-4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5272
     (QDouble fromFloat:-4.5000000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5273
     (QDouble fromFloat:-4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5274
     (QDouble fromFloat:-0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5275
     (QDouble fromFloat:-0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5276
     (QDouble fromFloat:-0.4) roundedAsFloat
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5277
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5278
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5279
    "Created: / 13-06-2017 / 01:52:44 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5280
    "Modified (comment): / 13-06-2017 / 17:33:19 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5281
! !
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5282
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5283
!QDouble class methodsFor:'documentation'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5284
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5285
version
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5286
    ^ '$Header$'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5287
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5288
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5289
version_CVS
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5290
    ^ '$Header$'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5291
! !