QDouble.st
author Stefan Vogel <sv@exept.de>
Fri, 29 Nov 2019 17:34:18 +0100
changeset 5314 1ac391a7075b
parent 5313 f2daab855dad
child 5315 2d4dfaeac032
permissions -rw-r--r--
fix typo
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
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
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
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	instanceVariableNames:''
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
    20
	classVariableNames:'DefaultPrintFormat E Epsilon FMax FMin InvFact Ln10 Ln2 NaN Pi
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
    21
		QDoubleOne QDoubleZero'
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	poolDictionaries:''
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
	category:'Magnitude-Numbers'
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) \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    63
	((((unsigned int *)(&x))[0] == 0x00000000) && \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    64
	 ((((unsigned int *)(&x))[1] & 0x7FF00000) == 0x7FF00000))
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
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    68
#if defined(__x86__) || defined(__x86_64__)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    69
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    70
# ifndef _FPU_EXTENDED
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    71
#  define _FPU_EXTENDED 0x0300
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    72
# endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    73
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    74
# ifndef _FPU_DOUBLE
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    75
#  define _FPU_DOUBLE 0x0200
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    76
# endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    77
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    78
# if defined( __win32__ ) && (defined( __BORLANDC__ ) || defined( __VISUALC__ ))
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
#  define fpu_fix_start(old_cw_ptr)\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    81
    {\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    82
	*old_cw_ptr = _control87(0, 0); \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    83
	_control87(_FPU_DOUBLE, _FPU_EXTENDED);\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    84
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    85
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    86
#  define fpu_fix_end(old_cw_ptr)\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    87
    {\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    88
	_control87(*old_cw_ptr, _FPU_EXTENDED);\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    89
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    90
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    91
# else // assume MINGW, GCC or CLANG
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    92
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    93
#  ifndef _FPU_GETCW
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    94
#   define _FPU_GETCW(x) asm volatile ("fnstcw %0":"=m" (x));
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    95
#  endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    96
#  ifndef _FPU_SETCW
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    97
#   define _FPU_SETCW(x) asm volatile ("fldcw %0": :"m" (x));
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    98
#  endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
    99
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   100
#  define fpu_fix_start(old_cw_ptr)\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   101
    {\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   102
	volatile unsigned short cw, new_cw;\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   103
	_FPU_GETCW(cw);\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   104
	new_cw = (cw & ~_FPU_EXTENDED) | _FPU_DOUBLE;\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   105
	_FPU_SETCW(new_cw);\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   106
	*old_cw_ptr = cw;\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   107
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   108
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   109
#  define fpu_fix_end(old_cw_ptr)\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   110
    {\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   111
	volatile unsigned short cw = *old_cw_ptr;\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   112
	_FPU_SETCW(cw);\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   113
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   114
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
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   117
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   118
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   119
#define __qNew_qdReal(newQD, d0,d1,d2,d3) { \
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   120
    double* __d__;  \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   121
    __qNew(newQD, sizeof(struct __qDoubleStruct));   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   122
    __stx_setClass(newQD, QDouble);                  \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   123
    __d__ = __QDoubleInstPtr(newQD)->d_qDoubleValue; \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   124
    __d__[0] = d0;   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   125
    __d__[1] = d1;   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   126
    __d__[2] = d2;   \
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   127
    __d__[3] = d3;   \
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
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   130
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   131
// sigh: not all compilers (borland) support inline functions;
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   132
// therefore we have to use macros...
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   133
// sigh2: c-macros are unhygienic - to avoid catching/hiding variable bindings,
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   134
// use different names in each macros (i.e. a_xxx)
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   135
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   136
#define _QD_SPLITTER 134217729.0               // = 2^27 + 1
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   137
#define _QD_SPLIT_THRESH 6.69692879491417e+299 // = 2^996
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   138
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   139
#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
   140
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   141
    double s_1 = (a_1) + (b_1);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   142
    (err_1) = (b_1) - (s_1 - (a_1));\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   143
    (rslt_1) = s_1; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   144
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   145
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   146
#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
   147
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   148
    double s_2 = (a_2) - (b_2);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   149
    (err_2) = ((a_2) - s_2) - (b_2);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   150
    (rslt_2) = s_2;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   151
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   152
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   153
#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
   154
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   155
    double s_3 = (a_3) + (b_3);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   156
    double v_3 = s_3 - (a_3);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   157
    (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
   158
    (rslt_3) = s_3;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   159
}
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
/* Computes fl(a-b) and err(a-b).  */
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   162
#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
   163
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   164
    double s_4 = (a_4) - (b_4);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   165
    double bb_4 = s_4 - (a_4);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   166
    (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
   167
    (rslt_4) = s_4;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   168
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   169
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   170
#define m_three_sum(a_5, b_5, c_5)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   171
{ \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   172
    double t1_5, t2_5, t3_5; \
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   173
    m_two_sum(t1_5, (a_5), (b_5), t2_5); \
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   174
    m_two_sum((a_5), (c_5), t1_5, t3_5); \
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   175
    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
   176
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   177
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   178
#define m_three_sum2(a_6, b_6, c_6)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   179
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   180
    double t1_6, t2_6, t3_6;\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   181
    m_two_sum(t1_6, (a_6), (b_6), t2_6);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   182
    m_two_sum((a_6), (c_6), t1_6, t3_6);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   183
    (b_6) = t2_6 + t3_6;\
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
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   186
#ifndef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   187
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   188
/* Computes high word and lo word of a */
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   189
#define m_split(a_7, hi_7, lo_7)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   190
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   191
    double temp_7;\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   192
    double thi_7, tlo_7;\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   193
    if ((a_7) > _QD_SPLIT_THRESH || (a_7) < -_QD_SPLIT_THRESH) {\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   194
	(a_7) *= 3.7252902984619140625e-09;\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   195
	temp_7 = _QD_SPLITTER * (a_7);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   196
	thi_7 = temp_7 - (temp_7 - (a_7));\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   197
	tlo_7 = (a_7) - thi_7;\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   198
	thi_7 *= 268435456.0;\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   199
	tlo_7 *= 268435456.0;\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   200
    } else {\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   201
	temp_7 = _QD_SPLITTER * (a_7);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   202
	thi_7 = temp_7 - (temp_7 - (a_7));\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   203
	tlo_7 = (a_7) - thi_7;\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   204
    }\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   205
    (hi_7) = thi_7; \
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   206
    (lo_7) = tlo_7; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   207
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   208
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   209
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   210
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   211
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   212
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   213
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   214
/* Computes fl(a*b) and err(a*b). */
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   215
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   216
#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
   217
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   218
    double p_8 = (a_8) * (b_8);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   219
    err_8 = QD_FMS((a_8), (b_8), p_8);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   220
    rslt_8 = p_8; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   221
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   222
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   223
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   224
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   225
#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
   226
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   227
    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
   228
    double p_8 = (a_8) * (b_8);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   229
    m_split(a_8, a_hi_8, a_lo_8);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   230
    m_split(b_8, b_hi_8, b_lo_8);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   231
    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
   232
    rslt_8 = p_8; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   233
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   234
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   235
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   236
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   237
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   238
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   239
#define m_two_sqr(rslt_9, a_9, err_9)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   240
{\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   241
    double p_9 = (a_9) * (a_9);\
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   242
    err_9 = QD_FMS((a_9), (a_9), p_9);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   243
    rslt_9 = p_9;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   244
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   245
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   246
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   247
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   248
#define m_two_sqr(rslt_9, a_9, err_9)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   249
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   250
    double hi_9, lo_9;\
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
   251
    double q_9 = (a_9) * (a_9);\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   252
    m_split(a_9, hi_9, lo_9);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   253
    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
   254
    rslt_9 = q_9;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   255
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   256
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   257
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   258
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   259
#define m_renorm4(c0_10, c1_10, c2_10, c3_10)\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   260
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   261
    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
   262
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   263
    if (! isinf(c0_10)) { \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   264
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   265
	m_quick_two_sum(s0_10, c2_10, c3_10, c3_10);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   266
	m_quick_two_sum(s0_10, c1_10, s0_10, c2_10);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   267
	m_quick_two_sum(c0_10, c0_10, s0_10, c1_10);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   268
\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   269
	s0_10 = c0_10;\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   270
	s1_10 = c1_10;\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   271
	if (s1_10 != 0.0) {\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   272
	     m_quick_two_sum(s1_10, s1_10, c2_10, s2_10);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   273
	    if (s2_10 != 0.0) {\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   274
		 m_quick_two_sum(s2_10, s2_10, c3_10, s3_10);\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   275
	    } else {\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   276
		 m_quick_two_sum(s1_10, s1_10, c3_10, s2_10);\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   277
	    }\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   278
	} else {\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   279
	    m_quick_two_sum(s0_10, s0_10, c2_10, s1_10);\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   280
	    if (s1_10 != 0.0) {\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   281
		 m_quick_two_sum(s1_10, s1_10, c3_10, s2_10);\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   282
	    } else {\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   283
		 m_quick_two_sum(s0_10, s0_10, c3_10, s1_10);\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   284
	    }\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   285
	}\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   286
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   287
	c0_10 = s0_10;\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   288
	c1_10 = s1_10;\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   289
	c2_10 = s2_10;\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   290
	c3_10 = s3_10;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   291
    }\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   292
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   293
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   294
#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
   295
{\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   296
    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
   297
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   298
    if (! isinf(c0_11)) { \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   299
	m_quick_two_sum(s0_11, c3_11, c4_11, c4_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   300
	m_quick_two_sum(s0_11, c2_11, s0_11, c3_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   301
	m_quick_two_sum(s0_11, c1_11, s0_11, c2_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   302
	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
   303
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   304
	s0_11 = c0_11; \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   305
	s1_11 = c1_11; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   306
\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   307
	m_quick_two_sum(s0_11, c0_11, c1_11, s1_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   308
	if (s1_11 != 0.0) { \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   309
	    m_quick_two_sum(s1_11, s1_11, c2_11, s2_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   310
	    if (s2_11 != 0.0) { \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   311
		m_quick_two_sum(s2_11 ,s2_11, c3_11, s3_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   312
		if (s3_11 != 0.0) {\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   313
		    s3_11 += c4_11; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   314
		} else {\
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   315
		    s2_11 += c4_11;\
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   316
		}\
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   317
	    } else { \
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   318
		m_quick_two_sum(s1_11, s1_11, c3_11, s2_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   319
		if (s2_11 != 0.0) {\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   320
		    m_quick_two_sum(s2_11, s2_11, c4_11, s3_11); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   321
		} else { \
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   322
		    m_quick_two_sum(s1_11, s1_11, c4_11, s2_11); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   323
		} \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   324
	    } \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   325
	} else { \
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   326
	    m_quick_two_sum(s0_11,s0_11, c2_11, s1_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   327
	    if (s1_11 != 0.0) { \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   328
		m_quick_two_sum(s1_11,s1_11, c3_11, s2_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   329
		if (s2_11 != 0.0) {\
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   330
		    m_quick_two_sum(s2_11,s2_11, c4_11, s3_11); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   331
		} else { \
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   332
		    m_quick_two_sum(s1_11 ,s1_11, c4_11, s2_11); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   333
		} \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   334
	    } else { \
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   335
		m_quick_two_sum(s0_11,s0_11, c3_11, s1_11); \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   336
		if (s1_11 != 0.0) { \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   337
		    m_quick_two_sum(s1_11,s1_11, c4_11, s2_11); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   338
		} else { \
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   339
		    m_quick_two_sum(s0_11,s0_11, c4_11, s1_11); \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   340
		} \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   341
	    } \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   342
	} \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   343
 \
4420
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   344
	c0_11 = s0_11; \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   345
	c1_11 = s1_11; \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   346
	c2_11 = s2_11; \
2ec5ce5062eb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4415
diff changeset
   347
	c3_11 = s3_11; \
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   348
    } \
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   349
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   350
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   351
%}
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
!QDouble primitiveFunctions!
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   355
%{
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
   356
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
   357
#ifdef __BORLANDC__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   358
# define INLINE /* */
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   359
#else
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   360
# define INLINE inline
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   361
#endif
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   362
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   363
// routines
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   364
// 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
   365
// 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
   366
// 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
   367
// three_sum2   : d + e = a + b + c, de are nonoverlapping, Bailey
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   368
// 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
   369
// 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
   370
// renorm       : renormalization algorithm
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   371
// qd_add_s  : qd + double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   372
// qd_add_qd : qd + qd (sloppy add)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   373
// s_sub_qd  : double - qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   374
// qd_sub_qd : qd - qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   375
// s_mul_qd  : double * qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   376
// qd_mul_qd : qd * qd
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   377
// qd_div_qd : qd / qd
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   378
// qd_sqr    : qd ^ 2
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   379
// qd_sqrt   : square root (scalar)
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   380
// qd_pow    : qd ^ n (n integer)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   381
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   382
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   383
fast_two_sum(double *s, double *e, double a, double b)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   384
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   385
    double v;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   386
    s[0] = 0.0; e[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   387
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   388
    s[0] = a + b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   389
    v = s[0] - a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   390
    e[0] = b - v;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   391
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   392
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   393
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   394
two_sum(double *s, double *e, double a, double b)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   395
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   396
    double v;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   397
    s[0] = 0.0; e[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   398
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   399
    s[0] = a + b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   400
    v = s[0] - a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   401
    e[0] = (a - (s[0] - v)) + (b - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   402
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   403
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   404
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   405
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
   406
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   407
    double t1,t2,t3,v;
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
    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
   410
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   411
    t1= a + b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   412
    v = t1 - a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   413
    t2= (a - (t1 - v))+(b - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   414
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   415
    d[0] = t1 + c;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   416
    v = d[0] - t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   417
    t3= (t1 - (d[0] - v))+(c - v);
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
    e[0] = t2 + t3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   420
    v = e[0] - t2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   421
    f[0] = (t2 - (e[0] - v))+(t3 - v);
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
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   424
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   425
three_sum2(double *d, double *e, double a, double b, double c)
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
    double t1,t2,t3,v;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   428
    d[0] = 0.0; e[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   429
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   430
    t1= a + b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   431
    v = t1 - a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   432
    t2= (a - (t1 - v))+(b - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   433
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   434
    d[0] = t1 + c;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   435
    v = d[0] - t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   436
    t3= (t1 - (d[0] - v))+(c - v);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   437
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   438
    e[0] = t2 + t3;
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
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   441
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   442
two_prod(double *p, double *e, double a, double b)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   443
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   444
    double t,ah,al,bh,bl;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   445
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   446
    p[0] = a * b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   447
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   448
    t = 134217729 * a;       // splitter: 2^27 + 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   449
    ah = t -(t - a);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   450
    al = a - ah;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   451
    t = 134217729 * b;       // splitter: 2^27 + 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   452
    bh = t -(t - b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   453
    bl = b - bh;
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
    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
   456
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   457
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   458
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   459
sqr(double *p, double *e, double a)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   460
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   461
    double t,ah,al;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   462
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   463
    p[0] = a * a;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   464
    t = 134217729 * a;          // splitter: 2^27 + 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   465
    ah = t -(t - a);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   466
    al = a - ah;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   467
    e[0] = ((ah*ah - p[0]) + (ah*al)*2.0) + al*al;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   468
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   469
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   470
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   471
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
   472
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   473
    double t0,t1,t2,t3,t4,s,ss;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   474
    s = 0.0; ss = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   475
    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
   476
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   477
//    fast_two_sum(&x, &y, a3, a4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   478
//    s = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   479
//    t4 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   480
//    fast_two_sum(&x, &y, a2, s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   481
//    s = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   482
//    t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   483
//    fast_two_sum(&x, &y, a1, s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   484
//    s = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   485
//    t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   486
//    fast_two_sum(&x, &y, a0, s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   487
//    t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   488
//    t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   489
//    if(t1 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   490
//        fast_two_sum(&x, &y, t1, t2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   491
//        t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   492
//        t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   493
//        if(t2 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   494
//            fast_two_sum(&x, &y,t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   495
//            t2 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   496
//            t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   497
//            if(t3 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   498
//                t3 += t4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   499
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   500
//                t2 += t4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   501
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   502
//        } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   503
//            fast_two_sum(&x, &y, t1, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   504
//            t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   505
//            t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   506
//            if(t2 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   507
//                fast_two_sum(&x, &y, t2, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   508
//                t2 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   509
//                t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   510
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   511
//                fast_two_sum(&x, &y, t1, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   512
//                t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   513
//                t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   514
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   515
//        }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   516
//    } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   517
//        fast_two_sum(&x, &y, t0, t2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   518
//        t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   519
//        t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   520
//        if(t1 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   521
//            fast_two_sum(&x, &y, t1, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   522
//            t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   523
//            t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   524
//            if(t2 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   525
//                fast_two_sum(&x, &y, t2, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   526
//                t2 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   527
//                t3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   528
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   529
//                fast_two_sum(&x, &y, t1, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   530
//                t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   531
//                t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   532
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   533
//        } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   534
//            fast_two_sum(&x, &y, t0, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   535
//            t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   536
//            t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   537
//            if(t1 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   538
//                fast_two_sum(&x, &y, t1, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   539
//                t1 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   540
//                t2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   541
//            } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   542
//                fast_two_sum(&x, &y, t0, t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   543
//                t0 = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   544
//                t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   545
//            }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   546
//        }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   547
//    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   548
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   549
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   550
    //[s,t4] = fast_two_sum(a4,a5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   551
    s = a3 + a4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   552
    t3 = a4 - (s - a3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   553
    //[ss,t3] = fast_two_sum(a3,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   554
    ss = a2 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   555
    t2 = s - (ss - a2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   556
    //[s,t2] = fast_two_sum(a2,ss);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   557
    s  = a1 + ss;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   558
    t1 = ss - (s - a1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   559
    //[b1,t1] = fast_two_sum(a1,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   560
    b0[0] = a0 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   561
    t0 = s - (b0[0] - a0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   562
    //[s,t3] = fast_two_sum(t3,t4);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   563
    s = t2 + t3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   564
    t2 = t3 - (s - t2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   565
    //[ss,t2] = fast_two_sum(t2,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   566
    ss = t1 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   567
    t1 = s - (ss - t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   568
    //[b2,t1] = fast_two_sum(t1,ss);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   569
    b1[0] = t0 + ss;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   570
    t0 = ss - (b1[0] - t0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   571
    //[s,t2] = fast_two_sum(t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   572
    s = t1 + t2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   573
    t1 = t2 - (s -t1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   574
    //[b3,t1] = fast_two_sum(t1,s);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   575
    b2[0] = t0 + s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   576
    t0 = s - (b2[0] - t0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   577
    b3[0] = t0 + t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   578
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   579
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   580
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   581
renorm4(double *c0Ptr, double *c1Ptr, double *c2Ptr, double *c3Ptr) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   582
    double s0, s1, s2 = 0.0, s3 = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   583
    double c0 = *c0Ptr;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   584
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   585
    if (isinf(c0)) return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   586
    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
   587
    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
   588
    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
   589
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   590
    s0 = c0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   591
    s1 = *c1Ptr;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   592
    if (s1 != 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   593
	fast_two_sum(&s1, &s2, s1, *c2Ptr);   // s1 = quick_two_sum(s1, *c2Ptr, &s2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   594
	if (s2 != 0.0)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   595
	    fast_two_sum(&s2, &s3, s2, *c3Ptr);   // s2 = quick_two_sum(s2, *c3Ptr, &s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   596
	else
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   597
	    fast_two_sum(&s1, &s2, s1, *c3Ptr);   // s1 = quick_two_sum(s1, *c3Ptr, &s2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   598
    } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   599
	fast_two_sum(&s0, &s1, s0, *c2Ptr);   // s0 = quick_two_sum(s0, *c2Ptr, &s1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   600
	if (s1 != 0.0)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   601
	    fast_two_sum(&s1, &s2, s1, *c3Ptr);   // s1 = quick_two_sum(s1, *c3Ptr, &s2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   602
	else
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   603
	    fast_two_sum(&s0, &s1, s0, *c3Ptr);   // s0 = quick_two_sum(s0, *c3Ptr, &s1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   604
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   605
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   606
    *c0Ptr = s0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   607
    *c1Ptr = s1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   608
    *c2Ptr = s2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   609
    *c3Ptr = s3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   610
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   611
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
// quad-double square
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
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   618
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
   619
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   620
    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
   621
    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
   622
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   623
    //O(1) term
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   624
    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
   625
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   626
    //O(eps) term
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   627
    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
   628
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   629
    //O(eps^2) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   630
    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
   631
    sqr(&x, &y, a1);                p11 = x;        e11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   632
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   633
    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
   634
    two_sum(&x, &y, e00, e01);      e00 = x;        e01 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   635
    two_sum(&x, &y, p02, p11);      p02 = x;        p11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   636
    two_sum(&x, &y, e00, p02);      s0 = x;         t0 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   637
    two_sum(&x, &y, e01, p11);      s1 = x;         t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   638
    two_sum(&x, &y, s1, t0);        s1 = x;         t0 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   639
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   640
    t0 = t0 + t1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   641
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   642
    fast_two_sum(&x, &y, s1, t0);   s1 = x;         t0 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   643
    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
   644
    fast_two_sum(&x, &y, t1, t0);   p11 = x;        e00 = y;
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
    //O(eps^3) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   647
    p03 = 2.0 * a0 * a3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   648
    p12 = 2.0 * a1 * a2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   649
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   650
    two_sum(&x, &y, p03, p12);      p03 = x;        p12 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   651
    two_sum(&x, &y, e02, e11);      e02 = x;        e11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   652
    two_sum(&x, &y, p03, e02);      t0 = x;         t1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   653
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   654
    t1 = t1 + p12 + e11;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   655
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   656
    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
   657
    p03 = p03 + e00 + t1;                                                   //O(eps^4) term ok
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   658
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   659
    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
   660
    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
   661
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   662
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   663
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   664
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   665
// addition quad-double + double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   666
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   667
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   668
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   669
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
   670
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   671
    double e,x,y,w,z;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   672
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   673
    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
   674
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   675
    two_sum(&x, &y, a0, b);         c0 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   676
    two_sum(&x, &y, a1, e);         c1 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   677
    two_sum(&x, &y, a2, e);         c2 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   678
    two_sum(&x, &y, a3, e);         c3 = x;      e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   679
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   680
    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
   681
}
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
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   685
// addition quad-double + double-double
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
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   688
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   689
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
   690
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   691
    double e1,e2,x,y,w,z;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   692
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   693
    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
   694
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   695
    two_sum(&x, &y, a0, b0);    c0 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   696
    two_sum(&x, &y, a1, b1);    c1 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   697
    two_sum(&x, &y, c1, e1);    c1 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   698
    two_sum(&x, &y, a2, e2);    c2 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   699
    two_sum(&x, &y, c2, e1);    c2 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   700
    two_sum(&x, &y, e1, e2);    e1 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   701
    two_sum(&x, &y, a3, e1);    c3 = x;      e1 = y;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   702
    e1 = e1 + e2;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   703
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e1);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   704
    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
   705
    return;
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
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
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   710
// addition quad-double + quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   711
//
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
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   714
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
   715
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   716
    double e1,e2,e3,e4,x,y,w,z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   717
    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
   718
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   719
    two_sum(&x, &y, a0, b0);        c0[0] = x;      e1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   720
    two_sum(&x, &y, a1, b1);        c1[0] = x;      e2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   721
    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
   722
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   723
    two_sum(&x, &y, a2, b2);        c2[0] = x;      e3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   724
    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
   725
    two_sum(&x, &y, a3, b3);        c3[0] = x;      e4 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   726
    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
   727
    e1 = e1 + e2 + e4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   728
    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
   729
    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
   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
//--------------------------------------------------------------------------------------------
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
// subtraction double - quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   735
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   736
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   737
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   738
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
   739
{
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   740
    double e,x,y,w,z;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   741
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   742
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   743
    e=0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   744
    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
   745
    b0=-b0; b1=-b1; b2=-b2; b3=-b3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   746
    two_sum(&x, &y, a, b0);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   747
    c0 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   748
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   749
    two_sum(&x, &y, b1, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   750
    c1 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   751
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   752
    two_sum(&x, &y, b2, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   753
    c2 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   754
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   755
    two_sum(&x, &y, b3, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   756
    c3 = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   757
    e = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   758
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   759
    o0[0] = x;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   760
    o1[0] = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   761
    o2[0] = w;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   762
    o3[0] = z;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   763
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   764
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   765
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   766
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   767
// subtraction quad-double - quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   768
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   769
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   770
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   771
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
   772
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   773
    double e1,e2,e3,e4,x,y,w,z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   774
    b0 = -b0; b1 = -b1;     b2 = -b2; b3 = -b3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   775
    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
   776
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   777
    two_sum(&x, &y, a0, b0);        c0[0] = x;      e1 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   778
    two_sum(&x, &y, a1, b1);        c1[0] = x;      e2 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   779
    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
   780
    two_sum(&x, &y, a2, b2);        c2[0] = x;      e3 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   781
    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
   782
    two_sum(&x, &y, a3, b3);        c3[0] = x;      e4 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   783
    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
   784
    e1 = e1 + e2 + e4;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   785
    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
   786
    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
   787
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   788
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   789
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   790
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   791
// multiplication double * quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   792
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   793
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   794
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   795
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
   796
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   797
    double e0,e1,e2,x,y,w,z;
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   798
    double c0, c1, c2, c3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   799
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   800
    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
   801
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   802
    two_prod(&x, &y, a0, b);            c0 = x;      e0 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   803
    two_prod(&x, &y, a1, b);            c1 = x;      e1 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   804
    two_sum(&x, &y, c1, e0);            c1 = x;      e0 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   805
    two_prod(&x, &y, a2, b);            c2 = x;      e2 = y;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   806
    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
   807
    c3 = a3*b;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   808
    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
   809
    e0 = e0 + e1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   810
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   811
    renorm(&x, &y, &w, &z, c0, c1, c2, c3, e0);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
   812
    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
   813
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   814
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   815
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   816
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   817
// multiplication quad-double * quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   818
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   819
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   820
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   821
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
   822
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   823
    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
   824
    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
   825
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   826
    //O(1) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   827
    two_prod(&x, &y, a0, b0);       c0[0] = x;      e00 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   828
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   829
    //O(eps) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   830
    two_prod(&x, &y, a0, b1);       p01 = x;        e01 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   831
    two_prod(&x, &y, a1, b0);       p10 = x;        e10 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   832
    three_sum(&x, &y, &z, p01, p10, e00);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   833
    c1[0] = x;      //O(eps)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   834
    p10 = y;        //O(eps^2)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   835
    p01 = z;        //O(eps^3)
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
    //O(eps^2) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   838
    two_prod(&x, &y, a0, b2);       p02 = x;        e02 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   839
    two_prod(&x, &y, a1, b1);       p11 = x;        e11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   840
    two_prod(&x, &y, a2, b0);       p20 = x;        e20 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   841
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   842
    //six three sum for p10, e01, e10, p02, p11, p20
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   843
    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
   844
    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
   845
    two_sum(&x, &y, p02, p10);                  c2[0] = x;      p10 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   846
    two_sum(&x, &y, p11, e01);                  p11 = x;        e01 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   847
    two_sum(&x, &y, p10, p11);                  p10 = x;        p11 = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   848
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   849
    e10 = e10 + p20 + e01 + p11;    //O(eps^4) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   850
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   851
    //O(eps^3) terms
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   852
    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
   853
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   854
    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
   855
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   856
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   857
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   858
    c3[0] = z;
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
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   862
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   863
// division quad-double / double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   864
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   865
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   866
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   867
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   868
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
   869
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   870
    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
   871
    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
   872
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   873
    c0[0] = a0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   874
    // reminder a - c_0*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   875
    two_prod(&x, &y, c0[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   876
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   877
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   878
    //qd subtruction (a - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   879
    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
   880
    r0 = x;     r1 = y; r2 = w; r3 = z;
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
    c1[0] = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   883
    // reminder r - c_1*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   884
    two_prod(&x, &y, c1[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   885
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   886
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   887
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   888
    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
   889
    r0 = x;     r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   890
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   891
    c2[0] = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   892
    // reminder r - c_2*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   893
    two_prod(&x, &y, c2[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   894
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   895
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   896
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   897
    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
   898
    r0 = x;     r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   899
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   900
    c3[0] = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   901
    // reminder r - c_3*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   902
    two_prod(&x, &y, c3[0], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   903
    t0 = -x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   904
    t1 = -y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   905
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   906
    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
   907
    r0 = x;     r1 = y; r2 = w; r3 = z;
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
    e = r0/b;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   910
    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
   911
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   912
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   913
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   914
    c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   915
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   916
}
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
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   919
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   920
// division quad-double / quad-double
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   921
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   922
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   923
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   924
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
   925
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   926
    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
   927
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   928
    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
   929
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   930
    c0[0] = a0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   931
    // reminder a - c_0*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   932
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   933
    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
   934
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   935
    //qd subtruction (a - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   936
    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
   937
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   938
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   939
    c1[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   940
    // reminder r - c_1*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   941
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   942
    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
   943
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   944
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   945
    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
   946
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   947
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   948
    c2[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   949
    // reminder r - c_2*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   950
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   951
    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
   952
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   953
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   954
    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
   955
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   956
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   957
    c3[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   958
    // reminder r - c_3*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   959
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   960
    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
   961
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   962
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   963
    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
   964
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   965
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   966
    e = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   967
    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
   968
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   969
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   970
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   971
    c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   972
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   973
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   974
//--------------------------------------------------------------------------------------------
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
// division double / quad-double sloppy
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   977
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   978
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   979
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   980
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
   981
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   982
    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
   983
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   984
    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
   985
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   986
    c0[0] = a/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   987
    // reminder a - c_0*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   988
    //multiplication
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   989
    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
   990
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   991
    //qd subtruction (a - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   992
    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
   993
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   994
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   995
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
    c1[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   998
    // reminder r - c_1*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
   999
    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
  1000
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1001
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1002
    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
  1003
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1004
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1005
    c2[0] = r0/b0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1006
    // reminder r - c_2*b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1007
    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
  1008
    t0 = -x;        t1 = -y;        t2 = -w;        t3 = -z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1009
    //qd subtruction (r - t)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1010
    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
  1011
    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1012
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1013
    c3[0] = r0/b0;
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
    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
  1016
    c0[0] = x;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1017
    c1[0] = y;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1018
    c2[0] = w;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1019
    c3[0] = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1020
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1021
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1022
static INLINE void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1023
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
  1024
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1025
    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
  1026
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1027
    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
  1028
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1029
    c0[0] = 1.0/sqrt(a0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1030
    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
  1031
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1032
    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
  1033
    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
  1034
    x0 = -p;        x1 = -q;        x2 = -r;        x3 = -s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1035
    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
  1036
    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
  1037
    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
  1038
    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
  1039
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1040
    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
  1041
    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
  1042
    x0 = -p;        x1 = -q;        x2 = -r;        x3 = -s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1043
    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
  1044
    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
  1045
    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
  1046
    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
  1047
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1048
    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
  1049
    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
  1050
    x0 = -p;        x1 = -q;        x2 = -r;        x3 = -s;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1051
    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
  1052
    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
  1053
    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
  1054
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1055
    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
  1056
    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
  1057
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1058
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1059
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1060
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
  1061
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1062
    double r0,r1,r2,r3,x,y,w,z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1063
    int abs_p;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1064
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1065
    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
  1066
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1067
    if (p == 0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1068
	c0[0] = 1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1069
    } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1070
	r0 = a0; r1 = a1; r2 = a2; r3 = a3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1071
	c0[0] = 1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1072
	abs_p = abs(p);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1073
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1074
	if (abs_p > 1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1075
	    while (abs_p > 0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1076
		if ((abs_p % 2)==1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1077
		    qd_mul_qd(&x, &y, &w, &z, c0[0], c1[0], c2[0], c3[0], r0, r1, r2, r3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1078
		    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
  1079
		}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1080
		abs_p = abs_p / 2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1081
		if (abs_p > 0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1082
		    qd_sqr(&x, &y, &w, &z, r0, r1, r2, r3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1083
		    r0 = x; r1 = y; r2 = w; r3 = z;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1084
		}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1085
	    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1086
	} else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1087
	    c0[0] = r0; c1[0] = r1;     c2[0] = r2;     c3[0] = r3;
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
	if (p < 0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1090
	    s_div_qd(&x, &y, &w, &z, 1.0, c0[0], c1[0], c2[0], c3[0]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1091
	    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
  1092
	}
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
}
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
// round to nearest integer
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1097
#define round(x)  (floor((x)+0.5))
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
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1100
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
  1101
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1102
    x0[0]=round(a0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1103
    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
  1104
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1105
    if(x0[0]==a0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1106
	x1[0]=round(a1);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1107
	if(x1[0]==a1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1108
	    x2[0]=round(a2);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1109
	    if(x2[0]==a2) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1110
		x3[0]=round(a3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1111
	    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1112
	    else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1113
		if(((int)fabs(x2[0]-a2)==0.5) && (a3<0.0)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1114
		    x2[0]=x2[0]-1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1115
		}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1116
	    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1117
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1118
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1119
	    if(((int)fabs(x1[0]-a1)==0.5) && (a2<0.0)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1120
		x1[0]=x1[0]-1.0;
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
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1123
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1124
    else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1125
	if(((int)fabs(x0[0]-a0)==0.5) && (a1<0.0)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1126
	    x0[0]=x0[0]-1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1127
	}
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
    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
  1130
    return;
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
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1133
static double s_table[256][4]= {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1134
    {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
  1135
    {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
  1136
    {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
  1137
    {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
  1138
    {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
  1139
    {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
  1140
    {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
  1141
    {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
  1142
    {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
  1143
    {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
  1144
    {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
  1145
    {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
  1146
    {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
  1147
    {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
  1148
    {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
  1149
    {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
  1150
    {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
  1151
    {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
  1152
    {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
  1153
    {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
  1154
    {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
  1155
    {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
  1156
    {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
  1157
    {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
  1158
    {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
  1159
    {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
  1160
    {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
  1161
    {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
  1162
    {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
  1163
    {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
  1164
    {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
  1165
    {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
  1166
    {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
  1167
    {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
  1168
    {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
  1169
    {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
  1170
    {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
  1171
    {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
  1172
    {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
  1173
    {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
  1174
    {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
  1175
    {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
  1176
    {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
  1177
    {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
  1178
    {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
  1179
    {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
  1180
    {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
  1181
    {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
  1182
    {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
  1183
    {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
  1184
    {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
  1185
    {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
  1186
    {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
  1187
    {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
  1188
    {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
  1189
    {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
  1190
    {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
  1191
    {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
  1192
    {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
  1193
    {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
  1194
    {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
  1195
    {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
  1196
    {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
  1197
    {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
  1198
    {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
  1199
    {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
  1200
    {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
  1201
    {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
  1202
    {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
  1203
    {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
  1204
    {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
  1205
    {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
  1206
    {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
  1207
    {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
  1208
    {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
  1209
    {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
  1210
    {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
  1211
    {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
  1212
    {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
  1213
    {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
  1214
    {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
  1215
    {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
  1216
    {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
  1217
    {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
  1218
    {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
  1219
    {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
  1220
    {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
  1221
    {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
  1222
    {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
  1223
    {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
  1224
    {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
  1225
    {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
  1226
    {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
  1227
    {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
  1228
    {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
  1229
    {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
  1230
    {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
  1231
    {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
  1232
    {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
  1233
    {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
  1234
    {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
  1235
    {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
  1236
    {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
  1237
    {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
  1238
    {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
  1239
    {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
  1240
    {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
  1241
    {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
  1242
    {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
  1243
    {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
  1244
    {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
  1245
    {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
  1246
    {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
  1247
    {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
  1248
    {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
  1249
    {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
  1250
    {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
  1251
    {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
  1252
    {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
  1253
    {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
  1254
    {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
  1255
    {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
  1256
    {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
  1257
    {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
  1258
    {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
  1259
    {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
  1260
    {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
  1261
    {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
  1262
    {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
  1263
    {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
  1264
    {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
  1265
    {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
  1266
    {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
  1267
    {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
  1268
    {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
  1269
    {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
  1270
    {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
  1271
    {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
  1272
    {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
  1273
    {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
  1274
    {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
  1275
    {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
  1276
    {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
  1277
    {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
  1278
    {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
  1279
    {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
  1280
    {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
  1281
    {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
  1282
    {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
  1283
    {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
  1284
    {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
  1285
    {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
  1286
    {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
  1287
    {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
  1288
    {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
  1289
    {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
  1290
    {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
  1291
    {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
  1292
    {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
  1293
    {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
  1294
    {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
  1295
    {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
  1296
    {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
  1297
    {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
  1298
    {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
  1299
    {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
  1300
    {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
  1301
    {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
  1302
    {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
  1303
    {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
  1304
    {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
  1305
    {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
  1306
    {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
  1307
    {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
  1308
    {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
  1309
    {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
  1310
    {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
  1311
    {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
  1312
    {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
  1313
    {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
  1314
    {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
  1315
    {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
  1316
    {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
  1317
    {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
  1318
    {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
  1319
    {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
  1320
    {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
  1321
    {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
  1322
    {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
  1323
    {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
  1324
    {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
  1325
    {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
  1326
    {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
  1327
    {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
  1328
    {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
  1329
    {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
  1330
    {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
  1331
    {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
  1332
    {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
  1333
    {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
  1334
    {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
  1335
    {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
  1336
    {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
  1337
    {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
  1338
    {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
  1339
    {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
  1340
    {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
  1341
    {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
  1342
    {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
  1343
    {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
  1344
    {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
  1345
    {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
  1346
    {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
  1347
    {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
  1348
    {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
  1349
    {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
  1350
    {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
  1351
    {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
  1352
    {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
  1353
    {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
  1354
    {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
  1355
    {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
  1356
    {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
  1357
    {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
  1358
    {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
  1359
    {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
  1360
    {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
  1361
    {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
  1362
    {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
  1363
    {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
  1364
    {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
  1365
    {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
  1366
    {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
  1367
    {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
  1368
    {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
  1369
    {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
  1370
    {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
  1371
    {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
  1372
    {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
  1373
    {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
  1374
    {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
  1375
    {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
  1376
    {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
  1377
    {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
  1378
    {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
  1379
    {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
  1380
    {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
  1381
    {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
  1382
    {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
  1383
    {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
  1384
    {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
  1385
    {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
  1386
    {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
  1387
    {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
  1388
    {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
  1389
    {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
  1390
};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1391
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1392
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1393
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
  1394
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1395
    int int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1396
    s0[0]=s_table[int_j-1][0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1397
    s1[0]=s_table[int_j-1][1];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1398
    s2[0]=s_table[int_j-1][2];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1399
    s3[0]=s_table[int_j-1][3];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1400
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1401
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1402
static double c_table[265][4] = {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1403
    {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
  1404
    {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
  1405
    {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
  1406
    {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
  1407
    {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
  1408
    {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
  1409
    {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
  1410
    {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
  1411
    {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
  1412
    {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
  1413
    {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
  1414
    {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
  1415
    {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
  1416
    {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
  1417
    {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
  1418
    {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
  1419
    {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
  1420
    {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
  1421
    {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
  1422
    {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
  1423
    {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
  1424
    {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
  1425
    {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
  1426
    {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
  1427
    {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
  1428
    {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
  1429
    {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
  1430
    {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
  1431
    {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
  1432
    {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
  1433
    {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
  1434
    {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
  1435
    {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
  1436
    {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
  1437
    {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
  1438
    {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
  1439
    {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
  1440
    {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
  1441
    {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
  1442
    {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
  1443
    {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
  1444
    {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
  1445
    {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
  1446
    {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
  1447
    {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
  1448
    {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
  1449
    {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
  1450
    {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
  1451
    {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
  1452
    {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
  1453
    {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
  1454
    {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
  1455
    {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
  1456
    {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
  1457
    {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
  1458
    {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
  1459
    {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
  1460
    {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
  1461
    {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
  1462
    {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
  1463
    {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
  1464
    {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
  1465
    {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
  1466
    {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
  1467
    {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
  1468
    {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
  1469
    {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
  1470
    {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
  1471
    {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
  1472
    {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
  1473
    {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
  1474
    {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
  1475
    {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
  1476
    {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
  1477
    {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
  1478
    {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
  1479
    {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
  1480
    {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
  1481
    {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
  1482
    {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
  1483
    {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
  1484
    {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
  1485
    {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
  1486
    {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
  1487
    {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
  1488
    {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
  1489
    {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
  1490
    {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
  1491
    {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
  1492
    {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
  1493
    {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
  1494
    {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
  1495
    {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
  1496
    {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
  1497
    {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
  1498
    {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
  1499
    {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
  1500
    {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
  1501
    {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
  1502
    {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
  1503
    {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
  1504
    {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
  1505
    {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
  1506
    {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
  1507
    {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
  1508
    {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
  1509
    {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
  1510
    {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
  1511
    {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
  1512
    {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
  1513
    {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
  1514
    {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
  1515
    {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
  1516
    {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
  1517
    {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
  1518
    {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
  1519
    {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
  1520
    {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
  1521
    {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
  1522
    {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
  1523
    {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
  1524
    {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
  1525
    {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
  1526
    {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
  1527
    {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
  1528
    {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
  1529
    {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
  1530
    {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
  1531
    {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
  1532
    {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
  1533
    {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
  1534
    {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
  1535
    {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
  1536
    {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
  1537
    {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
  1538
    {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
  1539
    {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
  1540
    {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
  1541
    {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
  1542
    {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
  1543
    {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
  1544
    {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
  1545
    {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
  1546
    {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
  1547
    {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
  1548
    {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
  1549
    {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
  1550
    {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
  1551
    {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
  1552
    {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
  1553
    {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
  1554
    {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
  1555
    {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
  1556
    {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
  1557
    {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
  1558
    {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
  1559
    {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
  1560
    {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
  1561
    {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
  1562
    {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
  1563
    {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
  1564
    {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
  1565
    {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
  1566
    {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
  1567
    {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
  1568
    {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
  1569
    {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
  1570
    {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
  1571
    {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
  1572
    {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
  1573
    {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
  1574
    {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
  1575
    {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
  1576
    {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
  1577
    {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
  1578
    {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
  1579
    {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
  1580
    {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
  1581
    {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
  1582
    {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
  1583
    {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
  1584
    {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
  1585
    {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
  1586
    {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
  1587
    {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
  1588
    {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
  1589
    {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
  1590
    {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
  1591
    {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
  1592
    {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
  1593
    {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
  1594
    {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
  1595
    {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
  1596
    {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
  1597
    {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
  1598
    {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
  1599
    {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
  1600
    {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
  1601
    {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
  1602
    {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
  1603
    {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
  1604
    {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
  1605
    {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
  1606
    {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
  1607
    {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
  1608
    {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
  1609
    {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
  1610
    {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
  1611
    {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
  1612
    {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
  1613
    {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
  1614
    {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
  1615
    {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
  1616
    {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
  1617
    {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
  1618
    {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
  1619
    {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
  1620
    {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
  1621
    {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
  1622
    {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
  1623
    {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
  1624
    {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
  1625
    {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
  1626
    {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
  1627
    {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
  1628
    {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
  1629
    {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
  1630
    {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
  1631
    {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
  1632
    {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
  1633
    {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
  1634
    {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
  1635
    {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
  1636
    {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
  1637
    {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
  1638
    {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
  1639
    {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
  1640
    {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
  1641
    {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
  1642
    {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
  1643
    {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
  1644
    {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
  1645
    {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
  1646
    {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
  1647
    {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
  1648
    {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
  1649
    {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
  1650
    {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
  1651
    {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
  1652
    {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
  1653
    {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
  1654
    {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
  1655
    {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
  1656
    {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
  1657
    {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
  1658
    {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
  1659
};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1660
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1661
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1662
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
  1663
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1664
    int int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1665
    c0[0]=c_table[int_j-1][0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1666
    c1[0]=c_table[int_j-1][1];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1667
    c2[0]=c_table[int_j-1][2];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1668
    c3[0]=c_table[int_j-1][3];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1669
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1670
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1671
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1672
static double inv_fact[15][4] = {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1673
    {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
  1674
    {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
  1675
    {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
  1676
    {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
  1677
    {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
  1678
    {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
  1679
    {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
  1680
    {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
  1681
    {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
  1682
    {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
  1683
    {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
  1684
    {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
  1685
    {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
  1686
    {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
  1687
    {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
  1688
};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1689
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1690
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1691
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
  1692
{
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1693
	double eps = 1.21543267145725e-63; // = 2^-209
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1694
	double thresh = 0.5*fabs(x0)*eps;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1695
	double y0,y1,y2,y3,r0,r1,r2,r3,t0,t1,t2,t3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1696
	int i;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1697
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1698
	if(x0==0.0) {
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1699
	    s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1700
	    return;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1701
	}
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1702
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1703
	i=0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1704
	qd_mul_qd(&y0,&y1,&y2,&y3,x0,x1,x2,x3,x0,x1,x2,x3);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1705
	y0 = -y0;   y1 = -y1;   y2 = -y2;   y3 = -y3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1706
	s0[0]=x0;   s1[0]=x1;   s2[0]=x2;   s3[0]=x3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1707
	r0=x0;      r1=x1;      r2=x2;      r3=x3;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1708
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1709
	qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1710
	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]);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1711
	qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],s0[0],s1[0],s2[0],s3[0],t0,t1,t2,t3);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1712
	i=i+2;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1713
	while ((i<=15)||(fabs(t0)>thresh)) {
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1714
	    qd_mul_qd(&r0,&r1,&r2,&r3,r0,r1,r2,r3,y0,y1,y2,y3);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1715
	    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]);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1716
	    qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],s0[0],s1[0],s2[0],s3[0],t0,t1,t2,t3);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1717
	    i=i+2;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1718
	}
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1719
}
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1720
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1721
static void
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1722
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
  1723
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1724
    double eps = 1.21543267145725e-63; // = 2^-209
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1725
    double thresh = 0.5*eps;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1726
    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
  1727
    int i;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1728
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1729
    if(x0==0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1730
	c0[0]=1.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
  1731
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1732
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1733
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1734
    i=1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1735
    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
  1736
    y0 = -y0;   y1 = -y1;   y2 = -y2;   y3 = -y3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1737
    r0=y0; r1=y1; r2=y2; r3=y3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1738
    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
  1739
    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
  1740
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1741
    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
  1742
    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
  1743
    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
  1744
    i=i+2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1745
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1746
    while((i<=15)||(fabs(t0)>thresh)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1747
	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
  1748
	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]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1749
	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
  1750
	i=i+2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1751
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1752
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1753
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1754
static void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1755
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
  1756
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1757
    double eps = 1.21543267145725e-63; // = 2^-209
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1758
    double thresh = 0.5 * fabs(x0)*eps;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1759
    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
  1760
    int i;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1761
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1762
    if(x0==0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1763
	s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1764
	c0[0]=1.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
  1765
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1766
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1767
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1768
    i=0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1769
    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
  1770
    y0 = -y0;   y1 = -y1;   y2 = -y2;   y3 = -y3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1771
    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
  1772
    r0=x0; r1=x1; r2=x2; r3=x3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1773
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1774
    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
  1775
    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
  1776
    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
  1777
    i=i+2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1778
    while ((i<=15)||((int)fabs(t0)>thresh)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1779
	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
  1780
	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
  1781
	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
  1782
	i=i+2;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1783
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1784
    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
  1785
    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
  1786
    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
  1787
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1788
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1789
//--------------------------------------------------------------------------------------------
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
// quad-double sine
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1792
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1793
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1794
// a0, a1, a2, a3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1795
// a0 + a1 + a2 + a3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1796
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1797
// return (s0,s1,s2,s3) for qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1798
//
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
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1801
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
  1802
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1803
    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
  1804
    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
  1805
    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
  1806
    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
  1807
    double u0,u1,u2,u3,v0,v1,v2,v3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1808
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1809
    int int_j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1810
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1811
    if(a0[0]==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1812
	s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1813
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1814
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1815
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1816
    //approximately reduce modulo 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1817
    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
  1818
    nint_qd(&z0,&z1,&z2,&z3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1819
    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
  1820
    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
  1821
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1822
    //approximately reduce modulo pi/2 and then modulo pi/1024
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1823
    j=floor(r0/_pi2[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1824
    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
  1825
    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
  1826
    k=floor(t0/_pi1024[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1827
    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
  1828
    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
  1829
    abs_k=(int)fabs(k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1830
    int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1831
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1832
    //checking errors
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1833
    if(j<-2 || j>2) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1834
	s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1835
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1836
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1837
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1838
    if(abs_k >256) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1839
	s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1840
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1841
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1842
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1843
    if(k==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1844
	switch(int_j) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1845
	    case 0:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1846
		sin_taylor_qd(&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
  1847
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1848
	    case 1:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1849
		cos_taylor_qd(&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
  1850
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1851
	    case -1:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1852
		cos_taylor_qd(&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
  1853
		s0[0]=-s0[0]; s1[0]=-s1[0]; s2[0]=-s2[0]; s3[0]=-s3[0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1854
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1855
	    case 2:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1856
	    case -2:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1857
		sin_taylor_qd(&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
  1858
		s0[0]=-s0[0]; s1[0]=-s1[0]; s2[0]=-s2[0]; s3[0]=-s3[0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1859
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1860
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1861
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1862
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1863
    cos_table_qd(&u0,&u1,&u2,&u3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1864
    sin_table_qd(&v0,&v1,&v2,&v3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1865
    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
  1866
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1867
    if(j==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1868
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1869
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1870
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1871
	    qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1872
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1873
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1874
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1875
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1876
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
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
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1879
    else if(j==1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1880
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1881
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1882
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1883
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1884
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1885
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1886
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1887
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1888
	    qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1889
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1890
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1891
    else if(j==-1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1892
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1893
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1894
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1895
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1896
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1897
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1898
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1899
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1900
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1901
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1902
	}
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
    else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1905
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1906
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1907
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1908
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1909
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1910
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1911
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1912
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1913
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1914
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1915
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1916
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1917
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1918
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1919
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1920
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1921
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1922
// quad-double cosine
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1923
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1924
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1925
// a0, a1, a2, a3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1926
// a0 + a1 + a2 + a3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1927
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1928
// return (c0,c1,c2,c3) for qd number
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
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1931
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  1932
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
  1933
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1934
    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
  1935
    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
  1936
    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
  1937
    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
  1938
    double u0,u1,u2,u3,v0,v1,v2,v3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1939
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1940
    int int_j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1941
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1942
    if(a0[0]==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1943
	c1[0]=1.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
  1944
	return;
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
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1947
    //approximately reduce modulo 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1948
    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
  1949
    nint_qd(&z0,&z1,&z2,&z3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1950
    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
  1951
    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
  1952
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1953
    //approximately reduce modulo pi/2 and then modulo pi/1024
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1954
    j=floor(r0/_pi2[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1955
    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
  1956
    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
  1957
    k=floor(t0/_pi1024[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1958
    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
  1959
    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
  1960
    abs_k=(int)fabs(k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1961
    int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1962
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1963
    //checking errors
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1964
    if(j<-2 || j>2) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1965
	c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1966
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1967
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1968
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1969
    if(abs_k >256) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1970
	c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1971
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1972
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1973
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1974
    if(k==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1975
	switch(int_j) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1976
	    case 0:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1977
		cos_taylor_qd(&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
  1978
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1979
	    case 1:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1980
		sin_taylor_qd(&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
  1981
		c0[0]=-c0[0]; c1[0]=-c1[0]; c2[0]=-c2[0]; c3[0]=-c3[0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1982
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1983
	    case -1:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1984
		sin_taylor_qd(&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
  1985
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1986
	    case 2:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1987
	    case -2:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1988
		cos_taylor_qd(&c0[0],&c1[0],&c2[2],&c3[0],t0,t1,t2,t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1989
		c0[0]=-c0[0]; c1[0]=-c1[0]; c2[0]=-c2[0]; c3[0]=-c3[0];
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1990
		return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1991
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1992
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1993
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1994
    cos_table_qd(&u0,&u1,&u2,&u3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1995
    sin_table_qd(&v0,&v1,&v2,&v3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1996
    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
  1997
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1998
    if(j==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  1999
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2000
	    //u * cos_t - v * sin_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2001
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2002
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2003
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2004
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2005
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2006
	    //u * cos_t + v * sin_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2007
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2008
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2009
	    qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2010
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2011
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2012
    else if(j==1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2013
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2014
	    //-u * sin_t - v * cos_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2015
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2016
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2017
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2018
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,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
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2021
	    //v * cos_t - u * sin_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2022
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2023
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2024
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2025
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2026
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2027
    else if(j==-1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2028
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2029
	    //u * sin_t + v * cos_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2030
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2031
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2032
	    qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2033
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2034
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2035
	    //u * sin_t - v * cos_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2036
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2037
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2038
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
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
    else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2042
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2043
	    //v * sin_t - u * cos_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2044
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2045
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2046
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2047
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2048
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2049
	    //-u * cos_t - v * sin_t;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2050
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2051
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2052
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2053
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2054
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2055
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2056
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2057
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2058
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
// quad-double sine and cosine
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2062
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2063
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2064
static INLINE void
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2065
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
  2066
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2067
    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
  2068
    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
  2069
    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
  2070
    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
  2071
    double u0,u1,u2,u3,v0,v1,v2,v3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2072
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2073
    int int_j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2074
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2075
    if(a0==0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2076
	s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2077
	c0[0]=1.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
  2078
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2079
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2080
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2081
    //approximately reduce modulo 2*pi
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2082
    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
  2083
    nint_qd(&z0,&z1,&z2,&z3,p0,p1,p2,p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2084
    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
  2085
    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
  2086
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2087
    //approximately reduce modulo pi/2 and then modulo pi/1024
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2088
    j=floor(r0/_pi2[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2089
    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
  2090
    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
  2091
    k=floor(t0/_pi1024[0]+0.5);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2092
    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
  2093
    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
  2094
    abs_k=(int)fabs(k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2095
    int_j=(int)j;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2096
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2097
    //checking errors
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2098
    if(j<-2 || j>2) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2099
	s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2100
	c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2101
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2102
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2103
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2104
    if(abs_k >256) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2105
	s0[0]=0.0; s1[0]=0.0; s2[0]=0.0; s3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2106
	c0[0]=0.0; c1[0]=0.0; c2[0]=0.0; c3[0]=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2107
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2108
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2109
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2110
    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
  2111
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2112
    if(k==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2113
	if(j==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2114
	    s0[0]=sin0; s1[0]=sin1; s2[0]=sin2; s3[0]=sin3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2115
	    c0[0]=cos0; c1[0]=cos1; c2[0]=cos2; c3[0]=cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2116
	    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2117
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2118
	else if(j==1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2119
	    s0[0]=cos0; s1[0]=cos1; s2[0]=cos2; s3[0]=cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2120
	    c0[0]=-sin0; c1[0]=-sin1; c2[0]=-sin2; c3[0]=-sin3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2121
	    return;
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
	else if(j==-1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2124
	    s0[0]=-cos0; s1[0]=-cos1; s2[0]=-cos2; s3[0]=-cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2125
	    c0[0]=sin0; c1[0]=sin1; c2[0]=sin2; c3[0]=sin3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2126
	    return;
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
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2129
	    s0[0]=-sin0; s1[0]=-sin1; s2[0]=-sin2; s3[0]=-sin3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2130
	    c0[0]=-cos0; c1[0]=-cos1; c2[0]=-cos2; c3[0]=-cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2131
	    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2132
	}
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
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2135
    cos_table_qd(&u0,&u1,&u2,&u3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2136
    sin_table_qd(&v0,&v1,&v2,&v3,abs_k);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2137
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2138
    if(j==0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2139
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2140
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2141
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2142
	    qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2143
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2144
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2145
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2146
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
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
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2149
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2150
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2151
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2152
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2153
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2154
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2155
	    qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2156
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2157
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2158
    else if(j==1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2159
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2160
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2161
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2162
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
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
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2165
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2166
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2167
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2168
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2169
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2170
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2171
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2172
	    qd_add_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2173
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2174
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2175
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2176
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2177
	}
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
    else if(j==-1) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2180
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2181
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2182
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2183
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2184
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2185
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2186
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2187
	    qd_add_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2188
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2189
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2190
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2191
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2192
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2193
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2194
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2195
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2196
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2197
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2198
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2199
    }
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
    else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2202
	if(k>0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2203
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2204
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2205
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2206
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2207
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2208
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2209
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2210
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2211
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2212
	else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2213
	    qd_mul_qd(&p0,&p1,&p2,&p3,v0,v1,v2,v3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2214
	    qd_mul_qd(&q0,&q1,&q2,&q3,u0,u1,u2,u3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2215
	    qd_sub_qd(&s0[0],&s1[0],&s2[0],&s3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2216
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2217
	    qd_mul_qd(&p0,&p1,&p2,&p3,u0,u1,u2,u3,cos0,cos1,cos2,cos3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2218
	    qd_mul_qd(&q0,&q1,&q2,&q3,v0,v1,v2,v3,sin0,sin1,sin2,sin3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2219
	    p0=-p0; p1=-p1; p2=-p2; p3=-p3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2220
	    qd_sub_qd(&c0[0],&c1[0],&c2[0],&c3[0],p0,p1,p2,p3,q0,q1,q2,q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2221
	}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2222
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2223
}
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
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2226
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2227
// quad-double tangent
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2228
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2229
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2230
// a0, a1, a2, a3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2231
// a0 + a1 + a2 + a3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2232
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2233
// return (t0,t1,t2,t3) for qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2234
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2235
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2236
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2237
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
  2238
{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2239
    double sin0,sin1,sin2,sin3,cos0,cos1,cos2,cos3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2240
    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
  2241
    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
  2242
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2243
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2244
//--------------------------------------------------------------------------------------------
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
// quad-double exponent
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2247
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2248
// args
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2249
// x0, x1, x2, x3 : double numbers
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2250
// x0 + x1 + x2 + x3 = qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2251
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2252
// return (e0, e1, e2, e3) for qd number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2253
//
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2254
//--------------------------------------------------------------------------------------------
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2255
static void
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2256
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
  2257
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2258
    double k = ldexp(1.0,16);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2259
    double inv_k = 1.0 / k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2260
    double log_2[4] = {6.931471805599452862e-01,2.319046813846299558e-17,5.707708438416212066e-34,-3.582432210601811423e-50};
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2261
    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
  2262
    int i;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2263
    double t=1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2264
    double eps = 1.21543267145725e-63; // = 2^-209
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2265
    double thresh = inv_k * eps;
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
    if((x0[0]==0.0) && (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
  2268
	e0[0] = 1.0;    e1[0] = 0.0;    e2[0] = 0.0;    e3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2269
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2270
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2271
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2272
    if((x0[0]==1.0) && (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
  2273
	e0[0] = 2.7182818284590451;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2274
	e1[0] = 1.4456468917292502e-16;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2275
	e2[0] = -2.127717108038176765e-33;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2276
	e3[0] = 1.515630159841218954e-49;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2277
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2278
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2279
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2280
    if(x0[0]<=-709) {               //underflow
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2281
	e0[0] = 0.0;    e1[0] = 0.0;    e2[0] = 0.0;    e3[0] = 0.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2282
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2283
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2284
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2285
    if(x0[0]>=709) {                //overflow
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2286
	e0[0] = 0.0;    e1[0] = 1.0;    e2[0] = 2.0;    e3[0] = 3.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2287
	return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2288
    }
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
    m = floor(x0[0] / log_2[0] + 0.5);
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
    s_mul_qd(&p0, &p1, &p2, &p3, m, log_2[0], log_2[1], log_2[2], log_2[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2293
    qd_sub_qd(&q0, &q1, &q2, &q3, x0[0], x1[0], x2[0], x3[0], p0, p1, p2, p3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2294
    r0 = q0 * inv_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2295
    r1 = q1 * inv_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2296
    r2 = q2 * inv_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2297
    r3 = q3 * inv_k;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2298
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2299
    qd_sqr(&p0, &p1, &p2, &p3, r0, r1, r2, r3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2300
    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
  2301
    i = 0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2302
    do {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2303
	qd_mul_qd(&p0, &p1, &p2, &p3, p0, p1, p2, p3, r0, r1, r2, r3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2304
	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]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2305
	i = i+1;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2306
	qd_add_qd(&s0, &s1, &s2, &s3, s0, s1, s2, s3, t0, t1, t2, t3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2307
    } while ((i<=17) && (fabs(t0)>thresh));
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2308
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
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2311
    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
  2312
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2313
    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
  2314
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2315
    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
  2316
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2317
    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
  2318
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2319
    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
  2320
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2321
    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
  2322
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2323
    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
  2324
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2325
    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
  2326
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2327
    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
  2328
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2329
    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
  2330
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2331
    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
  2332
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2333
    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
  2334
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2335
    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
  2336
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2337
    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
  2338
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2339
    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
  2340
    qd_sqr(&v0, &v1, &v2, &v3, s0, s1, s2, s3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2341
    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
  2342
    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
  2343
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2344
    for(i=0; i<m; i++) {
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2345
	t=t*2;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2346
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2347
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2348
    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
  2349
    return;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2350
}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2351
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2352
#if 0
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2353
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2354
/*********** Basic Functions ************/
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2355
/* 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
  2356
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2357
quick_two_sum(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2358
  double s = a + b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2359
  *errPtr = b - (s - a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2360
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2361
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2362
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2363
/* 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
  2364
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2365
quick_two_diff(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2366
  double s = a - b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2367
  *errPtr = (a - s) - b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2368
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2369
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2370
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2371
/* Computes fl(a+b) and err(a+b).  */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2372
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2373
two_sum(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2374
  double s = a + b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2375
  double bb = s - a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2376
  *errPtr = (a - (s - bb)) + (b - bb);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2377
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2378
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2379
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2380
/* Computes fl(a-b) and err(a-b).  */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2381
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2382
two_diff(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2383
  double s = a - b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2384
  double bb = s - a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2385
  *errPtr = (a - (s - bb)) - (b + bb);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2386
  return s;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2387
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2388
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2389
#ifndef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2390
/* Computes high word and lo word of a */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2391
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2392
split(double a, double *hiPtr, double *loPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2393
  double temp;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2394
  if (a > _QD_SPLIT_THRESH || a < -_QD_SPLIT_THRESH) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2395
    a *= 3.7252902984619140625e-09;  // 2^-28
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2396
    temp = _QD_SPLITTER * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2397
    *hiPtr = temp - (temp - a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2398
    *loPtr = a - *hiPtr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2399
    *hiPtr *= 268435456.0;          // 2^28
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2400
    *loPtr *= 268435456.0;          // 2^28
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2401
  } else {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2402
    temp = _QD_SPLITTER * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2403
    *hiPtr = temp - (temp - a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2404
    *loPtr = a - *hiPtr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2405
  }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2406
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2407
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2408
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2409
/* Computes fl(a*b) and err(a*b). */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2410
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2411
two_prod(double a, double b, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2412
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2413
  double p = a * b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2414
  *errPtr = QD_FMS(a, b, p);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2415
  return p;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2416
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2417
  double a_hi, a_lo, b_hi, b_lo;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2418
  double p = a * b;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2419
  split(a, &a_hi, &a_lo);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2420
  split(b, &b_hi, &b_lo);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2421
  *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
  2422
  return p;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2423
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2424
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2425
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2426
/* 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
  2427
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2428
two_sqr(double a, double *errPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2429
#ifdef QD_FMS
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2430
  double p = a * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2431
  *errPtr = QD_FMS(a, a, p);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2432
  return p;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2433
#else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2434
  double hi, lo;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2435
  double q = a * a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2436
  split(a, &hi, &lo);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2437
  *errPtr = ((hi * hi - q) + 2.0 * hi * lo) + lo * lo;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2438
  return q;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2439
#endif
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 the nearest integer to d. */
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
nint(double d) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2445
  if (d == floor(d))
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2446
    return d;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2447
  return floor(d + 0.5);
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 the truncated integer. */
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
aint(double d) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2453
  return (d >= 0.0) ? floor(d) : ceil(d);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2454
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2455
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2456
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2457
renorm4(double *c0Ptr, double *c1Ptr, double *c2Ptr, double *c3Ptr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2458
  double s0, s1, s2 = 0.0, s3 = 0.0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2459
  double c0 = *c0Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2460
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2461
  if (isinf(c0)) return;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2462
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2463
  s0 = quick_two_sum(*c2Ptr, *c3Ptr, c3Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2464
  s0 = quick_two_sum(*c1Ptr, s0, c2Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2465
  c0 = quick_two_sum(c0, s0, c1Ptr);
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
  s0 = c0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2468
  s1 = *c1Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2469
  if (s1 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2470
    s1 = quick_two_sum(s1, *c2Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2471
    if (s2 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2472
      s2 = quick_two_sum(s2, *c3Ptr, &s3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2473
    else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2474
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2475
  } else {
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2476
    s0 = quick_two_sum(s0, *c2Ptr, &s1);
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2477
    if (s1 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2478
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2479
    else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2480
      s0 = quick_two_sum(s0, *c3Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2481
  }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2482
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2483
  *c0Ptr = s0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2484
  *c1Ptr = s1;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2485
  *c2Ptr = s2;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2486
  *c3Ptr = s3;
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
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2489
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2490
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
  2491
  double s0, s1, s2 = 0.0, s3 = 0.0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2492
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2493
  if (isinf(*c0Ptr)) return;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2494
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2495
  s0 = quick_two_sum(*c3Ptr, *c4Ptr, c4Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2496
  s0 = quick_two_sum(*c2Ptr, s0, c3Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2497
  s0 = quick_two_sum(*c1Ptr, s0, c2Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2498
  *c0Ptr = quick_two_sum(*c0Ptr, s0, c1Ptr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2499
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2500
  s0 = *c0Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2501
  s1 = *c1Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2502
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2503
  s0 = quick_two_sum(*c0Ptr, *c1Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2504
  if (s1 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2505
    s1 = quick_two_sum(s1, *c2Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2506
    if (s2 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2507
      s2 =quick_two_sum(s2, *c3Ptr, &s3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2508
      if (s3 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2509
	s3 += *c4Ptr;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2510
      else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2511
	s2 += *c4Ptr;
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
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2514
      if (s2 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2515
	s2 = quick_two_sum(s2, *c4Ptr, &s3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2516
      else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2517
	s1 = quick_two_sum(s1, *c4Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2518
    }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2519
  } else {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2520
    s0 = quick_two_sum(s0, *c2Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2521
    if (s1 != 0.0) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2522
      s1 = quick_two_sum(s1, *c3Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2523
      if (s2 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2524
	s2 = quick_two_sum(s2, *c4Ptr, &s3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2525
      else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2526
	s1 = quick_two_sum(s1, *c4Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2527
    } else {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2528
      s0 = quick_two_sum(s0, *c3Ptr, &s1);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2529
      if (s1 != 0.0)
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2530
	s1 = quick_two_sum(s1, *c4Ptr, &s2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2531
      else
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2532
	s0 = quick_two_sum(s0, *c4Ptr, &s1);
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
  }
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2535
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2536
  *c0Ptr = s0;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2537
  *c1Ptr = s1;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2538
  *c2Ptr = s2;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2539
  *c3Ptr = s3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2540
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2541
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2542
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2543
three_sum(double *aPtr, double *bPtr, double *cPtr) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2544
  double t1, t2, t3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2545
  t1 = two_sum(*aPtr, *bPtr, &t2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2546
  *aPtr  = two_sum(*cPtr, t1, &t3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2547
  *bPtr  = two_sum(t2, t3, cPtr);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2548
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2549
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2550
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
  2551
  double t1, t2, t3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2552
  t1 = two_sum(*aPtr, *bPtr, &t2);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2553
  *aPtr  = two_sum(*cPtr, t1, &t3);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2554
  *bPtr = t2 + t3;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2555
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2556
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2557
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2558
#if 0
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2559
/* These are provided to give consistent
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2560
   interface for double with double-double and quad-double. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2561
INLINE void
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2562
sincosh(double t, double &sinh_t, double &cosh_t) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2563
  sinh_t = sinh(t);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2564
  cosh_t = cosh(t);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2565
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2566
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2567
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2568
sqr(double t) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2569
  return t * t;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2570
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2571
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2572
INLINE double
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2573
to_double(double a) {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2574
    return a;
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2575
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2576
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2577
INLINE int
4413
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2578
to_int(double a)    {
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2579
    return static_cast<int>(a);
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2580
}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2581
#endif
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2582
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2583
%}
e3ee8be3627f oops - cvs messed it
Claus Gittinger <cg@exept.de>
parents: 4412
diff changeset
  2584
! !
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2585
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2586
!QDouble class methodsFor:'documentation'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2587
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2588
copyright
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2589
"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2590
 COPYRIGHT (c) 2017 by eXept Software AG
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2591
	      All Rights Reserved
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2592
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2593
 This software is furnished under a license and may be used
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2594
 only in accordance with the terms of that license and with the
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2595
 inclusion of the above copyright notice.   This software may not
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2596
 be provided or otherwise made available to, or used by, any
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2597
 other person.  No title to or ownership of the software is
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2598
 hereby transferred.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2599
"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2600
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2601
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2602
documentation
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2603
"
4391
f2ece85e1ae3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4390
diff changeset
  2604
    ATTENTION: ongoing, unfinished work.
4450
c832d7890dda #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4447
diff changeset
  2605
    No warranty that this works correctly...
4391
f2ece85e1ae3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4390
diff changeset
  2606
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2607
    QDoubles represent rational numbers with extended, but still limited precision.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2608
4451
1550f45dc062 #QUALITY by cg
Claus Gittinger <cg@exept.de>
parents: 4450
diff changeset
  2609
    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
  2610
    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
  2611
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2612
    Representation:
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2613
	QDoubles use 4 IEEE doubles, each keeping 53 bits of precision.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2614
	A qDouble's value is the sum of those 4 doubles,
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2615
	and a qDouble keeps this unevaluated sum as its state.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2616
	(due to overlap and rounding, the final precision is less than 53*4)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2617
	The exponent range is still the double exponent range,
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2618
	but the number of mantissa bits is rougly multiplied by 4.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2619
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2620
    Range and Precision of Storage Formats: see LimitedPrecisionReal >> documentation
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  2621
    The number of decmal digits:
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2622
	QDouble decimalPrecision     -> 61
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2623
	LongFloat decimalPrecision   -> 19
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2624
	Float decimalPrecision       -> 16
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2625
	ShortFloat decimalPrecision  -> 7
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  2626
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  2627
    The number of bits:
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2628
	QDouble precision            -> 204
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2629
	LongFloat precision          -> 64
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2630
	Float precision              -> 53
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2631
	ShortFloat precision         -> 24
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2632
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2633
    Notice:
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2634
	when assigning a converted double precision number as in:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2635
	    qd := 1.0 asQDouble.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2636
	you still get only a regular double precision approximation to 0.1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2637
	because the error is already inherit in the double.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2638
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2639
	For a full precision constant, you (currently) need to convert from a string
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2640
	(because the compilers do not know about them, yet):
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2641
	    qd := QDouble readFrom:'0.1'.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2642
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2643
	To see the error of the double precision version, compute:
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2644
	    (0.1 asQDouble) - (QDouble readFrom:'0.1')
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2645
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2646
    [author:]
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2647
	Claus Gittinger
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2648
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2649
    [see also:]
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2650
	Number
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2651
	Float ShortFloat LongFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2652
	Fraction FixedPoint Integer Complex
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2653
	FloatArray DoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2654
"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2655
!
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2656
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2657
examples
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2658
"
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2659
  Floats, LongFloats suffer from loosing bits:
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2660
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2661
     (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2662
    -(Float readFrom:'0.333333333333333333333333333333333333333333333333333333333')
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2663
	-> 0.0
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2664
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2665
       (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2666
     = (Float readFrom:'0.333333333333333333333333333333333333333333333333333333333')
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2667
	-> true
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2668
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2669
       (Float readFrom:'0.33333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2670
     = (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333333333333')
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2671
	-> true
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2672
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
  2673
       (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2674
     = (Float readFrom:'0.3333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2675
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2676
     (LongFloat readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2677
    -(LongFloat readFrom:'0.333333333333333333333333333333333333333333333333333333333')
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2678
	-> 0.0
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2679
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2680
      (LongFloat readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2681
    = (LongFloat readFrom:'0.333333333333333333333333333333333333333333333333333333333')
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2682
	-> 0.0
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2683
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2684
 (QDouble readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2685
-(QDouble readFrom:'0.333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2686
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2687
 (QDouble readFrom:'0.33333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2688
-(QDouble readFrom:'0.3333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2689
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2690
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2691
 (QDouble readFrom:'0.33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2692
-(QDouble readFrom:'0.3333333333333333333333333333333333333333333333333333333333333333333333333333333333333333')
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2693
"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2694
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2695
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2696
!QDouble class methodsFor:'instance creation'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2697
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2698
basicNew
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2699
    "return a new quad-precision double - here we return 0.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2700
     Notice that numbers are usually NOT created this way ...
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2701
     It's implemented here to allow things like binary store & load
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2702
     of floats. (but even this support will go away eventually, it's not
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2703
     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
  2704
     totally different representation - so floats should be
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2705
     binary stored in a device independent format."
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2706
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2707
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2708
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2709
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2710
#else
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2711
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2712
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2713
    __qNew_qdReal(newQD, 0.0, 0.0, 0.0, 0.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2714
    RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2715
#endif /* not SCHTEAM */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2716
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2717
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2718
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2719
     self basicNew
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2720
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2721
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2722
    "Created: / 12-06-2017 / 16:00:38 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2723
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2724
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2725
d0:d0 d1:d1 d2:d2 d3:d3
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2726
    "return a new quad-precision double from individual double components"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2727
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2728
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2729
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2730
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2731
#else
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2732
    OBJ newQD;
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2733
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2734
    if (__isFloatLike(d0)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2735
     && __isFloatLike(d1)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2736
     && __isFloatLike(d2)
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2737
     && __isFloatLike(d3)) {
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2738
	__qNew_qdReal(newQD, __floatVal(d0), __floatVal(d1),
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2739
			     __floatVal(d2), __floatVal(d3));
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2740
	RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2741
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2742
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2743
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2744
    self error:'invalid argument'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2745
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2746
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2747
     self d0: 3.141592653589793116e+00
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2748
	  d1: 1.224646799147353207e-16
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2749
	  d2: -2.994769809718339666e-33
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2750
	  d3: 1.112454220863365282e-49
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2751
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2752
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2753
    "Created: / 12-06-2017 / 20:17:14 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2754
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2755
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2756
fromDoubleArray:aDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2757
    "return a new quad-precision double from coercing a double array"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2758
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2759
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2760
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2761
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2762
#else
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2763
    OBJ newQD;
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2764
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2765
    if (__isDoubleArray(aDoubleArray)) {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2766
	double* __d__ =  __DoubleArrayInstPtr(aDoubleArray)->d_element;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2767
	__qNew_qdReal(newQD, __d__[0], __d__[1], __d__[2], __d__[3]);
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2768
	RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2769
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2770
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2771
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2772
    self error:'invalid argument'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2773
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2774
    "
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2775
     self fromDoubleArray(DoubleArray
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2776
				with: 3.141592653589793116e+00
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2777
				with: 1.224646799147353207e-16
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2778
				with: -2.994769809718339666e-33
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2779
				with: 1.112454220863365282e-49)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2780
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2781
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2782
    "Created: / 12-06-2017 / 18:25:32 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2783
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2784
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2785
fromFloat:aFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2786
    "return a new quad-precision double from coercing aFloat"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2787
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2788
%{  /* NOCONTEXT */
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2789
#ifdef __SCHTEAM__
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2790
    ERROR("trying to instantiate a qDouble");
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2791
#else
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2792
    double dVal;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2793
    OBJ newQD;
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2794
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2795
    if (__isFloatLike(aFloat)) {
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2796
	dVal = __floatVal(aFloat);
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2797
    } else if (__isShortFloat(aFloat)) {
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2798
	dVal = __shortFloatVal(aFloat);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2799
    } else {
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2800
	goto badArg;
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2801
    }
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2802
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2803
    __qNew_qdReal(newQD, dVal, 0.0, 0.0, 0.0);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2804
    RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2805
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2806
badArg: ;
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2807
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2808
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2809
%}.
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2810
    self argumentError:'invalid (non-float) argument'
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2811
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2812
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2813
     self fromFloat:1.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2814
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2815
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2816
    "Created: / 12-06-2017 / 16:06:54 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2817
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2818
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2819
fromInteger:anInteger
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2820
    "return a new quad-precision double from coercing anInteger"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2821
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2822
%{  /* NOCONTEXT */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2823
#ifdef __SCHTEAM__
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2824
    ERROR("trying to instantiate a qDouble");
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2825
#else
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2826
    OBJ newQD;
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2827
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2828
    if (__isSmallInteger(anInteger)) {
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2829
	INT iVal = __smallIntegerVal(anInteger);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2830
	double *d;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2831
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2832
	__qNew(newQD, sizeof(struct __qDoubleStruct));
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2833
	__stx_setClass(newQD, QDouble);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2834
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2835
	d = __QDoubleInstPtr(newQD)->d_qDoubleValue;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2836
	d[1] = 0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2837
	d[2] = 0.0;
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2838
	d[3] = 0.0;
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2839
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2840
	// need more than 52bits?
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2841
	if ((sizeof(INT) > 52)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2842
	 && ((iVal > 0xFFFFFFFFFFFFF) || (iVal < -0xFFFFFFFFFFFFF))) {
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2843
	    d[0] = (double)(iVal & ~0xFFFFFFFF);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2844
	    d[1] = (double)(iVal & 0xFFFFFFFF);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2845
	    renorm(&(d[0]), &(d[1]), &(d[2]), &(d[3]), d[0], d[1], 0.0, 0.0, 0.0);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2846
	    // renorm4(&(a[0]), &(a[1]), &(a[2]), &(a[3]));
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2847
	} else {
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  2848
	    d[0] = (double)iVal;
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2849
	}
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2850
	RETURN (newQD);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2851
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2852
#endif
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2853
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2854
    ^ super fromInteger:anInteger
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2855
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2856
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2857
     self fromInteger:2
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2858
     self fromInteger:16rFFFFFFFF            -- 32bit 4294967295.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2859
     self fromInteger:16rFFFFFFFFFFFF        -- 48bit 281474976710655.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2860
     self fromInteger:16rFFFFFFFFFFFFF       -- 52bit 4503599627370495.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2861
     self fromInteger:16rFFFFFFFFFFFFFF      -- 56bit 72057594037927935.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2862
     self fromInteger:16rFFFFFFFFFFFFFFF     -- 60bit 1152921504606846975.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2863
     self fromInteger:16r1FFFFFFFFFFFFFFF    -- 61bit 2305843009213693951.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2864
     self fromInteger:16r3FFFFFFFFFFFFFFF    -- 62bit 4611686018427387903.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2865
     self fromInteger:16r7FFFFFFFFFFFFFFF    -- 63bit 9223372036854775807.0
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2866
     self fromInteger:16rFFFFFFFFFFFFFFFF    -- 64bit 18446744073709551615.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2867
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2868
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2869
    "Created: / 12-06-2017 / 16:10:10 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  2870
    "Modified: / 04-07-2017 / 12:51:52 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2871
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2872
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2873
!QDouble class methodsFor:'coercing & converting'!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2874
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2875
coerce:aNumber
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2876
    "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
  2877
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2878
    ^ aNumber asQDouble
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2879
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2880
    "Created: / 12-06-2017 / 17:13:47 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2881
    "Modified: / 12-06-2017 / 21:09:06 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2882
! !
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  2883
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2884
!QDouble class methodsFor:'constants'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2885
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2886
NaN
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2887
    "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
  2888
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2889
    NaN isNil ifTrue:[
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  2890
	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
  2891
    ].
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2892
    ^ NaN
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2893
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2894
    "Created: / 21-06-2017 / 20:44:57 / cg"
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2895
!
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  2896
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2897
e
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2898
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  2899
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2900
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2901
    E isNil ifTrue:[
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2902
	E := self d0: 2.718281828459045091e+00
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2903
		  d1: 1.445646891729250158e-16
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2904
		  d2: -2.127717108038176765e-33
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2905
		  d3: 1.515630159841218954e-49
4388
742f099741bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4387
diff changeset
  2906
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2907
    ^ E
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2908
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2909
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2910
     self e printfPrintString:'%.61f'
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  2911
       -> '2.7182818284590452353602874713526624977572470936999595749669676'
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  2912
     Wolfram says:
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2913
	   2.71828182845904523536028747135266249775724709369995957496696762772407663035354759457138217852516642742746
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2914
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2915
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2916
    "Created: / 12-06-2017 / 18:29:36 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2917
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2918
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2919
fmax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2920
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  2921
     (returns approx. 200 bits of precision)"
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2922
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2923
    FMax isNil ifTrue:[
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2924
	FMax := self d0: 1.797693134862314E+308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2925
		     d1: 9.97920154767359795037e+291
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2926
		     d2: 5.53956966280111259858e+275
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2927
		     d3: 3.07507889307840487279e+259
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2928
    ].
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2929
    ^ FMax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2930
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2931
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2932
     Float fmax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2933
     self fmax
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2934
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2935
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2936
    "Created: / 14-06-2017 / 19:14:18 / cg"
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2937
!
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2938
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2939
fmin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2940
    "return the smallest representable instance of this class"
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2941
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2942
    FMin isNil ifTrue:[
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2943
	FMin := Float fmin asQDouble. "/ 1.6259745436952323e-260 asQDouble
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2944
    ].
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2945
    ^ FMin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2946
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2947
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2948
     QDouble fmin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2949
     Float fmin
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2950
    "
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2951
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2952
    "Created: / 14-06-2017 / 19:14:49 / cg"
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2953
!
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  2954
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  2955
infinity
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  2956
    ^ Infinity positive
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  2957
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  2958
    "Created: / 18-06-2017 / 23:41:07 / cg"
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  2959
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  2960
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2961
ln10
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2962
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  2963
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2964
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2965
    Ln10 isNil ifTrue:[
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  2966
	Ln10 := self d0: 2.302585092994045901e+00
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  2967
		     d1: -2.170756223382249351e-16
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  2968
		     d2: -9.984262454465776570e-33
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  2969
		     d3: -4.023357454450206379e-49
4388
742f099741bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4387
diff changeset
  2970
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2971
    ^ Ln10
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2972
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2973
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  2974
     self ln10 printfPrintString:'%.61f'
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  2975
	-> '2.3025850929940456840179914546843642076011014886287729760333279'
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  2976
     Wolfram says:
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  2977
	    2.30258509299404568401799145468436420760110148862877297603332790096757260967735248023599720508959829834196778404228...
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2978
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2979
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2980
    "Created: / 12-06-2017 / 18:32:29 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2981
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2982
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2983
ln2
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2984
    "return the constant e as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  2985
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2986
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2987
    Ln2 isNil ifTrue:[
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2988
	Ln2 := self d0: 6.931471805599452862e-01
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2989
		    d1: 2.319046813846299558e-17
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2990
		    d2: 5.707708438416212066e-34
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2991
		    d3: -3.582432210601811423e-50
4388
742f099741bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4387
diff changeset
  2992
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2993
    ^ Ln2
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2994
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  2995
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2996
     self ln2 printfPrintString:'%.61f'
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2997
	-> '0.6931471805599452709398341558750792990469129794959648865081141'
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  2998
     Wolfram says:
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  2999
	    0.69314718055994530941723212145817656807550013436025525412068000949339362196969471560586332699641868754200148102057...
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3000
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3001
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3002
    "Created: / 12-06-2017 / 18:31:34 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3003
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3004
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3005
negativeInfinity
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3006
    ^ Infinity negative
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3007
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3008
    "Created: / 18-06-2017 / 23:40:47 / cg"
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3009
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  3010
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3011
pi
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3012
    "return the constant pi as quad precision double.
4433
37d85359188d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4431
diff changeset
  3013
     (returns approx. 200 bits of precision)"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3014
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3015
    Pi isNil ifTrue:[
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3016
	Pi := self d0: 3.141592653589793116e+00
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3017
		   d1: 1.224646799147353207e-16
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3018
		   d2: -2.994769809718339666e-33
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3019
		   d3: 1.112454220863365282e-49
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3020
    ].
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3021
    ^ Pi
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3022
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3023
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3024
     self pi printfPrintString:'%.60f'
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3025
	  '3.141592653589793238462643383279502884197169399375105820974945'
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3026
     Wolfram says:
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3027
	   3.141592653589793238462643383279502884197169399375105820974944592307816406286208998628034825342117068
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3028
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3029
     (QDouble readFrom:'3.1415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253')
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3030
     printfPrintString:'%.60f'
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3031
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3032
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3033
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3034
    "Created: / 12-06-2017 / 18:27:13 / cg"
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3035
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3036
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3037
unity
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3038
    "return the neutral element for multiplication (1.0) as QDouble"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3039
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3040
    QDoubleOne isNil ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3041
	QDoubleOne := 1.0 asQDouble.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3042
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3043
    ^ QDoubleOne
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3044
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3045
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3046
     self unity
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3047
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3048
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3049
    "Created: / 15-06-2017 / 11:45:22 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3050
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3051
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3052
zero
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3053
    "return the neutral element for addition (0.0) as QDouble"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3054
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3055
    QDoubleZero isNil ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3056
	QDoubleZero := 0.0 asQDouble
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3057
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3058
    ^ QDoubleZero
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3059
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3060
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3061
     self zero
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3062
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3063
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3064
    "Created: / 15-06-2017 / 11:44:13 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3065
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3066
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3067
!QDouble class methodsFor:'queries'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3068
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3069
defaultPrintPrecision
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3070
    "return the number of decimal digits printed by default"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3071
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3072
    ^ 30
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3073
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3074
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3075
     ShortFloat defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3076
     Float defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3077
     LongFloat defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3078
     QDouble defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3079
     QuadFloat defaultPrintPrecision
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3080
     OctaFloat defaultPrintPrecision
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3081
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3082
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3083
    "Created: / 17-06-2017 / 02:58:51 / cg"
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3084
    "Modified: / 21-06-2017 / 13:39:08 / cg"
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3085
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3086
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3087
epsilon
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3088
    "return the maximum relative spacing of instances of mySelf
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  3089
     (i.e. the value-delta of the least significant bit)
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  3090
     see https://en.wikipedia.org/wiki/Machine_epsilon"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3091
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3092
    "/ ^ 1.2154326714572500565324311366323150942261000827598106963711353e-63
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3093
    Epsilon isNil ifTrue:[
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3094
	Epsilon := self computeEpsilon.
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3095
    ].
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3096
    ^ Epsilon
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3097
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3098
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3099
     Float epsilon       -> 2.22044604925031E-16
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3100
     ShortFloat epsilon  -> 1.19209289550781E-07
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  3101
     LongFloat epsilon   -> 1.0842021724855E-19
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3102
     QDouble epsilon     -> 7.77876909732643E-62 / (1.215432671457250056532e-63 read comment in 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
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3105
    "Created: / 12-06-2017 / 18:52:44 / cg"
4443
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  3106
    "Modified: / 22-06-2017 / 15:34:56 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3107
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3108
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3109
numBitsInExponent
5275
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3110
    "answer the number of bits in the exponent.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3111
     I use regular IEEE doubles to store the value,
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3112
     thus my exponent bits are the same as double's exponent bits"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3113
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3114
    ^ Float numBitsInExponent
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3115
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3116
    "
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3117
     1.0 asQDouble numBitsInExponent
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3118
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3119
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3120
    "Created: / 12-06-2017 / 11:11:04 / cg"
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3121
    "Modified (comment): / 28-05-2019 / 08:55:04 / Claus Gittinger"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3122
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3123
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3124
numBitsInMantissa
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3125
    "answer the number of bits in the mantissa.
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3126
     Here, a fake number is returned"
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3127
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3128
    ^ (Float numBitsInMantissa - 1) * 4
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3129
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3130
    "
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3131
     1.0 asFloat numBitsInMantissa
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3132
     1.0 asShortFloat numBitsInMantissa
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3133
     1.0 asLongFloat numBitsInMantissa
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3134
     1.0 asQDouble numBitsInMantissa
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3135
     1.0 asQDouble class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3136
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3137
     Float numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3138
     ShortFloat numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3139
     QDouble numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3140
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3141
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3142
    "Created: / 12-06-2017 / 11:13:44 / cg"
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3143
    "Modified (comment): / 20-06-2017 / 11:05:26 / cg"
4963
51f6cd13f43b #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4962
diff changeset
  3144
    "Modified (comment): / 28-05-2019 / 09:07:07 / Claus Gittinger"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3145
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3146
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3147
precision
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3148
    "answer the number of bits in the mantissa"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3149
4431
a7e1399f418e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4430
diff changeset
  3150
    "/ subtract some due to overlap in the component numbers
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3151
    "/ actual precision seems to be more like:
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3152
    "/ ^ (Float precision) * 4 - 3 + 1.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3153
    "/ but I am a bit conservative here:
4431
a7e1399f418e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4430
diff changeset
  3154
    ^ (Float precision - 2) * 4
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3155
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3156
    "
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3157
     ShortFloat precision  -> 24
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3158
     Float precision       -> 53
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3159
     LongFloat precision   -> 64
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3160
     QDouble precision     -> 204
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3161
     QuadFloat precision   -> 113
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3162
     OctaFloat precision   -> 237
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3163
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3164
     1.0 class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3165
     1.0 asShortFloat class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3166
     1.0 asLongFloat class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3167
     1.0 asQDouble class numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3168
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3169
     Float numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3170
     ShortFloat numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3171
     QDouble numBitsInMantissa
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3172
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3173
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3174
    "Created: / 12-06-2017 / 18:49:11 / cg"
4431
a7e1399f418e #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4430
diff changeset
  3175
    "Modified (comment): / 20-06-2017 / 12:59:00 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3176
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3177
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3178
radix
5057
cc72e91af490 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 4981
diff changeset
  3179
    "answer the radix of a QDouble's exponent
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3180
     This is an IEEE float, which is represented as binary"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3181
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3182
    ^ Float radix
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3183
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3184
    "Created: / 12-06-2017 / 18:50:04 / cg"
5057
cc72e91af490 #OTHER by cg
Claus Gittinger <cg@exept.de>
parents: 4981
diff changeset
  3185
    "Modified (comment): / 19-07-2019 / 17:28:25 / Claus Gittinger"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3186
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3187
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3188
!QDouble methodsFor:'arithmetic'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3189
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3190
* aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3191
    "return the product of the receiver and the argument, aNumber"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3192
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3193
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3194
    if (__isFloatLike(aNumber)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3195
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3196
	double b = __floatVal(aNumber);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3197
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3198
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3199
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3200
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3201
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3202
	s_mul_qd(&c0, &c1, &c2, &c3, b, a[0], a[1], a[2], a[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3203
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3204
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3205
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3206
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3207
    if (__isQDouble(aNumber)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3208
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3209
	double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3210
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3211
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3212
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3213
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3214
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3215
	qd_mul_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3216
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3217
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3218
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3219
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3220
%}.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3221
    ^ aNumber productFromQDouble:self
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3222
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3223
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3224
     (QDouble fromFloat:1e20) * 2.0
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3225
     (QDouble fromFloat:1e20) * 1e20
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3226
     (QDouble fromFloat:1e20) * (QDouble fromFloat:1e20)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3227
     ((QDouble fromFloat:1e20) * (QDouble fromFloat:2.0)) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3228
     ((QDouble fromFloat:1e-20) * (QDouble fromFloat:2.0)) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3229
     ((QDouble fromFloat:2.0) * (QDouble fromFloat:2.0)) asDoubleArray
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
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3232
    "Created: / 12-06-2017 / 23:41:39 / cg"
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3233
    "Modified (comment): / 15-06-2017 / 00:34:41 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3234
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3235
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3236
+ aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3237
    "return the sum of the receiver and the argument, aNumber"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3238
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3239
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3240
    if (__isFloatLike(aNumber)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3241
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3242
	double b = __floatVal(aNumber);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3243
	double c0, c1, c2, c3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3244
	OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3245
	int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3246
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3247
	fpu_fix_start(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3248
	qd_add_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3249
	fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3250
	__qNew_qdReal(newQD, c0, c1, c2, c3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3251
	RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3252
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3253
    if (__isQDouble(aNumber)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3254
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3255
	double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3256
	double c0, c1, c2, c3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3257
	OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3258
	int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3259
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3260
	fpu_fix_start(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3261
	qd_add_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3262
	fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3263
	__qNew_qdReal(newQD, c0, c1, c2, c3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3264
	RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3265
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3266
%}.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3267
    ^ aNumber sumFromQDouble:self
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3268
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3269
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3270
     ((QDouble fromFloat:1e20) + 1.0) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3271
     ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3272
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3273
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3274
    "Created: / 12-06-2017 / 16:17:46 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3275
    "Modified: / 12-06-2017 / 23:06:22 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3276
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3277
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3278
- aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3279
    "return the sum of the receiver and the argument, aNumber"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3280
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3281
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3282
    if (__isFloatLike(aNumber)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3283
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3284
	double b = __floatVal(aNumber);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3285
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3286
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3287
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3288
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3289
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3290
	qd_add_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], -b);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3291
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3292
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3293
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3294
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3295
    if (__isQDouble(aNumber)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3296
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3297
	double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3298
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3299
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3300
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3301
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3302
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3303
	qd_sub_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3304
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3305
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3306
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3307
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3308
%}.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3309
    ^ self + (aNumber negated)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3310
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3311
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3312
     (QDouble fromFloat:1e20) - 1.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3313
     ((QDouble fromFloat:1e20) - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3314
     (QDouble fromFloat:1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3315
     ((QDouble fromFloat:1e-20) - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3316
     ((QDouble fromFloat:2.0) - (QDouble fromFloat:1.0)) asDoubleArray
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3317
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3318
     ((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
  3319
     ((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
  3320
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3321
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3322
    "Created: / 12-06-2017 / 23:41:39 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3323
    "Modified (comment): / 15-06-2017 / 00:34:41 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3324
!
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3325
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3326
/ aNumber
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3327
    "return the quotient of the receiver and the argument, aNumber"
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3328
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3329
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3330
    if (__isFloatLike(aNumber)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3331
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3332
	double b = __floatVal(aNumber);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3333
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3334
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3335
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3336
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3337
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3338
	qd_div_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3339
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3340
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3341
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3342
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3343
    if (__isQDouble(aNumber)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3344
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3345
	double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3346
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3347
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3348
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3349
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3350
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3351
	qd_div_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3352
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3353
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3354
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3355
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3356
%}.
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3357
    ^ aNumber quotientFromQDouble:self
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3358
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3359
    "
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3360
     ((QDouble fromFloat:1e20) / (QDouble fromFloat:2.0)) asDoubleArray
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3361
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3362
     ((QDouble fromFloat:1.2345) / (QDouble fromFloat:10.0)) asDoubleArray
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3363
     ((QDouble fromFloat:1.2345) / 10.0) asDoubleArray
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3364
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3365
    "
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3366
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3367
    "Created: / 13-06-2017 / 17:59:09 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  3368
    "Modified (comment): / 15-06-2017 / 00:14:26 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3369
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3370
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3371
!QDouble methodsFor:'coercing & converting'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3372
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3373
asDoubleArray
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3374
    ^ DoubleArray
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3375
	    with:self d0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3376
	    with:self d1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3377
	    with:self d2
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3378
	    with:self d3.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3379
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3380
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3381
     (QDouble fromFloat:1.0) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3382
     (1.0 asQDouble + 1e-40) asDoubleArray
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3383
     (QDouble fromFloat:2.0) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3384
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3385
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3386
    "Created: / 12-06-2017 / 18:19:19 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3387
    "Modified (comment): / 13-06-2017 / 17:58:09 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3388
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3389
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3390
asFloat
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3391
    ^ self d0 + self d1
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3392
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3393
    "
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3394
     (QDouble fromFloat:1.0) asFloat  -> 1.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3395
     (QDouble fromFloat:2.0) asFloat  -> 2.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3396
     (2.0 asQDouble + 1e-14) asFloat  -> 2.00000000000001
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3397
     (2.0 + 1e-14) - 2.0              -> 1.02140518265514E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3398
     (2.0 + 1e-15) - 2.0              -> 8.88178419700125E-16
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3399
     (2.0 + 1e-16) - 2.0              -> 0.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3400
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3401
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3402
    "Created: / 12-06-2017 / 18:15:27 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3403
    "Modified: / 13-06-2017 / 17:56:50 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3404
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3405
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3406
asInteger
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3407
    ^ self d0 asInteger
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3408
    + self d1 asInteger
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3409
    + self d2 asInteger
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3410
    + self d3 asInteger
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3411
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3412
    "Created: / 19-06-2017 / 18:07:17 / cg"
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3413
!
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3414
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3415
asLargeFloat
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3416
    ^ (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
  3417
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3418
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3419
     (QDouble fromFloat:1.0) asLargeFloat    -> 1.000000000000000000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3420
     (QDouble fromFloat:2.0) asLargeFloat    -> 2.000000000000000000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3421
     (2.0 asQDouble + 1e-14) asLargeFloat    -> 2.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3422
     (2.0 asLargeFloat + 1e-14) - 2.0        -> 0.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3423
     (2.0  + 1e-14) - 2.0                   -> 1.02140518265514E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3424
     (2.0 asLargeFloat + 1e-14) - 2.0       -> 0.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3425
     (2.0 asLargeFloat + 1e-15) - 2.0       -> 0.000000000000000888178419700125
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3426
     (2.0 asLargeFloat + 1e-16) - 2.0       -> 0.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3427
     (2QL + 1QL-14) - 2QL                   -> 0.000000000000010000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3428
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3429
!
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3430
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3431
asLongFloat
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3432
    ^ self d0 asLongFloat + self d1
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3433
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3434
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3435
     (QDouble fromFloat:1.0) asLongFloat    -> 1.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3436
     (QDouble fromFloat:2.0) asLongFloat    -> 2.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3437
     (2.0 asQDouble + 1e-14) asLongFloat    -> 2.00000000000001
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3438
     (2.0 asLongFloat + 1e-14) - 2.0        -> 1.00000303177028016E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3439
     (2.0  + 1e-14) - 2.0                   -> 1.02140518265514E-14
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3440
     (2.0 asLargeFloat + 1e-14) - 2.0       -> 0.000000000000010214051826551440
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3441
     (2.0 asLargeFloat + 1e-15) - 2.0       -> 0.000000000000000888178419700125
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3442
     (2.0 asLargeFloat + 1e-16) - 2.0       -> 0.0
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3443
     (2QL + 1QL-14) - 2QL                   -> 0.000000000000010000000000000000
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3444
    "
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3445
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3446
    "Created: / 12-06-2017 / 18:15:27 / cg"
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3447
    "Modified: / 13-06-2017 / 17:56:50 / cg"
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3448
!
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  3449
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3450
asQDouble
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3451
    "return a QDouble with same value as myself."
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3452
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3453
    ^ self
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3454
!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3455
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3456
asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3457
    ^ self d0 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3458
    + self d1 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3459
    + self d2 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3460
    + self d3 asTrueFraction
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3461
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3462
    "
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3463
     1e10 asTrueFraction        -> 10000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3464
     1e20 asTrueFraction        -> 100000000000000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3465
     (1e20 + 1) asTrueFraction  -> 100000000000000000000 ouch!!
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3466
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3467
     1e10 asQDouble asTrueFraction       -> 10000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3468
     1e20 asQDouble asTrueFraction       -> 100000000000000000000
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3469
     (1e20 asQDouble + 1) asTrueFraction -> 100000000000000000001
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3470
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3471
     (1e40 asQDouble + 1e20 + 1) asTrueFraction -> 10000000000000000303886028427003666890753
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3472
     (1e40 asQDouble + 1e20) asTrueFraction
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3473
    "
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3474
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3475
    "Created: / 20-06-2017 / 11:09:03 / cg"
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3476
!
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3477
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3478
coerce:aNumber
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3479
    "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
  3480
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3481
    ^ aNumber asQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3482
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3483
    "Created: / 12-06-2017 / 17:13:47 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3484
    "Modified: / 12-06-2017 / 21:09:06 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3485
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3486
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3487
exponent
5275
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3488
    "extract a normalized float's (unbiased) exponent.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3489
     The returned value depends on the float-representation of
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3490
     the underlying machine and is therefore highly unportable.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3491
     This is not for general use.
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3492
     This assumes that the mantissa is normalized to
e9d0b744512a #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5273
diff changeset
  3493
     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
  3494
4430
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3495
    ^ self d0 exponent
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3496
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3497
    "Created: / 20-06-2017 / 11:06:02 / cg"
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3498
!
2abefbc21260 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4427
diff changeset
  3499
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3500
generality
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3501
    "return the generality value - see ArithmeticValue>>retry:coercing:"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3502
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3503
    ^ 95
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3504
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3505
    "Created: / 12-06-2017 / 17:13:14 / cg"
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3506
!
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3507
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3508
mantissa
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3509
    "extract a normalized float's mantissa.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3510
     The returned value depends on the float-representation of
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3511
     the underlying machine and is therefore highly unportable.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3512
     This is not for general use.
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3513
     This assumes that the mantissa is normalized to
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3514
     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
  3515
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3516
    "/ fake it here
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3517
    ^ self / (2 raisedTo:self exponent)
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3518
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3519
    "
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3520
     1.0 exponent        -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3521
     1.0 mantissa        -> 0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3522
     12345.0 exponent    -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3523
     12345.0 mantissa    -> 0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3524
     -1.0 exponent       -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3525
     -1.0 mantissa       -> -0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3526
     -12345.0 exponent   -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3527
     -12345.0 mantissa   -> -0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3528
     (1e40 + 1e-40) exponent   -> 133
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3529
     (1e40 + 1e-40) mantissa   -> 0.918354961579912
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3530
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3531
     1.0 asQDouble exponent        -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3532
     1.0 asQDouble mantissa        -> 0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3533
     12345.0 asQDouble exponent    -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3534
     12345.0 asQDouble mantissa    -> 0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3535
     -1.0 asQDouble exponent       -> 1
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3536
     -1.0 asQDouble mantissa       -> -0.5
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3537
     -12345.0 asQDouble exponent   -> 14
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3538
     -12345.0 asQDouble mantissa   -> -0.75347900390625
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3539
     (1e40 + 1e-40) asQDouble exponent   -> 133
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3540
     (1e40 + 1e-40) asQDouble mantissa   -> 0.918354961579912
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3541
    "
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3542
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  3543
    "Created: / 20-06-2017 / 11:06:02 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3544
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3545
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3546
!QDouble methodsFor:'comparing'!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3547
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3548
< aNumber
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3549
    "return true, if the argument, aNumber is greater than the receiver"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3550
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3551
    ^ aNumber lessFromQDouble:self
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3552
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3553
    "Created: / 13-06-2017 / 16:58:53 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3554
!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3555
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3556
= aNumber
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3557
    "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
  3558
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3559
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3560
    if (__isSmallInteger(aNumber)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3561
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3562
	double b = (double)(__intVal(aNumber));
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3563
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3564
	RETURN ((a[0] == b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3565
		&& a[1] == 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3566
		&& a[2] == 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3567
		&& a[3] == 0.0) ? true : false);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3568
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3569
    if (aNumber == nil) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3570
	RETURN(false);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3571
    }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3572
    if (__qClass(aNumber) == QDouble) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3573
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3574
	double *b = __QDoubleInstPtr(aNumber)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3575
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3576
	RETURN ((a[0] == b[0]
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3577
		&& a[1] == b[1]
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3578
		&& a[2] == b[2]
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3579
		&& a[3] == b[3]) ? true : false);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3580
    }
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3581
    if (__qClass(aNumber) == Float) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3582
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3583
	double b = __floatVal(aNumber);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3584
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3585
	RETURN ((a[0] == b
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3586
		&& a[1] == 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3587
		&& a[2] == 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3588
		&& a[3] == 0.0) ? true : false);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3589
    }
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3590
%}.
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3591
    ^ aNumber equalFromQDouble:self
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3592
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3593
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3594
     1.0 asQDouble = 1.0 asQDouble
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3595
     1.0 asQDouble = 1.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3596
     1.0 asQDouble = 1
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3597
     1.0 asQDouble = 2
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3598
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  3599
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3600
    "Created: / 13-06-2017 / 17:12:09 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3601
! !
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3602
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3603
!QDouble methodsFor:'double dispatching'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3604
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3605
differenceFromFloat:aFloat
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3606
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3607
    if (__isFloatLike(aFloat)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3608
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3609
	double b = __floatVal(aFloat);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3610
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3611
	double e;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3612
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3613
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3614
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3615
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3616
	s_sub_qd(&c0, &c1, &c2, &c3, b, a[0], a[1], a[2], a[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3617
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3618
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3619
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3620
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3621
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3622
    ^ super differenceFromFloat:aFloat.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3623
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3624
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3625
     1.0 - (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3626
     1e20 - (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3627
     (1.0 - (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3628
     (1e20 - (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3629
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3630
     (1.0 - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3631
     (1e20 - (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3632
     (1e20 - (QDouble fromFloat:1.0) + 1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3633
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3634
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3635
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3636
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3637
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3638
differenceFromQDouble:aQDouble
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3639
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3640
    if (__isQDouble(aQDouble)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3641
	double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3642
	double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3643
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3644
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3645
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3646
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3647
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3648
	qd_sub_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3649
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3650
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3651
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3652
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3653
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3654
    ^ super differenceFromQDouble:aQDouble
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3655
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3656
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3657
     (QDouble fromFloat:1.0) - (QDouble fromFloat:1.0)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3658
     (QDouble fromFloat:1.0) - 1.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3659
     1.0 - (QDouble fromFloat:1.0)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3660
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3661
     ((QDouble fromFloat:1.0) - (QDouble fromFloat:1.0)) asDoubleArray
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3662
     ((QDouble fromFloat:1.0) - 1.0) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3663
     (1.0 - (QDouble fromFloat:1.0)) asDoubleArray
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3664
     (1e-20 - (QDouble fromFloat:1.0)) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3665
     (1e20 - (QDouble fromFloat:1.0)) asDoubleArray
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3666
   "
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3667
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3668
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3669
equalFromQDouble:aQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3670
%{
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3671
    if (__Class(aQDouble) == QDouble) {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3672
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3673
	double *b = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3674
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3675
	RETURN ((a[0] == b[0]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3676
		&& a[1] == b[1]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3677
		&& a[2] == b[2]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3678
		&& a[3] == b[3]) ? true : false);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3679
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3680
%}.
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3681
    ^ (aQDouble d0 = self d0)
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3682
    and:[ (aQDouble d1 = self d1)
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3683
    and:[ (aQDouble d2 = self d2)
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3684
    and:[ (aQDouble d3 = self d3) ]]]
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3685
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3686
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3687
     (QDouble fromFloat:1.0) = (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3688
     (QDouble fromFloat:1.0) = 1.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3689
     1.0 = (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3690
   "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3691
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3692
    "Created: / 13-06-2017 / 03:01:19 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  3693
    "Modified: / 13-06-2017 / 18:01:52 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3694
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3695
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3696
lessFromQDouble:aQDouble
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3697
    "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
  3698
     Return true if aQDouble < self"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3699
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3700
%{
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3701
    if (__Class(aQDouble) == QDouble) {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3702
	double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3703
	double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3704
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3705
	// now compare if a < b!
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3706
	RETURN
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3707
	    ((a[0] < b[0] ||
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3708
	      (a[0] == b[0] && (a[1] < b[1] ||
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3709
		(a[1] == b[1] && (a[2] < b[2] ||
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3710
		  (a[2] == b[2] && a[3] < b[3])))))) ? true : false);
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3711
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3712
%}.
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3713
    ^ super lessFromQDouble:aQDouble
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3714
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3715
    "
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3716
     (1.0 + 1e-40) > 1.0
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3717
     ((QDouble fromFloat:1.0) + (QDouble fromFloat:1e-40)) > (QDouble fromFloat:1.0)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3718
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3719
     (QDouble fromFloat:1.0) > (QDouble fromFloat:1.0)
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3720
     (QDouble fromFloat:1.1) > (QDouble fromFloat:1.0)
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3721
     (QDouble fromFloat:1.0) > 1.0
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3722
     (QDouble fromFloat:1.1) > 1.0
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3723
     1.0 > (QDouble fromFloat:1.0)
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3724
   "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3725
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3726
    "Created: / 13-06-2017 / 17:07:47 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3727
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3728
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3729
productFromFloat:aFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3730
%{
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3731
    if (__isFloatLike(aFloat)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3732
	double a  = __floatVal(aFloat);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3733
	double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3734
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3735
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3736
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3737
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3738
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3739
	s_mul_qd(&c0, &c1, &c2, &c3, a, b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3740
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3741
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3742
	RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3743
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3744
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3745
    ^ super productFromFloat:aFloat.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3746
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3747
    "
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3748
     loosing bits here:
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3749
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3750
     (1e20+1.0)*2.0    - 2E20  -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3751
     (1e20+1.0)*100.0  - 1E+22 -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3752
     (1e20+1.0)*1000.0 - 1E+23 -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3753
     (1e20+1.0)*1e20   - 1E+40 -> 0.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3754
     (1e40+1.0)*2.0    - 2E+40 -> 0.0
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3755
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3756
     but not here:
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3757
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3758
     ((1e20 asQDouble) + (1.0)) * 2.0    - 2E20  -> 2.0
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3759
     ((1e20 asQDouble) + (1.0)) * 100.0  - 1E+22 -> 100.0
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3760
     ((1e20 asQDouble) + (1.0)) * 1000.0 - 1E+23 -> 8389608.0  WRONG
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3761
     ((1e20 asQDouble) + (1.0)) * 1e20   - 1E+40 ->
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3762
     ((1e40 asQDouble) + (1.0)) * 2.0    - 2E+40 ->
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3763
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3764
     2.0 * (QDouble fromFloat:1.0)
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3765
     2.0 * (QDouble fromFloat:3.0)
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3766
     (QDouble fromFloat:2.0) * (QDouble fromFloat:3.0)
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3767
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3768
     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
  3769
     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
  3770
     QDouble ln2 * 2.0
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3771
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3772
     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
  3773
     ((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
  3774
     ((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
  3775
     (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
  3776
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3777
     (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
  3778
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3779
     (2.0 * (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3780
     (1e20 * (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3781
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3782
     (1e20 * (QDouble fromFloat:1.0) * 1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3783
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3784
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3785
    "Created: / 13-06-2017 / 00:58:56 / cg"
4421
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3786
    "Modified: / 19-06-2017 / 16:48:18 / cg"
2603ea13cb5c #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4420
diff changeset
  3787
    "Modified (comment): / 19-06-2017 / 18:11:43 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3788
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3789
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3790
productFromQDouble:aQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3791
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3792
    if (__isQDouble(aQDouble)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3793
	double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3794
	double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3795
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3796
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3797
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3798
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3799
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3800
	qd_mul_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3801
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3802
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3803
	RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3804
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3805
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3806
    ^ super productFromQDouble:aQDouble.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3807
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3808
    "
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3809
     (QDouble fromFloat:1.0) * 2.0
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3810
     2.0 * (QDouble fromFloat:1.0)
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3811
     (QDouble fromFloat:1.0) * (QDouble fromFloat:2.0)
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3812
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3813
     1e20 * (QDouble fromFloat:2.0)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3814
     2.0 * (QDouble fromFloat:1e20)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3815
     (QDouble fromFloat:1e20) * (QDouble fromFloat:1e20)
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3816
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3817
     (1e20 * (QDouble fromFloat:1.0) * 1e-20) asDoubleArray
4392
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3818
a64fe2606d82 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4391
diff changeset
  3819
     ( ((QDouble fromFloat:1.0) + (QDouble fromFloat:1e20)) * (QDouble fromFloat:2.0)) asDoubleArray
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3820
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3821
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3822
    "Created: / 13-06-2017 / 01:06:22 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3823
    "Modified: / 05-07-2017 / 11:07:16 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3824
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3825
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3826
quotientFromFloat:aFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3827
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3828
    if (__isFloatLike(aFloat)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3829
	double a  = __floatVal(aFloat);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3830
	double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3831
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3832
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3833
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3834
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3835
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3836
	s_div_qd(&c0, &c1, &c2, &c3, a, b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3837
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3838
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3839
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3840
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3841
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3842
    ^ super quotientFromFloat:aFloat.
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3843
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3844
    "
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3845
     2.0 / (QDouble fromFloat:2.0)
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3846
     2.0 / (QDouble fromFloat:1.0)
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  3847
     1e20 / (QDouble fromFloat:1.0)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3848
     1e20 / (QDouble fromFloat:2.0)
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3849
     (2.0 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3850
     (1e20 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3851
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3852
     (QDouble fromFloat:2.0) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3853
     (QDouble fromFloat:1e20) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3854
     ((QDouble fromFloat:1.0) / 2.0) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3855
     ((QDouble fromFloat:1e20 / 2.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3856
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3857
     ((1e20 + (QDouble fromFloat:1.0) + 1e-20) / 2.0) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3858
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3859
     ((QDouble fromFloat:10.0) quotientFromQDouble: (QDouble fromFloat:1.234)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3860
     ((QDouble fromFloat:1.234) / (QDouble fromFloat:10.0)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3861
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3862
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3863
    "Created: / 13-06-2017 / 17:50:35 / cg"
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3864
    "Modified (comment): / 15-06-2017 / 01:02:05 / cg"
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3865
!
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3866
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3867
quotientFromQDouble:aQDouble
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3868
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3869
    if (__isQDouble(aQDouble)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3870
	double *a = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3871
	double *b = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3872
	double c0, c1, c2, c3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3873
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3874
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3875
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3876
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3877
	qd_div_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3878
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3879
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  3880
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3881
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3882
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3883
    ^ super quotientFromQDouble:aQDouble.
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3884
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3885
    "
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3886
     2.0 / (QDouble fromFloat:2.0)
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3887
     2.0 / (QDouble fromFloat:1.0)
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3888
     1e20 / (QDouble fromFloat:1.0)
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3889
     1e20 / (QDouble fromFloat:2.0)
5304
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3890
     (2.0 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3891
     (1e20 / (QDouble fromFloat:1.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3892
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3893
     (QDouble fromFloat:2.0) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3894
     (QDouble fromFloat:1e20) / 2.0
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3895
     ((QDouble fromFloat:1.0) / 2.0) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3896
     ((QDouble fromFloat:1e20 / 2.0)) asFloat
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3897
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3898
     ((1e20 + (QDouble fromFloat:1.0) + 1e-20) / 2.0) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3899
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3900
     ((QDouble fromFloat:10.0) quotientFromQDouble: (QDouble fromFloat:1.234)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3901
     ((QDouble fromFloat:1.234) / (QDouble fromFloat:10.0)) asDoubleArray
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3902
    "
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3903
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3904
    "Created: / 13-06-2017 / 17:50:35 / cg"
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3905
    "Modified (comment): / 15-06-2017 / 01:02:05 / cg"
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3906
!
f61106094adc #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5288
diff changeset
  3907
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3908
sumFromFloat:aFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3909
%{
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3910
    if (__isFloatLike(aFloat)) {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3911
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3912
	double b = __floatVal(aFloat);
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3913
	double c0, c1, c2, c3;
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3914
	double e;
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3915
	OBJ newQD;
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3916
	int savedCV;
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3917
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3918
	fpu_fix_start(&savedCV);
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3919
	qd_add_s(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b);
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3920
	fpu_fix_end(&savedCV);
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3921
	__qNew_qdReal(newQD, c0, c1, c2, c3);
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3922
	RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3923
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3924
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3925
    ^ super sumFromFloat:aFloat.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3926
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3927
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3928
     1.0 + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3929
     1e20 + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3930
     (1.0 + (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3931
     (1e20 + (QDouble fromFloat:1.0)) asFloat
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3932
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3933
     (1.0 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3934
     (1e20 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3935
     (1e20 + (QDouble fromFloat:1.0) + 1e-20) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3936
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3937
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3938
    "Created: / 12-06-2017 / 17:16:41 / cg"
4387
879309cae427 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4386
diff changeset
  3939
    "Modified: / 14-06-2017 / 11:43:47 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3940
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3941
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3942
sumFromInteger:anInteger
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3943
    ^ self sumFromFloat:(anInteger asFloat)
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3944
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3945
    "
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3946
     1 + (QDouble fromFloat:1.0)
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3947
     1e20 asInteger + (QDouble fromFloat:1.0)
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3948
     (1 + (QDouble fromFloat:1.0)) asFloat
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3949
     (1e20 asInteger + (QDouble fromFloat:1.0)) asFloat
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3950
    "
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3951
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3952
    "Created: / 03-07-2017 / 10:35:46 / cg"
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3953
!
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3954
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3955
sumFromQDouble:aQDouble
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3956
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3957
    if (__isQDouble(aQDouble)) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3958
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3959
	double *b = __QDoubleInstPtr(aQDouble)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3960
	double c0, c1, c2, c3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3961
	OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3962
	int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3963
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3964
	fpu_fix_start(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3965
	qd_add_qd(&c0, &c1, &c2, &c3, a[0], a[1], a[2], a[3], b[0], b[1], b[2], b[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3966
	fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3967
	__qNew_qdReal(newQD, c0, c1, c2, c3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  3968
	RETURN( newQD );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3969
    }
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3970
%}.
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3971
    ^ super sumFromQDouble:aQDouble
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  3972
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3973
    "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3974
     (QDouble fromFloat:1.0) + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3975
     (QDouble fromFloat:1.0) + 1.0
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3976
     1.0 + (QDouble fromFloat:1.0)
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3977
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3978
     ((QDouble fromFloat:1.0) + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3979
     ((QDouble fromFloat:1.0) + 1.0) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3980
     (1.0 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3981
     (1e-20 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3982
     (1e20 + (QDouble fromFloat:1.0)) asDoubleArray
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3983
   "
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3984
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3985
    "Created: / 12-06-2017 / 21:15:43 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  3986
    "Modified: / 03-07-2017 / 23:09:11 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3987
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3988
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3989
!QDouble methodsFor:'inspecting'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3990
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3991
inspectorExtraAttributes
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3992
    "extra (pseudo instvar) entries to be shown in an inspector."
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3993
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3994
    ^ super inspectorExtraAttributes
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3995
	add:'-{doubles}' -> [ self asDoubleArray printString ];
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  3996
	yourself
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3997
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  3998
    "Created: / 12-06-2017 / 23:43:05 / cg"
4478
010c2cd47df3 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4454
diff changeset
  3999
    "Modified (format): / 18-07-2017 / 19:54:48 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4000
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4001
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4002
!QDouble methodsFor:'mathematical functions'!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4003
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4004
cos
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4005
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4006
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4007
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4008
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4009
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4010
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4011
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4012
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4013
    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
  4014
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4015
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4016
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4017
%}.
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4018
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  4019
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4020
     1.0 cos
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4021
     (QDouble fromFloat:1.0) cos
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4022
    "
4440
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  4023
!
590547e4049d #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4439
diff changeset
  4024
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4025
exp
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4026
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4027
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4028
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4029
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4030
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4031
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4032
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4033
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4034
    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
  4035
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4036
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4037
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4038
%}.
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4039
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4040
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4041
     1.0 exp
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4042
     (QDouble fromFloat:1.0) exp
5313
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4043
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4044
     3.0 exp
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4045
     (QDouble fromFloat:3.0) exp
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4046
    "
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4047
!
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4048
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4049
ldexp:exp
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4050
    "multiply the receiver by an integral power of 2.
5288
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  4051
     I.e. return self * (2 ^ exp).
cd5e44b99011 #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5275
diff changeset
  4052
     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
  4053
     mantissa and exponent: (f mantissa ldexp:f exponent) = f"
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4054
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4055
    ^ self class
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4056
	d0:(self d0 ldexp:exp)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4057
	d1:(self d1 ldexp:exp)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4058
	d2:(self d2 ldexp:exp)
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4059
	d3:(self d3 ldexp:exp)
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4060
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4061
     |f| f := 1 asQDouble. (f mantissa ldexp:f exponent) -> 1.0
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4062
     |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
  4063
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4064
     1.0 ldexp:16            -> 65536.0
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4065
     1.0 asQDouble ldexp:16  -> 65536.0
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4066
     1.0 ldexp:100           -> 1.26765060022823E+30
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4067
     1.0 asQDouble ldexp:100 -> 1.26765060022823E+30
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4068
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4069
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4070
    "Created: / 19-06-2017 / 01:43:35 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4071
!
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4072
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4073
ln
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4074
    "return the natural logarithm of myself.
4445
5267aa3922e4 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4444
diff changeset
  4075
     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
  4076
5267aa3922e4 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4444
diff changeset
  4077
     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
  4078
     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
  4079
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4080
    |d0 x|
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4081
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4082
    "/ ^ super ln.
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4083
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4084
    d0 := self d0.
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4085
    d0 = 1.0 ifTrue:[
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4086
	"/ note: d0 checking alone is not sufficient - there could still be more in d1...
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4087
	self isOne ifTrue:[ ^ self class zero ].
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4088
    ].
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4089
    d0 > 0.0 ifTrue:[
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4090
	"/ initial approx.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4091
	x := d0 ln asQDouble.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4092
	"/ three more iterations of newton...
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4093
	x := x + (self * (x negated exp)) - 1.0.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4094
	x := x + (self * (x negated exp)) - 1.0.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4095
	x := x + (self * (x negated exp)) - 1.0.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4096
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4097
	^ x
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4098
    ].
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4099
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4100
    "/ now done via trapInfinity; was:
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4101
    "/ d0 = 0.0 ifTrue:[
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4102
    "/     ^ Infinity negative
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4103
    "/ ].
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4104
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4105
    "/ if you need -INF for a zero receiver, try Number trapInfinity:[...]
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4106
    ^ self class
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4107
	raise:(self = 0 ifTrue:[#infiniteResultSignal] ifFalse:[#domainErrorSignal])
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4108
	receiver:self
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4109
	selector:#ln
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4110
	arguments:#()
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4111
	errorString:'bad receiver in ln (not strictly positive)'
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4112
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4113
    "
4412
ad38e01db51a #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4411
diff changeset
  4114
     -1 ln
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4115
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4116
     -1.0 asQDouble ln
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4117
     0.0 asQDouble ln
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4118
     1.0 asQDouble ln
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4119
     0.5 ln
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4120
     0.5 asQDouble ln
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4121
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4122
     3.0 ln printfPrintString:'%60.58lf'
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4123
	    -> 1.0986122886681097821082175869378261268138885498046875000000'
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4124
				^
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4125
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4126
     3.0 asQDouble ln printfPrintString:'%60.58f'
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4127
	    -> 1.0986122886681096913952452369225257046474905578227494517347
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4128
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4129
     3.0 asQDouble ln printfPrintString:'%70.68f'
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4130
	    -> 1.09861228866810969139524523692252570464749055782274945173469433364779
4443
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  4131
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  4132
     (3.0 asQDouble ln_withAccuracy:1e-64) printfPrintString:'%70.68f'
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4133
	       1.09861228866810969139524523692252570464749055782274945173469433364475
4443
1a8440a32671 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4442
diff changeset
  4134
     (3.0 asQDouble ln_withAccuracy:1e-100) printfPrintString:'%70.68f'
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4135
	      '1.098612288668109691395245236922525704647490557822749451734694333656909'
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4136
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4137
     actual result:
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4138
	    -> 1.0986122886681096913952452369225257046474905578227494517346943336374942932186089668736157548137320887879700290659...
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4139
    "
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4140
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4141
    "Created: / 18-06-2017 / 23:32:54 / cg"
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4142
    "Modified: / 04-07-2017 / 11:46:27 / cg"
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4143
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4144
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4145
negated
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4146
    ^ self class
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4147
	d0:(self d0) negated
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4148
	d1:(self d1) negated
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4149
	d2:(self d2) negated
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4150
	d3:(self d3) negated
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4151
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4152
    "
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4153
     (QDouble fromFloat:1.0) negated
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4154
     ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0)) negated asDoubleArray
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4155
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4156
     (((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0))
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4157
     + ((QDouble fromFloat:1e20) + (QDouble fromFloat:1.0))) asDoubleArray
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4158
    "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4159
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4160
    "Created: / 12-06-2017 / 20:14:55 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4161
    "Modified (comment): / 12-06-2017 / 23:46:57 / cg"
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4162
!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4163
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4164
raisedToInteger:n
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4165
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4166
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4167
    if (__isSmallInteger(n)) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4168
	double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4169
	double q0, q1, q2, q3;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4170
	OBJ newQD;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4171
	int savedCV;
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4172
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4173
	fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4174
	qd_pow(&q0, &q1, &q2, &q3, a[0], a[1], a[2], a[3], __intVal(n));
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4175
	fpu_fix_end(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4176
	__qNew_qdReal(newQD, q0, q1, q2, q3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4177
	RETURN( newQD );
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4178
    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4179
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4180
    ^ super raisedToInteger:n.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4181
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4182
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4183
     (QDouble fromFloat:4.0) raisedToInteger:4
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4184
     (QDouble fromFloat:10.0) raisedToInteger:10
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4185
     (QDouble fromFloat:10.0000000000001) raisedToInteger:10
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4186
     10.0000000000001 raisedToInteger:10
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4187
    "
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4188
!
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4189
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4190
sin
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4191
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4192
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4193
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4194
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4195
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4196
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4197
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4198
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4199
    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
  4200
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4201
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4202
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4203
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4204
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4205
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4206
     1.0 sin
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4207
     (QDouble fromFloat:1.0) sin
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4208
    "
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4209
!
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4210
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4211
sqrt
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4212
    "Return the square root of the receiver"
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4213
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4214
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4215
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4216
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4217
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4218
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4219
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4220
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4221
    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
  4222
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4223
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4224
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4225
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4226
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4227
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4228
     (QDouble fromFloat:4.0) sqrt
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4229
     (QDouble fromFloat:2.0) sqrt
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4230
     (QDouble fromFloat:1e20) sqrt
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4231
    "
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4232
!
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4233
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4234
squared
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4235
    "return receiver * receiver"
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4236
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4237
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4238
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4239
    double q0, q1, q2, q3;
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4240
    OBJ newQD;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4241
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4242
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4243
    fpu_fix_start(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4244
    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
  4245
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4246
    __qNew_qdReal(newQD, q0, q1, q2, q3);
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4247
    RETURN( newQD );
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4248
%}.
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4249
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4250
    "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4251
     (QDouble fromFloat:4.0) squared
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4252
     (1e20 + (QDouble fromFloat:1.0)) squared
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4253
    "
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4254
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4255
    "Created: / 13-06-2017 / 01:27:58 / cg"
4442
ef3082dc3d1c #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4440
diff changeset
  4256
    "Modified: / 22-06-2017 / 14:08:31 / cg"
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4257
!
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4258
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4259
tan
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4260
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4261
%{
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4262
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4263
    double q0, q1, q2, q3;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4264
    OBJ newQD;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4265
    int savedCV;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4266
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4267
    fpu_fix_start(&savedCV);
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4268
    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
  4269
    fpu_fix_end(&savedCV);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4270
    __qNew_qdReal(newQD, q0, q1, q2, q3);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4271
    RETURN( newQD );
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4272
%}.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4273
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4274
    "
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4275
     1.0 tan
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4276
     (QDouble fromFloat:1.0) tan
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4277
    "
4385
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
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4280
!QDouble methodsFor:'printing & storing'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4281
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4282
digitsWithPrecision:precision
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4283
    <resource: #obsolete>
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4284
    "generate digits and exponent.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4285
     if precision is >0, that many digits are generated.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4286
     If it is 0 the required number of digits is generated
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4287
     (but never more than the decimalPrecision, which is 65)"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4288
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4289
    |numDigits r exp i d out str|
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4290
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4291
    numDigits := precision+1. "/ number of digits
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4292
    r := self abs.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4293
    self d0 = 0.0 ifTrue:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4294
	^ { String new:(precision max:1) withAll:$0 . 0 }
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4295
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4296
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4297
    out := WriteStream on:(String new:precision+5).
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4298
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4299
    "/ determine approx. exponent
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4300
    exp := self d0 abs log10 floor.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4301
    exp < -300 ifTrue:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4302
	"/ 1e-305 asQDouble
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4303
	r := r * (10.0 raisedToInteger:300).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4304
	r := r / (10.0 raisedToInteger:(exp+300)).
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4305
    ] ifFalse:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4306
	exp > 300 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4307
	    "/ 1e305 asQDouble
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4308
	    "/ lexpr(x,exp) = x * 2 ^ exp
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4309
self halt.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4310
	    r := r * (2 raisedTo:-53).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4311
	    r := r / (10.0 asQDouble raisedTo: exp).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4312
	    r := r * (2 raisedTo:53).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4313
	] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4314
	    r := r / (10.0 asQDouble raisedTo:exp).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4315
	]
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4316
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4317
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4318
    "/ Fix exponent if we are off by one
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4319
    (r >= 10.0) ifTrue:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4320
	r := r / 10.0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4321
	exp := exp + 1.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4322
    ] ifFalse:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4323
	(r < 1.0) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4324
	    r := r * 10.0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4325
	    exp := exp - 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4326
	]
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4327
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4328
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4329
    ((r >= 10.0) or:[ r < 1.0 ]) ifTrue:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4330
	self error:'can''t compute exponent.'.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4331
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4332
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4333
    "/
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4334
    "/ Extract the digits
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4335
    "/ notice, that the d1,d2 and d3 components might
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4336
    "/ be negative; therefore characters out of the 0..9 range
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4337
    "/ might be produced here
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4338
    "/
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4339
    i := 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4340
    [ (precision ~~ 0 and:[ i <= numDigits ])
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4341
    or:[ (precision == 0 and:[r d0 ~= 0.0])  ]] whileTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4342
	d := r d0 truncated.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4343
	r := r - d.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4344
	r := r * 10.0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4345
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4346
	out nextPut:($0 + d).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4347
	i := i + 1.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4348
    ].
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4349
    numDigits := i-1.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4350
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4351
    str := out contents.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4352
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4353
    "/ Fix out-of-range digits.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4354
    numDigits to:2 by:-1 do:[:i |
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4355
	(str at:i) < $0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4356
	    str at:i-1 put:(str at:i-1) - 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4357
	    str at:i put:(str at:i) + 10.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4358
	] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4359
	    (str at:i) > $9 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4360
		str at:i-1 put:(str at:i-1) + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4361
		str at:i put:(str at:i) - 10.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4362
	    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4363
	].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4364
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4365
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4366
    str first <= $0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4367
	self error:'non-positive leading digit'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4368
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4369
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4370
    "/ Round, handle carry
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4371
    (str at:numDigits) >= $5 ifTrue:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4372
	str at:numDigits-1 put:(str at:numDigits-1) + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4373
	i := numDigits-1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4374
	[i > 1 and:[(str at:i) > $9]] whileTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4375
	    str at:i put:(str at:i) - 10.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4376
	    i := i - 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4377
	    str at:i put:(str at:i) + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4378
	]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4379
    ].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4380
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4381
    "/ If first digit is 10, shift everything.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4382
    str first > $9 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4383
	exp := exp + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4384
	str at:1 put:$0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4385
	str := '1',str
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4386
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4387
    ^ { (str copyTo:numDigits-1) . exp }
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4388
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4389
    "
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4390
     0 asQDouble digitsWithPrecision:1      -> #('0' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4391
     0 asQDouble digitsWithPrecision:0      -> #('0' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4392
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4393
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4394
     1.2345 printfPrintString:'%.4f'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4395
     1.2345 asQDouble digitsWithPrecision:5 -> #('12345' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4396
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4397
     --- but 1.2345 is not really what you think:
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4398
     1.2345 printfPrintString:'%.20f'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4399
     1.2345 asQDouble digitsWithPrecision:20 -> #('12344999999999999307' 0)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4400
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4401
     12.345 asQDouble digitsWithPrecision:5 -> #('12345' 1)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4402
     12345 asQDouble digitsWithPrecision:5 -> #('12345' 4)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4403
     12345.1 asQDouble digitsWithPrecision:5 -> #('12345' 4)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4404
     12345.9 asQDouble digitsWithPrecision:5 -> #('12346' 4)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4405
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4406
     1.2345 asQDouble / 10.0 asQDouble
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4407
     1.2345 asQDouble / 10.0
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4408
    "
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4409
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4410
    "Created: / 15-06-2017 / 09:10:01 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4411
    "Modified: / 16-06-2017 / 10:01:03 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4412
!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4413
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4414
printOn:aStream
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4415
    "return a printed representation of the receiver.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4416
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4417
     Notice:
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4418
	this code was adapted from an ugly piece of c++ code,
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4419
	which was obviously hacked.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4420
	It does need a rework.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4421
	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
  4422
5313
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4423
"/    self d1 = 0.0 ifTrue:[
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4424
"/        self d0 printOn:aStream.
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4425
"/        ^ self
f2daab855dad #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5312
diff changeset
  4426
"/    ].
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4427
    thisContext isRecursive ifTrue:[
5314
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4428
	aStream nextPutAll:'aQDouble (error while printing)'.
1ac391a7075b fix typo
Stefan Vogel <sv@exept.de>
parents: 5313
diff changeset
  4429
	^ self.
4978
99f7c90223f2 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4963
diff changeset
  4430
    ].
4981
952fad400b5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4978
diff changeset
  4431
4438
e5665b676a65 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4437
diff changeset
  4432
    PrintfScanf printf:'%g' on:aStream argument:self.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4433
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4434
"/    self
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4435
"/        printOn:aStream precision:40 width:0
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4436
"/        fixed:true showPositive:false uppercase:false fillChar:(Character space)
4393
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
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4439
     (1.2345 asQDouble) printString
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4440
     (2 asQDouble squared) printString
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4441
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4442
     (1.2345 asQDouble) printString.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4443
     (1.2345 asFloat) printString.
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4444
     (1.2345 asLongFloat) printString.
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4445
     (1.2345 asShortFloat) printString.
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4446
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4447
     ((QDouble fromFloat:1.2345) / 10.0) printString
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4448
     ((QDouble fromFloat:1.2345) / 10000.0) printString
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4449
     ((QDouble fromFloat:1.2345) / 1000000000.0) printString -> '0.0000123449999999999987156270014193593714e-4'
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4450
     (1.2345 / 1000000000.0) printString                     -> '1.2345E-09'
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
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4453
    "Created: / 15-06-2017 / 01:51:36 / cg"
4439
4c6520416d7d #UI_ENHANCEMENT by cg
Claus Gittinger <cg@exept.de>
parents: 4438
diff changeset
  4454
    "Modified (comment): / 21-06-2017 / 09:55:10 / cg"
4978
99f7c90223f2 #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 4963
diff changeset
  4455
    "Modified: / 05-06-2019 / 20:38:58 / Claus Gittinger"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4456
!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4457
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4458
printOn:aStream precision:precisionIn width:width
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4459
    fixed:fixed showPositive:showPositive uppercase:uppercase fillChar:fillChar
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4460
    <resource: #obsolete>
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4461
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4462
    "return a printed representation of the receiver.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4463
     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
  4464
     Notice:
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4465
	this code was adapted from an ugly piece of c++ code,
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4466
	which was obviously hacked.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4467
	It does need a rework.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4468
	As an alternative, use the printf functions, which should also deal wth QDoubles
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4469
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4470
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4471
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4472
     1.2345 asQDouble printString
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4473
     12.345 asQDouble printString
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4474
     12345 asQDouble printString
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4475
    "
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4476
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4477
    |sgn count delta exp precision|
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4478
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4479
"/    self d1 = 0.0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4480
"/        self d0 printOn:aStream.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4481
"/        ^ self.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4482
"/    ].
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4483
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4484
    count := 0.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4485
    sgn := true.
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4486
    exp := 0.
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4487
    precision := precisionIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4488
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4489
    self isInfinite ifTrue:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4490
	self < 0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4491
	    aStream nextPut:$-.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4492
	    count := 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4493
	] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4494
	    showPositive ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4495
		aStream nextPut:$+.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4496
		count := 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4497
	    ] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4498
		sgn := false.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4499
	    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4500
	].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4501
	uppercase ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4502
	    aStream nextPutAll:'INF'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4503
	] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4504
	    aStream nextPutAll:'inf'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4505
	].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4506
	count := count + 3.
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4507
    ] ifFalse:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4508
	self isNaN ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4509
	    uppercase ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4510
		aStream nextPutAll:'NAN'
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4511
	    ] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4512
		aStream nextPutAll:'nan'
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
	    count := count + 3.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4515
	] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4516
	    self < 0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4517
		aStream nextPut:$-.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4518
		count := count + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4519
	    ] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4520
		showPositive ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4521
		    aStream nextPut:$+.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4522
		    count := count + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4523
		] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4524
		    sgn := false.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4525
		].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4526
	    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4527
	    self = 0.0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4528
		aStream nextPut:$0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4529
		count := count + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4530
		precision > 0 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4531
		    aStream nextPut:$..
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4532
		    count := count + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4533
		    precision timesRepeat:[ aStream nextPut:$0 ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4534
		    count := count + precision.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4535
		].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4536
		self halt.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4537
	    ] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4538
		|off d d_width_extra|
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4539
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4540
		"/ non-zero case
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4541
		off := fixed
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4542
			ifTrue:[ 1 + self asFloat abs log10 floor asInteger ]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4543
			ifFalse:[1].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4544
		d := precision + off.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4545
		d_width_extra := d.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4546
		fixed ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4547
		    d_width_extra := 40 max:d.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4548
		].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4549
		"/ highly special case - fixed mode, precision is zero, abs(*this) < 1.0
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4550
		"/ without this trap a number like 0.9 printed fixed with 0 precision prints as 0
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4551
		"/ should be rounded to 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4552
		(fixed and:[ (precision == 0) and:[ (self abs < 1.0) ]]) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4553
		    (self abs >= 0.5) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4554
			aStream nextPut:$1
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4555
		    ] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4556
			aStream nextPut:$0
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4557
		    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4558
		    ^ self
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4559
		].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4560
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4561
		"/ handle near zero to working precision (but not exactly zero)
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4562
		(fixed and:[ d <= 0 ]) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4563
		    aStream nextPut:$0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4564
		    (precision > 0) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4565
			aStream nextPut:$. .
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4566
			aStream next:precision put:$0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4567
		    ]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4568
		] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4569
		    "/ default
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4570
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4571
		    |t j|
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4572
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4573
		    t := self digitsWithPrecision:(fixed ifTrue:[d_width_extra] ifFalse:[d])+1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4574
		    exp := t second.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4575
		    t := t first.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4576
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4577
		    fixed ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4578
			"/ fix the string if it's been computed incorrectly
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4579
			"/ round here in the decimal string if required
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4580
			t := self round_string_qd:t at:(d + 1) offset:off.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4581
			precision := t at:3.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4582
			off := t at:2.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4583
			t := t at:1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4584
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4585
			(off > 0) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4586
			    aStream next:off putAll:t startingAt:1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4587
			    (precision > 0) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4588
				aStream nextPut:$. .
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4589
				aStream next:precision-1 putAll:t startingAt:off+1.
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
			] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4592
			    aStream nextPutAll:'0.'.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4593
			    (off < 0) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4594
				aStream next:off negated put:$0.
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
			    aStream next:d putAll:t startingAt:0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4597
			]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4598
		    ] ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4599
			aStream nextPut:(t at:1).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4600
			(precision > 0) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4601
			    aStream nextPut:$. .
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4602
			].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4603
			aStream next:precision putAll:t startingAt:2.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4604
		    ]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4605
		].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4606
	    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4607
	]
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4608
    ].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4609
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4610
    "/ trap for improper offset with large values
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4611
    "/ 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
  4612
    "/ 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
  4613
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4614
"/    (fixed and:[ (precision > 0) ]) ifTrue:[
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4615
"/        "/ make sure that the value isn't dramatically larger
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4616
"/        from_string = atof(s.c_str());
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4617
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4618
"/        // if this ratio is large, then we've got problems
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4619
"/        if( fabs( from_string / this->x[0] ) > 3.0 ){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4620
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4621
"/                int point_position;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4622
"/                char temp;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4623
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4624
"/                // loop on the string, find the point, move it up one
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4625
"/                // don't act on the first character
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4626
"/                for(i=1; i < s.length(); i++){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4627
"/                        if(s[i] == '.'){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4628
"/                                s[i] = s[i-1] ;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4629
"/                                s[i-1] = '.' ;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4630
"/                                break;
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4631
"/                        }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4632
"/                }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4633
"/
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4634
"/                from_string = atof(s.c_str());
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4635
"/                // 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
  4636
"/                if( fabs( from_string / this->x[0] ) > 3.0 ){
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4637
"/                        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
  4638
"/                }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4639
"/        }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4640
"/    }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4641
"/
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4642
    fixed ifFalse:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4643
      "/ Fill in exponent part
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4644
      aStream nextPut:(uppercase ifTrue:[$E] ifFalse:[$e]).
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4645
      aStream print:exp.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4646
    ].
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4647
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4648
    "/ fill in the blanks
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4649
    (delta := width-count) > 0 ifTrue:[
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4650
	self halt.
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4651
"/    if (fmt & ios_base::internal) {
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4652
"/      if (sgn)
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4653
"/        s.insert(static_cast<string::size_type>(1), delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4654
"/      else
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4655
"/        s.insert(static_cast<string::size_type>(0), delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4656
"/    } else if (fmt & ios_base::left) {
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4657
"/      s.append(delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4658
"/    } else {
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4659
"/      s.insert(static_cast<string::size_type>(0), delta, fill);
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4660
"/    }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4661
"/  }
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4662
    ].
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4663
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4664
    "Created: / 15-06-2017 / 02:37:31 / cg"
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4665
    "Modified (comment): / 16-06-2017 / 14:48:30 / cg"
4385
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4666
!
3bfafdde1cb5 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4380
diff changeset
  4667
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4668
round_string_qd:str at:precisionIn offset:offsetIn
4454
f9079c08585a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4451
diff changeset
  4669
    <resource: #obsolete>
4395
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4670
    "returns a triple of: { new-str . new-offset . new-precision }"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4671
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4672
    "/
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4673
    "/ Input string must be all digits or errors will occur.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4674
    "/
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4675
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4676
    |i numDigits offsetOut precisionOut|
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4677
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4678
    numDigits := precisionIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4679
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4680
    offsetOut := offsetIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4681
    precisionOut := precisionIn.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4682
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4683
    "/ Round, handle carry
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4684
    ((str at:numDigits) >= $5) ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4685
	str at:numDigits-1 put:(str at:numDigits-1)+1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4686
	i := numDigits-1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4687
	[ i > 1 and:[ (str at:i) > $9] ] whileTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4688
	    str at:i put:(str at:i)-10.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4689
	    i := i - 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4690
	    str at:i put:(str at:i)+1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4691
	]
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4692
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4693
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4694
    "/ If first digit is 10, shift everything.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4695
    (str at:1) > $9 ifTrue:[
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4696
	"/ e++; // don't modify exponent here
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4697
	str replaceFrom:2 with:str startingAt:1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4698
	str at:1 put:$1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4699
	str at:2 put:$0.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4700
	offsetOut := offsetOut + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4701
	precisionOut := precisionOut + 1.
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4702
    ].
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4703
    ^ { (str copyTo:precisionOut) . offsetOut . precisionOut }
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4704
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4705
    "Created: / 16-06-2017 / 10:12:39 / cg"
3a01a83b6303 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4393
diff changeset
  4706
    "Modified (comment): / 16-06-2017 / 11:22:03 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4707
! !
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4708
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4709
!QDouble methodsFor:'private'!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4710
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4711
nintAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4712
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4713
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4714
%{
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4715
    /* Computes the nearest integer to d. */
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4716
#define nint(d) (((d) == floor(d)) ? (d) : floor((d) + 0.5))
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4717
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4718
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4719
    OBJ newQD;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4720
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4721
    double x0, x1, x2, x3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4722
    x0 = nint(a[0]);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4723
    x1 = x2 = x3 = 0.0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4724
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4725
    if (x0 == a[0]) {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4726
	/* First double is already an integer. */
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4727
	x1 = nint(a[1]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4728
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4729
	if (x1 == a[1]) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4730
	    /* Second double is already an integer. */
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4731
	    x2 = nint(a[2]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4732
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4733
	    if (x2 == a[2]) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4734
		/* Third double is already an integer. */
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4735
		x3 = nint(a[3]);
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4736
	    } else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4737
		if (abs(x2 - a[2]) == 0.5 && a[3] < 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4738
		    x2 -= 1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4739
		}
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4740
	    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4741
	} else {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4742
	    if (abs(x1 - a[1]) == 0.5 && a[2] < 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4743
		x1 -= 1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4744
	    }
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4745
	}
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4746
    } else {
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4747
	/* First double is not an integer. */
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4748
	if (abs(x0 - a[0]) == 0.5 && a[1] < 0.0) {
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4749
	    x0 -= 1.0;
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4750
	}
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4751
    }
5312
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4752
    renorm(&x0, &x1, &x2, &x3, x0, x1, x2, x3, 0.0);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4753
    // m_renorm4(x0, x1, x2, x3);
52a17656aa5b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5311
diff changeset
  4754
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4755
    __qNew_qdReal(newQD, x0, x1, x2, x3);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4756
    RETURN( newQD );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4757
%}.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4758
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4759
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4760
     (QDouble fromFloat:4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4761
     (QDouble fromFloat:4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4762
     (QDouble fromFloat:4.50000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4763
     (QDouble fromFloat:4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4764
     (QDouble fromFloat:4.49999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4765
     (QDouble fromFloat:4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4766
     (QDouble fromFloat:4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4767
     (QDouble fromFloat:0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4768
     (QDouble fromFloat:0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4769
     (QDouble fromFloat:0.49999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4770
     (QDouble fromFloat:0.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4771
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4772
     (QDouble fromFloat:-4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4773
     (QDouble fromFloat:-4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4774
     (QDouble fromFloat:-4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4775
     (QDouble fromFloat:-4.499999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4776
     (QDouble fromFloat:-4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4777
     (QDouble fromFloat:-4.5000000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4778
     (QDouble fromFloat:-4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4779
     (QDouble fromFloat:-0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4780
     (QDouble fromFloat:-0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4781
     (QDouble fromFloat:-0.4) roundedAsFloat
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4782
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4783
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4784
    "Created: / 13-06-2017 / 01:52:44 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4785
    "Modified (comment): / 13-06-2017 / 17:33:19 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4786
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4787
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4788
renorm
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4789
    "destructive renormalization"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4790
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4791
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4792
    double c0, c1, c2, c3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4793
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4794
    c0 = a[0];
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4795
    c1 = a[1];
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4796
    c2 = a[2];
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4797
    c3 = a[3];
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4798
    m_renorm4(c0, c1, c2, c3);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4799
    a[0] = c0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4800
    a[1] = c1;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4801
    a[2] = c2;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4802
    a[3] = c3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4803
    RETURN( self );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4804
%}.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4805
    ^ self error.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4806
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4807
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4808
     (QDouble fromFloat:1.0) renorm
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4809
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4810
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4811
    "Created: / 13-06-2017 / 18:05:33 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4812
    "Modified: / 15-06-2017 / 00:12:59 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4813
! !
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4814
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4815
!QDouble methodsFor:'private accessing'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4816
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4817
d0
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4818
    "the most significant (and highest valued) 53 bits of precision"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4819
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4820
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[0]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4821
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4822
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4823
    "Created: / 12-06-2017 / 20:15:12 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4824
    "Modified (comment): / 13-06-2017 / 17:59:47 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4825
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4826
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4827
d1
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4828
    "the next most significant (and next highest valued) 53 bits of precision"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4829
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4830
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[1]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4831
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4832
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4833
    "Created: / 12-06-2017 / 20:15:12 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4834
    "Modified (comment): / 13-06-2017 / 18:00:00 / cg"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4835
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4836
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4837
d2
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4838
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4839
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[2]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4840
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4841
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4842
    "Created: / 12-06-2017 / 20:15:29 / cg"
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4843
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4844
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4845
d3
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4846
    "the least significant (and smallest valued) 53 bits of precision"
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4847
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4848
    RETURN ( __MKFLOAT(__QDoubleInstPtr(self)->d_qDoubleValue[3]) );
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4849
%}
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4850
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  4851
    "Created: / 12-06-2017 / 20:15:32 / cg"
4386
0a320155d78a #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4385
diff changeset
  4852
    "Modified (comment): / 13-06-2017 / 18:00:18 / cg"
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4853
! !
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4854
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4855
!QDouble methodsFor:'testing'!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4856
4404
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4857
isFinite
5195
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4858
    "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
  4859
4404
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4860
    ^ self d0 isFinite
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4861
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4862
    "Created: / 17-06-2017 / 03:40:30 / cg"
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4863
!
2708f482fe13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4395
diff changeset
  4864
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4865
isInfinite
5195
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4866
    "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
  4867
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4868
    ^ self d0 isInfinite
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4869
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4870
    "Created: / 15-06-2017 / 01:57:57 / cg"
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4871
!
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4872
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4873
isNaN
5195
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4874
     "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
  4875
cfe34e335f2c #DOCUMENTATION by exept
Claus Gittinger <cg@exept.de>
parents: 5057
diff changeset
  4876
   ^ self d0 isNaN
4393
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4877
4084ca142033 #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4392
diff changeset
  4878
    "Created: / 15-06-2017 / 01:57:35 / cg"
4411
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4879
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4880
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4881
isOne
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4882
    ^ self d0 = 1.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4883
    and:[ self d1 = 0.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4884
    and:[ self d2 = 0.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4885
    and:[ self d3 = 0.0 ]]]
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4886
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4887
    "Created: / 18-06-2017 / 23:29:07 / cg"
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4888
!
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4889
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4890
isZero
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4891
    ^ self d0 = 0.0
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4892
8055a8f0b66f #FEATURE by cg
Claus Gittinger <cg@exept.de>
parents: 4404
diff changeset
  4893
    "Created: / 18-06-2017 / 23:29:25 / cg"
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4894
!
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4895
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4896
negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4897
    ^ self d0 negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4898
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4899
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4900
     (QDouble fromFloat:0.0) negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4901
     (QDouble fromFloat:1.0) negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4902
     (QDouble fromFloat:-1.0) negative
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4903
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4904
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4905
    "Created: / 13-06-2017 / 01:57:39 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4906
    "Modified: / 13-06-2017 / 17:58:26 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4907
!
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4908
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4909
positive
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4910
    "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
  4911
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4912
    ^ self d0 positive
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4913
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4914
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4915
     (QDouble fromFloat:1.0) positive
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4916
     (QDouble fromFloat:-1.0) positive
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4917
     (1.0 asQDouble + 1e-100) positive
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4918
     (0.0 asQDouble + 1e-100) positive
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4919
     (0.0 asQDouble - 1e-100) positive
5270
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4920
    "
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4921
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4922
    "Created: / 13-06-2017 / 01:56:53 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4923
    "Modified: / 13-06-2017 / 17:58:41 / cg"
af3b659665cf #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5195
diff changeset
  4924
    "Modified (comment): / 28-05-2019 / 05:55:55 / Claus Gittinger"
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4925
!
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4926
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4927
sign
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4928
    "return the sign of the receiver"
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4929
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4930
    ^ self d0 sign
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4931
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4932
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4933
     Float nan isNaN
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4934
     Float nan sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4935
     Float infinity sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4936
     Float infinity negated sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4937
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4938
     ShortFloat nan isNaN
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4939
     ShortFloat nan sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4940
     ShortFloat infinity sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4941
     ShortFloat infinity negated sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4942
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4943
     QDouble nan isNaN
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4944
     QDouble nan sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4945
     QDouble infinity sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4946
     QDouble infinity negated sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4947
     0 asQDouble sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4948
     1 asQDouble sign
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4949
     -1 asQDouble sign
5306
819725b85a08 #BUGFIX by exept
Claus Gittinger <cg@exept.de>
parents: 5304
diff changeset
  4950
    "
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
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4953
!QDouble methodsFor:'truncation & rounding'!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4954
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4955
ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4956
    "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
  4957
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4958
    |f|
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4959
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4960
    f := self ceilingAsFloat.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4961
    ^ 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
  4962
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4963
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4964
     (QDouble fromFloat:4.0) ceiling
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4965
     (QDouble fromFloat:4.1) ceiling
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4966
     (QDouble fromFloat:0.1) ceiling
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4967
     (0.1 + (QDouble fromFloat:1.0)) ceiling
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4968
     (1e20 + (QDouble fromFloat:1.0)) ceiling
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4969
     (1e20 + (QDouble fromFloat:1.1)) ceiling
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4970
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4971
     (QDouble fromFloat:1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4972
     (QDouble fromFloat:0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4973
     (QDouble fromFloat:-0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4974
     (QDouble fromFloat:-1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4975
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4976
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4977
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4978
ceilingAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4979
    "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
  4980
     This is much like #ceiling, but avoids a (possibly expensive) conversion
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4981
     of the result to an integer.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4982
     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
  4983
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4984
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4985
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4986
    OBJ newQD;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  4987
    int savedCV;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4988
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4989
    double x0, x1, x2, x3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4990
    x1 = x2 = x3 = 0.0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4991
    x0 = ceil(a[0]);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4992
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  4993
    if (x0 == a[0]) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4994
	x1 = ceil(a[1]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4995
	if (x1 == a[1]) {
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4996
	    x2 = ceil(a[2]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4997
	    if (x2 == a[2]) {
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4998
		x3 = ceil(a[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  4999
	    }
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5000
	}
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5001
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5002
	m_renorm4(x0, x1, x2, x3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5003
	fpu_fix_end(&savedCV);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5004
    }
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5005
    __qNew_qdReal(newQD, x0, x1, x2, x3);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5006
    RETURN( newQD );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5007
%}.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5008
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5009
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5010
     (QDouble fromFloat:4.0) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5011
     (QDouble fromFloat:4.1) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5012
     (QDouble fromFloat:0.1) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5013
     (0.1 + (QDouble fromFloat:1.0)) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5014
     (1e20 + (QDouble fromFloat:1.0)) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5015
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5016
     (QDouble fromFloat:1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5017
     (QDouble fromFloat:0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5018
     (QDouble fromFloat:-0.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5019
     (QDouble fromFloat:-1.5) ceiling
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5020
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5021
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5022
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5023
floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5024
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5025
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5026
    |f|
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5027
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5028
    f := self floorAsFloat.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5029
    ^ 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
  5030
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5031
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5032
     (QDouble fromFloat:4.0) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5033
     (QDouble fromFloat:4.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5034
     (QDouble fromFloat:0.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5035
     (0.1 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5036
     (1e20 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5037
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5038
     (QDouble fromFloat:1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5039
     (QDouble fromFloat:0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5040
     (QDouble fromFloat:-0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5041
     (QDouble fromFloat:-1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5042
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5043
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5044
    "Created: / 13-06-2017 / 01:52:44 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5045
    "Modified (comment): / 13-06-2017 / 17:33:19 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5046
!
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5047
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5048
floorAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5049
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5050
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5051
%{
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5052
    double *a = __QDoubleInstPtr(self)->d_qDoubleValue;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5053
    OBJ newQD;
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5054
    int savedCV;
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5055
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5056
    double x0, x1, x2, x3;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5057
    x1 = x2 = x3 = 0.0;
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5058
    x0 =floor(a[0]);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5059
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5060
    if (x0 == a[0]) {
5309
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5061
	x1 = floor(a[1]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5062
	if (x1 == a[1]) {
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5063
	    x2 = floor(a[2]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5064
	    if (x2 == a[2]) {
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5065
		x3 = floor(a[3]);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5066
	    }
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5067
	}
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5068
	fpu_fix_start(&savedCV);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5069
	m_renorm4(x0, x1, x2, x3);
3e482ee15d7f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 5308
diff changeset
  5070
	fpu_fix_end(&savedCV);
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5071
    }
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5072
    __qNew_qdReal(newQD, x0, x1, x2, x3);
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5073
    RETURN( newQD );
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5074
%}.
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
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5077
     (QDouble fromFloat:4.0) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5078
     (QDouble fromFloat:4.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5079
     (QDouble fromFloat:0.1) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5080
     (0.1 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5081
     (1e20 + (QDouble fromFloat:1.0)) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5082
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5083
     (QDouble fromFloat:1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5084
     (QDouble fromFloat:0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5085
     (QDouble fromFloat:-0.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5086
     (QDouble fromFloat:-1.5) floor
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5087
    "
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5088
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5089
    "Created: / 13-06-2017 / 01:52:44 / cg"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5090
    "Modified (comment): / 13-06-2017 / 17:33:19 / cg"
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
rounded
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5094
    "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
  5095
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5096
    |f|
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5097
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5098
    f := self roundedAsFloat.
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5099
    "/ ^ (f d0 + f d1 + f d2 + f d3) asInteger
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5100
    ^ 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
  5101
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5102
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5103
     (QDouble fromFloat:4.0) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5104
     (QDouble fromFloat:4.6) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5105
     (QDouble fromFloat:4.50000001) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5106
     (QDouble fromFloat:4.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5107
     (QDouble fromFloat:4.49999999) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5108
     (QDouble fromFloat:4.4) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5109
     (QDouble fromFloat:4.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5110
     (QDouble fromFloat:0.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5111
     (QDouble fromFloat:0.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5112
     (QDouble fromFloat:0.49999) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5113
     (QDouble fromFloat:0.4) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5114
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5115
     (QDouble fromFloat:-4.0) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5116
     (QDouble fromFloat:-4.6) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5117
     (QDouble fromFloat:-4.4) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5118
     (QDouble fromFloat:-4.499999999) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5119
     (QDouble fromFloat:-4.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5120
     (QDouble fromFloat:-4.5000000001) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5121
     (QDouble fromFloat:-4.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5122
     (QDouble fromFloat:-0.1) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5123
     (QDouble fromFloat:-0.5) rounded
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5124
     (QDouble fromFloat:-0.4) rounded
5273
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
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5128
roundedAsFloat
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5129
    "return the receiver truncated towards negative infinity"
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5130
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5131
    self positive ifTrue:[
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5132
	^ self nintAsFloat
5273
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5133
    ].
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5134
    ^ self negated nintAsFloat negated
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5135
9533c37f6d69 #FEATURE by exept
Claus Gittinger <cg@exept.de>
parents: 5270
diff changeset
  5136
    "
5308
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5137
     (QDouble fromFloat:4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5138
     (QDouble fromFloat:4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5139
     (QDouble fromFloat:4.50000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5140
     (QDouble fromFloat:4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5141
     (QDouble fromFloat:4.49999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5142
     (QDouble fromFloat:4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5143
     (QDouble fromFloat:4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5144
     (QDouble fromFloat:0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5145
     (QDouble fromFloat:0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5146
     (QDouble fromFloat:0.49999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5147
     (QDouble fromFloat:0.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5148
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5149
     (QDouble fromFloat:-4.0) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5150
     (QDouble fromFloat:-4.6) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5151
     (QDouble fromFloat:-4.4) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5152
     (QDouble fromFloat:-4.499999999) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5153
     (QDouble fromFloat:-4.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5154
     (QDouble fromFloat:-4.5000000001) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5155
     (QDouble fromFloat:-4.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5156
     (QDouble fromFloat:-0.1) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5157
     (QDouble fromFloat:-0.5) roundedAsFloat
d992975959ab #BUGFIX by cg
Claus Gittinger <cg@exept.de>
parents: 5306
diff changeset
  5158
     (QDouble fromFloat:-0.4) roundedAsFloat
5273
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
4380
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5165
!QDouble class methodsFor:'documentation'!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5166
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5167
version
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5168
    ^ '$Header$'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5169
!
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5170
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5171
version_CVS
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5172
    ^ '$Header$'
1f4fe7f1c1d3 initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
  5173
! !