ref: f479330acfa41b89b5345173251fb188e524bf6d
parent: 8f48df6f9767c5746f1bde6be7cfc933dae033fd
author: menno <menno>
date: Mon May 17 06:18:03 EDT 2004
Sync with internal CVS
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,39 @@
+17 may 2004 mbakker(at)nero.com
+ - syntax.c, decoder.c: Added some logging output
+
+17 may 2004 mbakker(at)nero.com
+ - mp4atom.c: Fixed an issue with broken MP4 files
+
+16 may 2004 mbakker(at)nero.com
+ - ps_dec.c: fixed point: forgot to convert a few multiplies
+
+14 may 2004 mbakker(at)nero.com
+ - sbr_*.c: reduced memory usage
+
+6 may 2004 mbakker(at)nero.com
+ - common.c: added some bit tricks and fixed point log2/pow2
+ - sbr_hfadj.c: log2/pow2 based gain calculation for SBR
+ - sbr_hfgen.c: use block exponent instead of stupid search to find max value
+
+5 may 2004 mbakker(at)nero.com
+ - decoder.c, neaacdec.h, decoder.h: added extra decode function to which a
+ buffer can be provided. Instead of the library providing a buffer.
+
+5 may 2004 mbakker(at)nero.com
+ - mdct.c: fixed fixed point MDCT with framesizes 960, 480, 120
+
+2 may 2004 mbakker(at)nero.com
+ - mdct_tab.h, mdct.c: Added tables for MDCT, for increased accuracy in fixed point
+ - specrec.c: Moved quantisation, scaling and reordering to 1 function
+
+20 april 2004 gpacutto(at)nero.com
+ - drm_dec.c, drm_dec.h: Don't do PS processing if no data was read this frame.
+ Fix for bitstread reading bug in specification.
+
+15 april 2004 mbakker(at)nero.com
+ - sbr_hfadj.c: fixed buffer overflow
+ - multiple: fixed some eVC problems
+
12 april 2004 mbakker(at)nero.com
- common.h, ps_dec.c: Updates for PS fixed point, should completely work now
--- a/common/mp4ff/mp4atom.c
+++ b/common/mp4ff/mp4atom.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: mp4atom.c,v 1.20 2004/04/12 18:17:42 menno Exp $
+** $Id: mp4atom.c,v 1.21 2004/05/17 10:18:02 menno Exp $
**/
#include <stdlib.h>
@@ -826,9 +826,11 @@
mp4ff_read_char(f); /* version */
mp4ff_read_int24(f); /* flags */
- while (sumsize < (size-12))
+ while (sumsize < (size-(header_size+4)))
{
subsize = mp4ff_atom_read_header(f, &atom_type, &header_size);
+ if (subsize <= header_size+4)
+ return 1;
if (atom_type == ATOM_ILST)
{
mp4ff_parse_metadata(f, (uint32_t)(subsize-(header_size+4)));
--- a/libfaad/cfft.c
+++ b/libfaad/cfft.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: cfft.c,v 1.25 2004/02/26 09:29:26 menno Exp $
+** $Id: cfft.c,v 1.28 2004/07/31 15:48:55 menno Exp $
**/
/*
@@ -1375,17 +1375,17 @@
switch (n)
{
- case 64: cfft->tab = cfft_tab_64; break;
- case 512: cfft->tab = cfft_tab_512; break;
+ case 64: cfft->tab = (complex_t*)cfft_tab_64; break;
+ case 512: cfft->tab = (complex_t*)cfft_tab_512; break;
#ifdef LD_DEC
- case 256: cfft->tab = cfft_tab_256; break;
+ case 256: cfft->tab = (complex_t*)cfft_tab_256; break;
#endif
#ifdef ALLOW_SMALL_FRAMELENGTH
- case 60: cfft->tab = cfft_tab_60; break;
- case 480: cfft->tab = cfft_tab_480; break;
+ case 60: cfft->tab = (complex_t*)cfft_tab_60; break;
+ case 480: cfft->tab = (complex_t*)cfft_tab_480; break;
#ifdef LD_DEC
- case 240: cfft->tab = cfft_tab_240; break;
+ case 240: cfft->tab = (complex_t*)cfft_tab_240; break;
#endif
#endif
}
--- a/libfaad/common.c
+++ b/libfaad/common.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: common.c,v 1.17 2004/03/19 10:37:55 menno Exp $
+** $Id: common.c,v 1.20 2004/07/31 15:48:55 menno Exp $
**/
/* just some common functions that could be used anywhere */
@@ -302,3 +302,236 @@
return (__r1 = (t3 >> 1) | t1 ) ^ (__r2 = (t4 + t4) | t2 );
}
+
+uint32_t ones32(uint32_t x)
+{
+ x -= ((x >> 1) & 0x55555555);
+ x = (((x >> 2) & 0x33333333) + (x & 0x33333333));
+ x = (((x >> 4) + x) & 0x0f0f0f0f);
+ x += (x >> 8);
+ x += (x >> 16);
+
+ return (x & 0x0000003f);
+}
+
+uint32_t floor_log2(uint32_t x)
+{
+#if 1
+ x |= (x >> 1);
+ x |= (x >> 2);
+ x |= (x >> 4);
+ x |= (x >> 8);
+ x |= (x >> 16);
+
+ return (ones32(x) - 1);
+#else
+ uint32_t count = 0;
+
+ while (x >>= 1)
+ count++;
+
+ return count;
+#endif
+}
+
+/* returns position of first bit that is not 0 from msb,
+ * starting count at lsb */
+uint32_t wl_min_lzc(uint32_t x)
+{
+#if 1
+ x |= (x >> 1);
+ x |= (x >> 2);
+ x |= (x >> 4);
+ x |= (x >> 8);
+ x |= (x >> 16);
+
+ return (ones32(x));
+#else
+ uint32_t count = 0;
+
+ while (x >>= 1)
+ count++;
+
+ return (count + 1);
+#endif
+}
+
+#ifdef FIXED_POINT
+
+#define TABLE_BITS 6
+/* just take the maximum number of bits for interpolation */
+#define INTERP_BITS (REAL_BITS-TABLE_BITS)
+
+static const real_t pow2_tab[] = {
+ REAL_CONST(1.000000000000000), REAL_CONST(1.010889286051701), REAL_CONST(1.021897148654117),
+ REAL_CONST(1.033024879021228), REAL_CONST(1.044273782427414), REAL_CONST(1.055645178360557),
+ REAL_CONST(1.067140400676824), REAL_CONST(1.078760797757120), REAL_CONST(1.090507732665258),
+ REAL_CONST(1.102382583307841), REAL_CONST(1.114386742595892), REAL_CONST(1.126521618608242),
+ REAL_CONST(1.138788634756692), REAL_CONST(1.151189229952983), REAL_CONST(1.163724858777578),
+ REAL_CONST(1.176396991650281), REAL_CONST(1.189207115002721), REAL_CONST(1.202156731452703),
+ REAL_CONST(1.215247359980469), REAL_CONST(1.228480536106870), REAL_CONST(1.241857812073484),
+ REAL_CONST(1.255380757024691), REAL_CONST(1.269050957191733), REAL_CONST(1.282870016078778),
+ REAL_CONST(1.296839554651010), REAL_CONST(1.310961211524764), REAL_CONST(1.325236643159741),
+ REAL_CONST(1.339667524053303), REAL_CONST(1.354255546936893), REAL_CONST(1.369002422974591),
+ REAL_CONST(1.383909881963832), REAL_CONST(1.398979672538311), REAL_CONST(1.414213562373095),
+ REAL_CONST(1.429613338391970), REAL_CONST(1.445180806977047), REAL_CONST(1.460917794180647),
+ REAL_CONST(1.476826145939499), REAL_CONST(1.492907728291265), REAL_CONST(1.509164427593423),
+ REAL_CONST(1.525598150744538), REAL_CONST(1.542210825407941), REAL_CONST(1.559004400237837),
+ REAL_CONST(1.575980845107887), REAL_CONST(1.593142151342267), REAL_CONST(1.610490331949254),
+ REAL_CONST(1.628027421857348), REAL_CONST(1.645755478153965), REAL_CONST(1.663676580326736),
+ REAL_CONST(1.681792830507429), REAL_CONST(1.700106353718524), REAL_CONST(1.718619298122478),
+ REAL_CONST(1.737333835273706), REAL_CONST(1.756252160373300), REAL_CONST(1.775376492526521),
+ REAL_CONST(1.794709075003107), REAL_CONST(1.814252175500399), REAL_CONST(1.834008086409342),
+ REAL_CONST(1.853979125083386), REAL_CONST(1.874167634110300), REAL_CONST(1.894575981586966),
+ REAL_CONST(1.915206561397147), REAL_CONST(1.936061793492294), REAL_CONST(1.957144124175400),
+ REAL_CONST(1.978456026387951), REAL_CONST(2.000000000000000)
+};
+
+static const real_t log2_tab[] = {
+ REAL_CONST(0.000000000000000), REAL_CONST(0.022367813028455), REAL_CONST(0.044394119358453),
+ REAL_CONST(0.066089190457772), REAL_CONST(0.087462841250339), REAL_CONST(0.108524456778169),
+ REAL_CONST(0.129283016944966), REAL_CONST(0.149747119504682), REAL_CONST(0.169925001442312),
+ REAL_CONST(0.189824558880017), REAL_CONST(0.209453365628950), REAL_CONST(0.228818690495881),
+ REAL_CONST(0.247927513443585), REAL_CONST(0.266786540694901), REAL_CONST(0.285402218862248),
+ REAL_CONST(0.303780748177103), REAL_CONST(0.321928094887362), REAL_CONST(0.339850002884625),
+ REAL_CONST(0.357552004618084), REAL_CONST(0.375039431346925), REAL_CONST(0.392317422778760),
+ REAL_CONST(0.409390936137702), REAL_CONST(0.426264754702098), REAL_CONST(0.442943495848728),
+ REAL_CONST(0.459431618637297), REAL_CONST(0.475733430966398), REAL_CONST(0.491853096329675),
+ REAL_CONST(0.507794640198696), REAL_CONST(0.523561956057013), REAL_CONST(0.539158811108031),
+ REAL_CONST(0.554588851677637), REAL_CONST(0.569855608330948), REAL_CONST(0.584962500721156),
+ REAL_CONST(0.599912842187128), REAL_CONST(0.614709844115208), REAL_CONST(0.629356620079610),
+ REAL_CONST(0.643856189774725), REAL_CONST(0.658211482751795), REAL_CONST(0.672425341971496),
+ REAL_CONST(0.686500527183218), REAL_CONST(0.700439718141092), REAL_CONST(0.714245517666123),
+ REAL_CONST(0.727920454563199), REAL_CONST(0.741466986401147), REAL_CONST(0.754887502163469),
+ REAL_CONST(0.768184324776926), REAL_CONST(0.781359713524660), REAL_CONST(0.794415866350106),
+ REAL_CONST(0.807354922057604), REAL_CONST(0.820178962415188), REAL_CONST(0.832890014164742),
+ REAL_CONST(0.845490050944375), REAL_CONST(0.857980995127572), REAL_CONST(0.870364719583405),
+ REAL_CONST(0.882643049361841), REAL_CONST(0.894817763307943), REAL_CONST(0.906890595608519),
+ REAL_CONST(0.918863237274595), REAL_CONST(0.930737337562886), REAL_CONST(0.942514505339240),
+ REAL_CONST(0.954196310386875), REAL_CONST(0.965784284662087), REAL_CONST(0.977279923499917),
+ REAL_CONST(0.988684686772166), REAL_CONST(1.000000000000000)
+};
+
+real_t pow2_fix(real_t val)
+{
+ uint32_t x1, x2;
+ uint32_t errcorr;
+ uint32_t index_frac;
+ real_t retval;
+ int32_t whole = (val >> REAL_BITS);
+
+ /* rest = [0..1] */
+ int32_t rest = val - (whole << REAL_BITS);
+
+ /* index into pow2_tab */
+ int32_t index = rest >> (REAL_BITS-TABLE_BITS);
+
+
+ if (val == 0)
+ return (1<<REAL_BITS);
+
+ /* leave INTERP_BITS bits */
+ index_frac = rest >> (REAL_BITS-TABLE_BITS-INTERP_BITS);
+ index_frac = index_frac & ((1<<INTERP_BITS)-1);
+
+ if (whole > 0)
+ {
+ retval = 1 << whole;
+ } else {
+ retval = REAL_CONST(1) >> -whole;
+ }
+
+ x1 = pow2_tab[index & ((1<<TABLE_BITS)-1)];
+ x2 = pow2_tab[(index & ((1<<TABLE_BITS)-1)) + 1];
+ errcorr = ( (index_frac*(x2-x1))) >> INTERP_BITS;
+
+ if (whole > 0)
+ {
+ retval = retval * (errcorr + x1);
+ } else {
+ retval = MUL_R(retval, (errcorr + x1));
+ }
+
+ return retval;
+}
+
+int32_t pow2_int(real_t val)
+{
+ uint32_t x1, x2;
+ uint32_t errcorr;
+ uint32_t index_frac;
+ real_t retval;
+ int32_t whole = (val >> REAL_BITS);
+
+ /* rest = [0..1] */
+ int32_t rest = val - (whole << REAL_BITS);
+
+ /* index into pow2_tab */
+ int32_t index = rest >> (REAL_BITS-TABLE_BITS);
+
+
+ if (val == 0)
+ return 1;
+
+ /* leave INTERP_BITS bits */
+ index_frac = rest >> (REAL_BITS-TABLE_BITS-INTERP_BITS);
+ index_frac = index_frac & ((1<<INTERP_BITS)-1);
+
+ if (whole > 0)
+ retval = 1 << whole;
+ else
+ retval = 0;
+
+ x1 = pow2_tab[index & ((1<<TABLE_BITS)-1)];
+ x2 = pow2_tab[(index & ((1<<TABLE_BITS)-1)) + 1];
+ errcorr = ( (index_frac*(x2-x1))) >> INTERP_BITS;
+
+ retval = MUL_R(retval, (errcorr + x1));
+
+ return retval;
+}
+
+/* ld(x) = ld(x*y/y) = ld(x/y) + ld(y), with y=2^N and [1 <= (x/y) < 2] */
+int32_t log2_int(uint32_t val)
+{
+ uint32_t frac;
+ uint32_t whole = (val);
+ int8_t exp = 0;
+ uint32_t index;
+ uint32_t index_frac;
+ uint32_t x1, x2;
+ uint32_t errcorr;
+
+ /* error */
+ if (val == 0)
+ return -10000;
+
+ exp = floor_log2(val);
+ exp -= REAL_BITS;
+
+ /* frac = [1..2] */
+ if (exp >= 0)
+ frac = val >> exp;
+ else
+ frac = val << -exp;
+
+ /* index in the log2 table */
+ index = frac >> (REAL_BITS-TABLE_BITS);
+
+ /* leftover part for linear interpolation */
+ index_frac = frac & ((1<<(REAL_BITS-TABLE_BITS))-1);
+
+ /* leave INTERP_BITS bits */
+ index_frac = index_frac >> (REAL_BITS-TABLE_BITS-INTERP_BITS);
+
+ x1 = log2_tab[index & ((1<<TABLE_BITS)-1)];
+ x2 = log2_tab[(index & ((1<<TABLE_BITS)-1)) + 1];
+
+ /* linear interpolation */
+ /* retval = exp + ((index_frac)*x2 + (1-index_frac)*x1) */
+
+ errcorr = (index_frac * (x2-x1)) >> INTERP_BITS;
+
+ return ((exp+REAL_BITS) << REAL_BITS) + errcorr + x1;
+}
+#endif
--- a/libfaad/common.h
+++ b/libfaad/common.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: common.h,v 1.60 2004/04/21 11:34:19 danchr Exp $
+** $Id: common.h,v 1.61 2004/05/17 10:18:02 menno Exp $
**/
#ifndef __COMMON_H__
@@ -56,6 +56,7 @@
/* #define USE_DOUBLE_PRECISION */
/* use fixed point reals */
//#define FIXED_POINT
+//#define BIG_IQ_TABLE
#ifdef _WIN32_WCE
#define FIXED_POINT
@@ -95,6 +96,7 @@
// Define LC_ONLY_DECODER if you want a pure AAC LC decoder (independant of SBR_DEC and PS_DEC)
//#define LC_ONLY_DECODER
#ifdef LC_ONLY_DECODER
+ #undef LD_DEC
#undef LTP_DEC
#undef MAIN_DEC
#undef SSR_DEC
@@ -385,6 +387,15 @@
/* common functions */
uint8_t cpu_has_sse(void);
uint32_t random_int(void);
+uint32_t ones32(uint32_t x);
+uint32_t floor_log2(uint32_t x);
+uint32_t wl_min_lzc(uint32_t x);
+#ifdef FIXED_POINT
+#define LOG2_MIN_INF REAL_CONST(-10000)
+int32_t log2_int(uint32_t val);
+int32_t pow2_int(real_t val);
+real_t pow2_fix(real_t val);
+#endif
uint8_t get_sr_index(const uint32_t samplerate);
uint8_t max_pred_sfb(const uint8_t sr_index);
uint8_t max_tns_sfb(const uint8_t sr_index, const uint8_t object_type,
--- a/libfaad/decoder.c
+++ b/libfaad/decoder.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: decoder.c,v 1.102 2004/04/03 10:49:14 menno Exp $
+** $Id: decoder.c,v 1.103 2004/05/17 10:18:02 menno Exp $
**/
#include "common.h"
@@ -50,6 +50,13 @@
uint16_t dbg_count;
#endif
+/* static function declarations */
+static void* aac_frame_decode(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo,
+ uint8_t *buffer, uint32_t buffer_size,
+ void **sample_buffer, uint32_t sample_buffer_size);
+static void create_channel_config(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo);
+
+
char* NEAACDECAPI NeAACDecGetErrorMessage(uint8_t errcode)
{
if (errcode >= NUM_ERROR_MESSAGES)
@@ -706,6 +713,28 @@
NeAACDecFrameInfo *hInfo,
uint8_t *buffer, uint32_t buffer_size)
{
+ return aac_frame_decode(hDecoder, hInfo, buffer, buffer_size, NULL, 0);
+}
+
+void* NEAACDECAPI NeAACDecDecode2(NeAACDecHandle hDecoder,
+ NeAACDecFrameInfo *hInfo,
+ uint8_t *buffer, uint32_t buffer_size,
+ void **sample_buffer, uint32_t sample_buffer_size)
+{
+ if ((sample_buffer == NULL) || (sample_buffer_size == 0))
+ {
+ hInfo->error = 27;
+ return NULL;
+ }
+
+ return aac_frame_decode(hDecoder, hInfo, buffer, buffer_size,
+ sample_buffer, sample_buffer_size);
+}
+
+static void* aac_frame_decode(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo,
+ uint8_t *buffer, uint32_t buffer_size,
+ void **sample_buffer2, uint32_t sample_buffer_size)
+{
uint8_t channels = 0;
uint8_t output_channels = 0;
bitfile ld;
@@ -723,6 +752,10 @@
return NULL;
}
+#if 0
+ printf("%d\n", buffer_size*8);
+#endif
+
frame_len = hDecoder->frameLength;
@@ -732,6 +765,21 @@
/* initialize the bitstream */
faad_initbits(&ld, buffer, buffer_size);
+#if 0
+ {
+ int i;
+ for (i = 0; i < ((buffer_size+3)>>2); i++)
+ {
+ uint8_t *buf;
+ buf = faad_getbitbuffer(&ld, 32);
+ printf("%d\n", getdword((void*)buf));
+ free(buf);
+ }
+ faad_endbits(&ld);
+ faad_initbits(&ld, buffer, buffer_size);
+ }
+#endif
+
#ifdef DRM
if (hDecoder->object_type == DRM_ER_LC)
{
@@ -873,14 +921,27 @@
stride = 2 * stride;
}
#endif
- if (hDecoder->sample_buffer)
- faad_free(hDecoder->sample_buffer);
- hDecoder->sample_buffer = NULL;
- hDecoder->sample_buffer = faad_malloc(frame_len*output_channels*stride);
+ /* check if we want to use internal sample_buffer */
+ if (sample_buffer_size == 0)
+ {
+ if (hDecoder->sample_buffer)
+ faad_free(hDecoder->sample_buffer);
+ hDecoder->sample_buffer = NULL;
+ hDecoder->sample_buffer = faad_malloc(frame_len*output_channels*stride);
+ } else if (sample_buffer_size < frame_len*output_channels*stride) {
+ /* provided sample buffer is not big enough */
+ hInfo->error = 27;
+ return NULL;
+ }
hDecoder->alloced_channels = output_channels;
}
- sample_buffer = hDecoder->sample_buffer;
+ if (sample_buffer_size == 0)
+ {
+ sample_buffer = hDecoder->sample_buffer;
+ } else {
+ sample_buffer = *sample_buffer2;
+ }
#ifdef SBR_DEC
if ((hDecoder->sbr_present_flag == 1) || (hDecoder->forceUpSampling == 1))
--- a/libfaad/decoder.h
+++ b/libfaad/decoder.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: decoder.h,v 1.41 2004/04/03 10:49:14 menno Exp $
+** $Id: decoder.h,v 1.44 2004/09/04 14:56:28 menno Exp $
**/
#ifndef __DECODER_H__
@@ -105,6 +105,11 @@
NeAACDecFrameInfo *hInfo,
uint8_t *buffer,
uint32_t buffer_size);
+
+void* NEAACDECAPI NeAACDecDecode2(NeAACDecHandle hDecoder,
+ NeAACDecFrameInfo *hInfo,
+ uint8_t *buffer, uint32_t buffer_size,
+ void **sample_buffer, uint32_t sample_buffer_size);
#ifdef _WIN32
#pragma pack(pop)
--- a/libfaad/error.c
+++ b/libfaad/error.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: error.c,v 1.25 2004/04/03 10:49:14 menno Exp $
+** $Id: error.c,v 1.28 2004/09/04 14:56:28 menno Exp $
**/
#include "common.h"
@@ -55,6 +55,7 @@
"First SBR frame is not the same as first AAC frame",
"Unexpected fill element with SBR data",
"Not all elements were provided with SBR data",
- "LTP decoding not available"
+ "LTP decoding not available",
+ "Output data buffer too small"
};
--- a/libfaad/error.h
+++ b/libfaad/error.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: error.h,v 1.19 2004/04/03 10:49:14 menno Exp $
+** $Id: error.h,v 1.22 2004/09/04 14:56:28 menno Exp $
**/
#ifndef __ERROR_H__
@@ -32,7 +32,7 @@
extern "C" {
#endif
-#define NUM_ERROR_MESSAGES 27
+#define NUM_ERROR_MESSAGES 28
extern char *err_msg[];
#ifdef __cplusplus
--- a/libfaad/filtbank.c
+++ b/libfaad/filtbank.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: filtbank.c,v 1.36 2004/02/26 09:29:26 menno Exp $
+** $Id: filtbank.c,v 1.37 2004/05/17 10:18:02 menno Exp $
**/
#include "common.h"
@@ -215,6 +215,7 @@
int64_t count = faad_get_ts();
#endif
+ /* select windows of current frame and previous frame (Sine or KBD) */
#ifdef LD_DEC
if (object_type == LD)
{
@@ -230,11 +231,24 @@
}
#endif
+#if 0
+ for (i = 0; i < 1024; i++)
+ {
+ printf("%d\n", freq_in[i]);
+ }
+#endif
+#if 0
+ printf("%d %d\n", window_sequence, window_shape);
+#endif
+
switch (window_sequence)
{
case ONLY_LONG_SEQUENCE:
+ /* perform iMDCT */
imdct_long(fb, freq_in, transf_buf, 2*nlong);
+
+ /* add second half output of previous frame to windowed output of current frame */
for (i = 0; i < nlong; i+=4)
{
time_out[i] = overlap[i] + MUL_F(transf_buf[i],window_long_prev[i]);
@@ -242,6 +256,8 @@
time_out[i+2] = overlap[i+2] + MUL_F(transf_buf[i+2],window_long_prev[i+2]);
time_out[i+3] = overlap[i+3] + MUL_F(transf_buf[i+3],window_long_prev[i+3]);
}
+
+ /* window the second half and save as overlap for next frame */
for (i = 0; i < nlong; i+=4)
{
overlap[i] = MUL_F(transf_buf[nlong+i],window_long[nlong-1-i]);
@@ -252,7 +268,10 @@
break;
case LONG_START_SEQUENCE:
+ /* perform iMDCT */
imdct_long(fb, freq_in, transf_buf, 2*nlong);
+
+ /* add second half output of previous frame to windowed output of current frame */
for (i = 0; i < nlong; i+=4)
{
time_out[i] = overlap[i] + MUL_F(transf_buf[i],window_long_prev[i]);
@@ -260,6 +279,9 @@
time_out[i+2] = overlap[i+2] + MUL_F(transf_buf[i+2],window_long_prev[i+2]);
time_out[i+3] = overlap[i+3] + MUL_F(transf_buf[i+3],window_long_prev[i+3]);
}
+
+ /* window the second half and save as overlap for next frame */
+ /* construct second half window using padding with 1's and 0's */
for (i = 0; i < nflat_ls; i++)
overlap[i] = transf_buf[nlong+i];
for (i = 0; i < nshort; i++)
@@ -269,6 +291,7 @@
break;
case EIGHT_SHORT_SEQUENCE:
+ /* perform iMDCT for each short block */
faad_imdct(fb->mdct256, freq_in+0*nshort, transf_buf+2*nshort*0);
faad_imdct(fb->mdct256, freq_in+1*nshort, transf_buf+2*nshort*1);
faad_imdct(fb->mdct256, freq_in+2*nshort, transf_buf+2*nshort*2);
@@ -277,6 +300,8 @@
faad_imdct(fb->mdct256, freq_in+5*nshort, transf_buf+2*nshort*5);
faad_imdct(fb->mdct256, freq_in+6*nshort, transf_buf+2*nshort*6);
faad_imdct(fb->mdct256, freq_in+7*nshort, transf_buf+2*nshort*7);
+
+ /* add second half output of previous frame to windowed output of current frame */
for (i = 0; i < nflat_ls; i++)
time_out[i] = overlap[i];
for(i = 0; i < nshort; i++)
@@ -288,6 +313,8 @@
if (i < trans)
time_out[nflat_ls+4*nshort+i] = overlap[nflat_ls+nshort*4+i] + MUL_F(transf_buf[nshort*7+i],window_short[nshort-1-i]) + MUL_F(transf_buf[nshort*8+i],window_short[i]);
}
+
+ /* window the second half and save as overlap for next frame */
for(i = 0; i < nshort; i++)
{
if (i >= trans)
@@ -302,7 +329,11 @@
break;
case LONG_STOP_SEQUENCE:
+ /* perform iMDCT */
imdct_long(fb, freq_in, transf_buf, 2*nlong);
+
+ /* add second half output of previous frame to windowed output of current frame */
+ /* construct first half window using padding with 1's and 0's */
for (i = 0; i < nflat_ls; i++)
time_out[i] = overlap[i];
for (i = 0; i < nshort; i++)
@@ -309,10 +340,20 @@
time_out[nflat_ls+i] = overlap[nflat_ls+i] + MUL_F(transf_buf[nflat_ls+i],window_short_prev[i]);
for (i = 0; i < nflat_ls; i++)
time_out[nflat_ls+nshort+i] = overlap[nflat_ls+nshort+i] + transf_buf[nflat_ls+nshort+i];
+
+ /* window the second half and save as overlap for next frame */
for (i = 0; i < nlong; i++)
overlap[i] = MUL_F(transf_buf[nlong+i],window_long[nlong-1-i]);
break;
}
+
+#if 0
+ for (i = 0; i < 1024; i++)
+ {
+ printf("%d\n", time_out[i]);
+ }
+#endif
+
#ifdef PROFILE
count = faad_get_ts() - count;
--- a/libfaad/fixed.h
+++ b/libfaad/fixed.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: fixed.h,v 1.22 2004/04/12 18:17:42 menno Exp $
+** $Id: fixed.h,v 1.26 2004/09/04 14:56:28 menno Exp $
**/
#ifndef __FIXED_H__
@@ -53,6 +53,7 @@
#define REAL_CONST(A) (((A) >= 0) ? ((real_t)((A)*(REAL_PRECISION)+0.5)) : ((real_t)((A)*(REAL_PRECISION)-0.5)))
#define COEF_CONST(A) (((A) >= 0) ? ((real_t)((A)*(COEF_PRECISION)+0.5)) : ((real_t)((A)*(COEF_PRECISION)-0.5)))
#define FRAC_CONST(A) (((A) == 1.00) ? ((real_t)FRAC_MAX) : (((A) >= 0) ? ((real_t)((A)*(FRAC_PRECISION)+0.5)) : ((real_t)((A)*(FRAC_PRECISION)-0.5))))
+//#define FRAC_CONST(A) (((A) >= 0) ? ((real_t)((A)*(FRAC_PRECISION)+0.5)) : ((real_t)((A)*(FRAC_PRECISION)-0.5)))
#define Q2_BITS 22
#define Q2_PRECISION (1 << Q2_BITS)
@@ -107,6 +108,7 @@
}
}
+#if 1
static INLINE real_t _MulHigh(real_t A, real_t B)
{
_asm {
@@ -129,6 +131,24 @@
*y1 = (_MulHigh(x1, c1) + _MulHigh(x2, c2))<<(FRAC_SIZE-FRAC_BITS);
*y2 = (_MulHigh(x2, c1) - _MulHigh(x1, c2))<<(FRAC_SIZE-FRAC_BITS);
}
+#else
+static INLINE real_t MUL_F(real_t A, real_t B)
+{
+ _asm {
+ mov eax,A
+ imul B
+ shrd eax,edx,FRAC_BITS
+ }
+}
+
+/* Complex multiplication */
+static INLINE void ComplexMult(real_t *y1, real_t *y2,
+ real_t x1, real_t x2, real_t c1, real_t c2)
+{
+ *y1 = MUL_F(x1, c1) + MUL_F(x2, c2);
+ *y2 = MUL_F(x2, c1) - MUL_F(x1, c2);
+}
+#endif
#elif defined(__GNUC__) && defined (__arm__)
--- a/libfaad/iq_table.h
+++ b/libfaad/iq_table.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: iq_table.h,v 1.13 2004/02/26 09:29:27 menno Exp $
+** $Id: iq_table.h,v 1.16 2004/09/04 14:56:28 menno Exp $
**/
#ifndef IQ_TABLE_H__
@@ -8243,7 +8243,11 @@
#else
+#ifdef BIG_IQ_TABLE
+#define IQ_TABLE_SIZE 8192
+#else
#define IQ_TABLE_SIZE 1026
+#endif
ALIGN static const real_t iq_table[IQ_TABLE_SIZE] =
{
@@ -9273,6 +9277,7174 @@
REAL_CONST(10307.836270711066/8.0),
REAL_CONST(10321.273240738796/8.0),
REAL_CONST(10334.71458549278/8.0)
+#ifdef BIG_IQ_TABLE
+ ,REAL_CONST(10348.160302127204/8.0),
+ REAL_CONST(10361.610387800878/8.0),
+ REAL_CONST(10375.064839677221/8.0),
+ REAL_CONST(10388.523654924258/8.0),
+ REAL_CONST(10401.986830714593/8.0),
+ REAL_CONST(10415.454364225412/8.0),
+ REAL_CONST(10428.926252638465/8.0),
+ REAL_CONST(10442.402493140049/8.0),
+ REAL_CONST(10455.883082921007/8.0),
+ REAL_CONST(10469.368019176709/8.0),
+ REAL_CONST(10482.85729910704/8.0),
+ REAL_CONST(10496.350919916393/8.0),
+ REAL_CONST(10509.848878813653/8.0),
+ REAL_CONST(10523.351173012188/8.0),
+ REAL_CONST(10536.857799729838/8.0),
+ REAL_CONST(10550.3687561889/8.0),
+ REAL_CONST(10563.884039616123/8.0),
+ REAL_CONST(10577.403647242685/8.0),
+ REAL_CONST(10590.927576304197/8.0),
+ REAL_CONST(10604.455824040679/8.0),
+ REAL_CONST(10617.988387696556/8.0),
+ REAL_CONST(10631.525264520642/8.0),
+ REAL_CONST(10645.066451766135/8.0),
+ REAL_CONST(10658.611946690598/8.0),
+ REAL_CONST(10672.161746555956/8.0),
+ REAL_CONST(10685.715848628475/8.0),
+ REAL_CONST(10699.274250178762/8.0),
+ REAL_CONST(10712.836948481747/8.0),
+ REAL_CONST(10726.403940816675/8.0),
+ REAL_CONST(10739.975224467091/8.0),
+ REAL_CONST(10753.550796720834/8.0),
+ REAL_CONST(10767.130654870027/8.0),
+ REAL_CONST(10780.714796211059/8.0),
+ REAL_CONST(10794.303218044579/8.0),
+ REAL_CONST(10807.895917675487/8.0),
+ REAL_CONST(10821.492892412922/8.0),
+ REAL_CONST(10835.094139570248/8.0),
+ REAL_CONST(10848.699656465047/8.0),
+ REAL_CONST(10862.309440419107/8.0),
+ REAL_CONST(10875.923488758415/8.0),
+ REAL_CONST(10889.541798813138/8.0),
+ REAL_CONST(10903.16436791762/8.0),
+ REAL_CONST(10916.791193410372/8.0),
+ REAL_CONST(10930.422272634056/8.0),
+ REAL_CONST(10944.05760293548/8.0),
+ REAL_CONST(10957.697181665582/8.0),
+ REAL_CONST(10971.341006179427/8.0),
+ REAL_CONST(10984.98907383619/8.0),
+ REAL_CONST(10998.641381999149/8.0),
+ REAL_CONST(11012.297928035676/8.0),
+ REAL_CONST(11025.958709317223/8.0),
+ REAL_CONST(11039.623723219316/8.0),
+ REAL_CONST(11053.292967121541/8.0),
+ REAL_CONST(11066.966438407539/8.0),
+ REAL_CONST(11080.64413446499/8.0),
+ REAL_CONST(11094.326052685608/8.0),
+ REAL_CONST(11108.012190465128/8.0),
+ REAL_CONST(11121.702545203296/8.0),
+ REAL_CONST(11135.397114303863/8.0),
+ REAL_CONST(11149.095895174571/8.0),
+ REAL_CONST(11162.798885227143/8.0),
+ REAL_CONST(11176.506081877278/8.0),
+ REAL_CONST(11190.217482544635/8.0),
+ REAL_CONST(11203.933084652828/8.0),
+ REAL_CONST(11217.652885629415/8.0),
+ REAL_CONST(11231.376882905886/8.0),
+ REAL_CONST(11245.105073917659/8.0),
+ REAL_CONST(11258.837456104062/8.0),
+ REAL_CONST(11272.574026908333/8.0),
+ REAL_CONST(11286.314783777601/8.0),
+ REAL_CONST(11300.059724162888/8.0),
+ REAL_CONST(11313.808845519083/8.0),
+ REAL_CONST(11327.562145304952/8.0),
+ REAL_CONST(11341.319620983111/8.0),
+ REAL_CONST(11355.081270020033/8.0),
+ REAL_CONST(11368.847089886023/8.0),
+ REAL_CONST(11382.617078055218/8.0),
+ REAL_CONST(11396.391232005579/8.0),
+ REAL_CONST(11410.169549218874/8.0),
+ REAL_CONST(11423.952027180676/8.0),
+ REAL_CONST(11437.738663380349/8.0),
+ REAL_CONST(11451.529455311042/8.0),
+ REAL_CONST(11465.324400469679/8.0),
+ REAL_CONST(11479.123496356951/8.0),
+ REAL_CONST(11492.926740477304/8.0),
+ REAL_CONST(11506.734130338931/8.0),
+ REAL_CONST(11520.545663453764/8.0),
+ REAL_CONST(11534.361337337466/8.0),
+ REAL_CONST(11548.181149509423/8.0),
+ REAL_CONST(11562.005097492724/8.0),
+ REAL_CONST(11575.83317881417/8.0),
+ REAL_CONST(11589.665391004253/8.0),
+ REAL_CONST(11603.501731597149/8.0),
+ REAL_CONST(11617.342198130715/8.0),
+ REAL_CONST(11631.186788146468/8.0),
+ REAL_CONST(11645.035499189589/8.0),
+ REAL_CONST(11658.888328808911/8.0),
+ REAL_CONST(11672.745274556904/8.0),
+ REAL_CONST(11686.606333989675/8.0),
+ REAL_CONST(11700.471504666955/8.0),
+ REAL_CONST(11714.340784152086/8.0),
+ REAL_CONST(11728.214170012021/8.0),
+ REAL_CONST(11742.091659817312/8.0),
+ REAL_CONST(11755.973251142101/8.0),
+ REAL_CONST(11769.858941564111/8.0),
+ REAL_CONST(11783.748728664636/8.0),
+ REAL_CONST(11797.642610028539/8.0),
+ REAL_CONST(11811.540583244237/8.0),
+ REAL_CONST(11825.442645903697/8.0),
+ REAL_CONST(11839.34879560242/8.0),
+ REAL_CONST(11853.259029939445/8.0),
+ REAL_CONST(11867.173346517333/8.0),
+ REAL_CONST(11881.091742942155/8.0),
+ REAL_CONST(11895.014216823492/8.0),
+ REAL_CONST(11908.940765774427/8.0),
+ REAL_CONST(11922.871387411526/8.0),
+ REAL_CONST(11936.806079354839/8.0),
+ REAL_CONST(11950.744839227897/8.0),
+ REAL_CONST(11964.687664657684/8.0),
+ REAL_CONST(11978.634553274653/8.0),
+ REAL_CONST(11992.585502712702/8.0),
+ REAL_CONST(12006.540510609168/8.0),
+ REAL_CONST(12020.499574604828/8.0),
+ REAL_CONST(12034.462692343877/8.0),
+ REAL_CONST(12048.429861473938/8.0),
+ REAL_CONST(12062.401079646032/8.0),
+ REAL_CONST(12076.376344514589/8.0),
+ REAL_CONST(12090.355653737433/8.0),
+ REAL_CONST(12104.339004975769/8.0),
+ REAL_CONST(12118.326395894188/8.0),
+ REAL_CONST(12132.317824160644/8.0),
+ REAL_CONST(12146.313287446457/8.0),
+ REAL_CONST(12160.312783426305/8.0),
+ REAL_CONST(12174.316309778205/8.0),
+ REAL_CONST(12188.323864183525/8.0),
+ REAL_CONST(12202.335444326955/8.0),
+ REAL_CONST(12216.351047896511/8.0),
+ REAL_CONST(12230.370672583531/8.0),
+ REAL_CONST(12244.394316082657/8.0),
+ REAL_CONST(12258.421976091831/8.0),
+ REAL_CONST(12272.453650312296/8.0),
+ REAL_CONST(12286.489336448574/8.0),
+ REAL_CONST(12300.529032208471/8.0),
+ REAL_CONST(12314.572735303058/8.0),
+ REAL_CONST(12328.620443446678/8.0),
+ REAL_CONST(12342.672154356922/8.0),
+ REAL_CONST(12356.727865754638/8.0),
+ REAL_CONST(12370.787575363909/8.0),
+ REAL_CONST(12384.851280912055/8.0),
+ REAL_CONST(12398.918980129623/8.0),
+ REAL_CONST(12412.990670750381/8.0),
+ REAL_CONST(12427.066350511306/8.0),
+ REAL_CONST(12441.146017152583/8.0),
+ REAL_CONST(12455.229668417589/8.0),
+ REAL_CONST(12469.317302052901/8.0),
+ REAL_CONST(12483.40891580827/8.0),
+ REAL_CONST(12497.50450743663/8.0),
+ REAL_CONST(12511.604074694078/8.0),
+ REAL_CONST(12525.707615339878/8.0),
+ REAL_CONST(12539.815127136444/8.0),
+ REAL_CONST(12553.926607849342/8.0),
+ REAL_CONST(12568.042055247275/8.0),
+ REAL_CONST(12582.161467102082/8.0),
+ REAL_CONST(12596.284841188726/8.0),
+ REAL_CONST(12610.41217528529/8.0),
+ REAL_CONST(12624.543467172971/8.0),
+ REAL_CONST(12638.678714636069/8.0),
+ REAL_CONST(12652.817915461985/8.0),
+ REAL_CONST(12666.961067441209/8.0),
+ REAL_CONST(12681.108168367316/8.0),
+ REAL_CONST(12695.259216036962/8.0),
+ REAL_CONST(12709.414208249869/8.0),
+ REAL_CONST(12723.573142808827/8.0),
+ REAL_CONST(12737.736017519681/8.0),
+ REAL_CONST(12751.902830191326/8.0),
+ REAL_CONST(12766.073578635704/8.0),
+ REAL_CONST(12780.248260667788/8.0),
+ REAL_CONST(12794.426874105588/8.0),
+ REAL_CONST(12808.609416770132/8.0),
+ REAL_CONST(12822.795886485468/8.0),
+ REAL_CONST(12836.986281078653/8.0),
+ REAL_CONST(12851.180598379744/8.0),
+ REAL_CONST(12865.378836221802/8.0),
+ REAL_CONST(12879.580992440871/8.0),
+ REAL_CONST(12893.787064875984/8.0),
+ REAL_CONST(12907.997051369144/8.0),
+ REAL_CONST(12922.210949765335/8.0),
+ REAL_CONST(12936.428757912496/8.0),
+ REAL_CONST(12950.650473661524/8.0),
+ REAL_CONST(12964.876094866273/8.0),
+ REAL_CONST(12979.105619383534/8.0),
+ REAL_CONST(12993.339045073039/8.0),
+ REAL_CONST(13007.576369797454/8.0),
+ REAL_CONST(13021.817591422368/8.0),
+ REAL_CONST(13036.062707816285/8.0),
+ REAL_CONST(13050.311716850629/8.0),
+ REAL_CONST(13064.564616399723/8.0),
+ REAL_CONST(13078.821404340792/8.0),
+ REAL_CONST(13093.082078553954/8.0),
+ REAL_CONST(13107.346636922217/8.0),
+ REAL_CONST(13121.615077331464/8.0),
+ REAL_CONST(13135.887397670458/8.0),
+ REAL_CONST(13150.163595830827/8.0),
+ REAL_CONST(13164.44366970706/8.0),
+ REAL_CONST(13178.727617196502/8.0),
+ REAL_CONST(13193.015436199352/8.0),
+ REAL_CONST(13207.307124618648/8.0),
+ REAL_CONST(13221.602680360265/8.0),
+ REAL_CONST(13235.902101332911/8.0),
+ REAL_CONST(13250.205385448118/8.0),
+ REAL_CONST(13264.512530620239/8.0),
+ REAL_CONST(13278.823534766434/8.0),
+ REAL_CONST(13293.138395806676/8.0),
+ REAL_CONST(13307.457111663734/8.0),
+ REAL_CONST(13321.779680263176/8.0),
+ REAL_CONST(13336.106099533356/8.0),
+ REAL_CONST(13350.436367405409/8.0),
+ REAL_CONST(13364.77048181325/8.0),
+ REAL_CONST(13379.108440693562/8.0),
+ REAL_CONST(13393.450241985796/8.0),
+ REAL_CONST(13407.795883632158/8.0),
+ REAL_CONST(13422.145363577607/8.0),
+ REAL_CONST(13436.498679769853/8.0),
+ REAL_CONST(13450.855830159346/8.0),
+ REAL_CONST(13465.216812699266/8.0),
+ REAL_CONST(13479.581625345529/8.0),
+ REAL_CONST(13493.950266056772/8.0),
+ REAL_CONST(13508.32273279435/8.0),
+ REAL_CONST(13522.699023522329/8.0),
+ REAL_CONST(13537.079136207483/8.0),
+ REAL_CONST(13551.463068819286/8.0),
+ REAL_CONST(13565.850819329906/8.0),
+ REAL_CONST(13580.2423857142/8.0),
+ REAL_CONST(13594.63776594971/8.0),
+ REAL_CONST(13609.036958016657/8.0),
+ REAL_CONST(13623.439959897927/8.0),
+ REAL_CONST(13637.846769579081/8.0),
+ REAL_CONST(13652.257385048335/8.0),
+ REAL_CONST(13666.67180429656/8.0),
+ REAL_CONST(13681.090025317284/8.0),
+ REAL_CONST(13695.512046106669/8.0),
+ REAL_CONST(13709.937864663521/8.0),
+ REAL_CONST(13724.367478989278/8.0),
+ REAL_CONST(13738.800887088004/8.0),
+ REAL_CONST(13753.238086966385/8.0),
+ REAL_CONST(13767.679076633727/8.0),
+ REAL_CONST(13782.123854101939/8.0),
+ REAL_CONST(13796.572417385545/8.0),
+ REAL_CONST(13811.024764501659/8.0),
+ REAL_CONST(13825.480893469998/8.0),
+ REAL_CONST(13839.94080231286/8.0),
+ REAL_CONST(13854.404489055134/8.0),
+ REAL_CONST(13868.871951724283/8.0),
+ REAL_CONST(13883.34318835034/8.0),
+ REAL_CONST(13897.818196965914/8.0),
+ REAL_CONST(13912.296975606168/8.0),
+ REAL_CONST(13926.779522308825/8.0),
+ REAL_CONST(13941.26583511416/8.0),
+ REAL_CONST(13955.755912064991/8.0),
+ REAL_CONST(13970.249751206682/8.0),
+ REAL_CONST(13984.747350587126/8.0),
+ REAL_CONST(13999.248708256751/8.0),
+ REAL_CONST(14013.753822268511/8.0),
+ REAL_CONST(14028.262690677873/8.0),
+ REAL_CONST(14042.775311542828/8.0),
+ REAL_CONST(14057.291682923867/8.0),
+ REAL_CONST(14071.811802883994/8.0),
+ REAL_CONST(14086.335669488704/8.0),
+ REAL_CONST(14100.863280805994/8.0),
+ REAL_CONST(14115.394634906341/8.0),
+ REAL_CONST(14129.92972986271/8.0),
+ REAL_CONST(14144.468563750548/8.0),
+ REAL_CONST(14159.01113464777/8.0),
+ REAL_CONST(14173.55744063476/8.0),
+ REAL_CONST(14188.107479794369/8.0),
+ REAL_CONST(14202.661250211901/8.0),
+ REAL_CONST(14217.218749975118/8.0),
+ REAL_CONST(14231.779977174227/8.0),
+ REAL_CONST(14246.344929901879/8.0),
+ REAL_CONST(14260.913606253163/8.0),
+ REAL_CONST(14275.486004325601/8.0),
+ REAL_CONST(14290.062122219146/8.0),
+ REAL_CONST(14304.641958036171/8.0),
+ REAL_CONST(14319.225509881464/8.0),
+ REAL_CONST(14333.812775862236/8.0),
+ REAL_CONST(14348.403754088098/8.0),
+ REAL_CONST(14362.998442671067/8.0),
+ REAL_CONST(14377.59683972556/8.0),
+ REAL_CONST(14392.198943368388/8.0),
+ REAL_CONST(14406.804751718748/8.0),
+ REAL_CONST(14421.414262898223/8.0),
+ REAL_CONST(14436.027475030774/8.0),
+ REAL_CONST(14450.64438624274/8.0),
+ REAL_CONST(14465.264994662828/8.0),
+ REAL_CONST(14479.889298422106/8.0),
+ REAL_CONST(14494.517295654005/8.0),
+ REAL_CONST(14509.148984494313/8.0),
+ REAL_CONST(14523.784363081166/8.0),
+ REAL_CONST(14538.423429555049/8.0),
+ REAL_CONST(14553.066182058781/8.0),
+ REAL_CONST(14567.712618737527/8.0),
+ REAL_CONST(14582.362737738777/8.0),
+ REAL_CONST(14597.016537212348/8.0),
+ REAL_CONST(14611.674015310382/8.0),
+ REAL_CONST(14626.33517018734/8.0),
+ REAL_CONST(14640.999999999993/8.0),
+ REAL_CONST(14655.668502907418/8.0),
+ REAL_CONST(14670.340677071003/8.0),
+ REAL_CONST(14685.016520654426/8.0),
+ REAL_CONST(14699.696031823671/8.0),
+ REAL_CONST(14714.379208746999/8.0),
+ REAL_CONST(14729.066049594967/8.0),
+ REAL_CONST(14743.756552540408/8.0),
+ REAL_CONST(14758.45071575843/8.0),
+ REAL_CONST(14773.148537426418/8.0),
+ REAL_CONST(14787.850015724018/8.0),
+ REAL_CONST(14802.555148833142/8.0),
+ REAL_CONST(14817.263934937961/8.0),
+ REAL_CONST(14831.976372224897/8.0),
+ REAL_CONST(14846.692458882624/8.0),
+ REAL_CONST(14861.41219310206/8.0),
+ REAL_CONST(14876.135573076363/8.0),
+ REAL_CONST(14890.862597000923/8.0),
+ REAL_CONST(14905.593263073371/8.0),
+ REAL_CONST(14920.327569493558/8.0),
+ REAL_CONST(14935.065514463557/8.0),
+ REAL_CONST(14949.807096187662/8.0),
+ REAL_CONST(14964.552312872382/8.0),
+ REAL_CONST(14979.301162726431/8.0),
+ REAL_CONST(14994.053643960735/8.0),
+ REAL_CONST(15008.809754788414/8.0),
+ REAL_CONST(15023.569493424788/8.0),
+ REAL_CONST(15038.332858087369/8.0),
+ REAL_CONST(15053.099846995858/8.0),
+ REAL_CONST(15067.870458372134/8.0),
+ REAL_CONST(15082.644690440264/8.0),
+ REAL_CONST(15097.422541426484/8.0),
+ REAL_CONST(15112.204009559202/8.0),
+ REAL_CONST(15126.989093068994/8.0),
+ REAL_CONST(15141.777790188597/8.0),
+ REAL_CONST(15156.570099152905/8.0),
+ REAL_CONST(15171.366018198967/8.0),
+ REAL_CONST(15186.165545565986/8.0),
+ REAL_CONST(15200.968679495301/8.0),
+ REAL_CONST(15215.775418230402/8.0),
+ REAL_CONST(15230.585760016909/8.0),
+ REAL_CONST(15245.399703102579/8.0),
+ REAL_CONST(15260.217245737298/8.0),
+ REAL_CONST(15275.038386173073/8.0),
+ REAL_CONST(15289.863122664035/8.0),
+ REAL_CONST(15304.691453466432/8.0),
+ REAL_CONST(15319.523376838621/8.0),
+ REAL_CONST(15334.358891041069/8.0),
+ REAL_CONST(15349.197994336346/8.0),
+ REAL_CONST(15364.040684989128/8.0),
+ REAL_CONST(15378.886961266177/8.0),
+ REAL_CONST(15393.736821436356/8.0),
+ REAL_CONST(15408.590263770609/8.0),
+ REAL_CONST(15423.447286541972/8.0),
+ REAL_CONST(15438.307888025554/8.0),
+ REAL_CONST(15453.172066498542/8.0),
+ REAL_CONST(15468.039820240196/8.0),
+ REAL_CONST(15482.91114753184/8.0),
+ REAL_CONST(15497.786046656869/8.0),
+ REAL_CONST(15512.664515900733/8.0),
+ REAL_CONST(15527.546553550939/8.0),
+ REAL_CONST(15542.432157897045/8.0),
+ REAL_CONST(15557.32132723066/8.0),
+ REAL_CONST(15572.214059845435/8.0),
+ REAL_CONST(15587.110354037064/8.0),
+ REAL_CONST(15602.010208103273/8.0),
+ REAL_CONST(15616.913620343823/8.0),
+ REAL_CONST(15631.820589060506/8.0),
+ REAL_CONST(15646.731112557136/8.0),
+ REAL_CONST(15661.645189139546/8.0),
+ REAL_CONST(15676.562817115593/8.0),
+ REAL_CONST(15691.483994795139/8.0),
+ REAL_CONST(15706.408720490062/8.0),
+ REAL_CONST(15721.336992514242/8.0),
+ REAL_CONST(15736.268809183561/8.0),
+ REAL_CONST(15751.204168815901/8.0),
+ REAL_CONST(15766.143069731135/8.0),
+ REAL_CONST(15781.085510251132/8.0),
+ REAL_CONST(15796.03148869974/8.0),
+ REAL_CONST(15810.981003402798/8.0),
+ REAL_CONST(15825.934052688119/8.0),
+ REAL_CONST(15840.890634885489/8.0),
+ REAL_CONST(15855.850748326673/8.0),
+ REAL_CONST(15870.814391345401/8.0),
+ REAL_CONST(15885.781562277361/8.0),
+ REAL_CONST(15900.752259460214/8.0),
+ REAL_CONST(15915.726481233565/8.0),
+ REAL_CONST(15930.704225938984/8.0),
+ REAL_CONST(15945.685491919978/8.0),
+ REAL_CONST(15960.670277522009/8.0),
+ REAL_CONST(15975.658581092481/8.0),
+ REAL_CONST(15990.65040098073/8.0),
+ REAL_CONST(16005.645735538035/8.0),
+ REAL_CONST(16020.644583117599/8.0),
+ REAL_CONST(16035.646942074556/8.0),
+ REAL_CONST(16050.652810765967/8.0),
+ REAL_CONST(16065.662187550806/8.0),
+ REAL_CONST(16080.675070789974/8.0),
+ REAL_CONST(16095.691458846273/8.0),
+ REAL_CONST(16110.711350084424/8.0),
+ REAL_CONST(16125.734742871053/8.0),
+ REAL_CONST(16140.761635574685/8.0),
+ REAL_CONST(16155.792026565747/8.0),
+ REAL_CONST(16170.825914216561/8.0),
+ REAL_CONST(16185.863296901338/8.0),
+ REAL_CONST(16200.904172996183/8.0),
+ REAL_CONST(16215.948540879079/8.0),
+ REAL_CONST(16230.996398929899/8.0),
+ REAL_CONST(16246.047745530386/8.0),
+ REAL_CONST(16261.102579064163/8.0),
+ REAL_CONST(16276.160897916721/8.0),
+ REAL_CONST(16291.22270047542/8.0),
+ REAL_CONST(16306.287985129484/8.0),
+ REAL_CONST(16321.356750269995/8.0),
+ REAL_CONST(16336.428994289896/8.0),
+ REAL_CONST(16351.504715583982/8.0),
+ REAL_CONST(16366.5839125489/8.0),
+ REAL_CONST(16381.666583583141/8.0),
+ REAL_CONST(16396.752727087041/8.0),
+ REAL_CONST(16411.842341462776/8.0),
+ REAL_CONST(16426.935425114363/8.0),
+ REAL_CONST(16442.031976447644/8.0),
+ REAL_CONST(16457.131993870298/8.0),
+ REAL_CONST(16472.235475791829/8.0),
+ REAL_CONST(16487.342420623561/8.0),
+ REAL_CONST(16502.452826778641/8.0),
+ REAL_CONST(16517.566692672033/8.0),
+ REAL_CONST(16532.684016720516/8.0),
+ REAL_CONST(16547.804797342676/8.0),
+ REAL_CONST(16562.929032958902/8.0),
+ REAL_CONST(16578.056721991394/8.0),
+ REAL_CONST(16593.18786286415/8.0),
+ REAL_CONST(16608.322454002962/8.0),
+ REAL_CONST(16623.460493835417/8.0),
+ REAL_CONST(16638.601980790896/8.0),
+ REAL_CONST(16653.746913300558/8.0),
+ REAL_CONST(16668.895289797354/8.0),
+ REAL_CONST(16684.047108716015/8.0),
+ REAL_CONST(16699.202368493046/8.0),
+ REAL_CONST(16714.361067566726/8.0),
+ REAL_CONST(16729.523204377107/8.0),
+ REAL_CONST(16744.688777366009/8.0),
+ REAL_CONST(16759.857784977012/8.0),
+ REAL_CONST(16775.030225655464/8.0),
+ REAL_CONST(16790.206097848466/8.0),
+ REAL_CONST(16805.385400004874/8.0),
+ REAL_CONST(16820.568130575302/8.0),
+ REAL_CONST(16835.754288012104/8.0),
+ REAL_CONST(16850.943870769381/8.0),
+ REAL_CONST(16866.136877302983/8.0),
+ REAL_CONST(16881.333306070494/8.0),
+ REAL_CONST(16896.53315553123/8.0),
+ REAL_CONST(16911.736424146249/8.0),
+ REAL_CONST(16926.943110378332/8.0),
+ REAL_CONST(16942.153212691992/8.0),
+ REAL_CONST(16957.366729553454/8.0),
+ REAL_CONST(16972.583659430682/8.0),
+ REAL_CONST(16987.804000793338/8.0),
+ REAL_CONST(17003.027752112816/8.0),
+ REAL_CONST(17018.254911862205/8.0),
+ REAL_CONST(17033.485478516312/8.0),
+ REAL_CONST(17048.719450551645/8.0),
+ REAL_CONST(17063.956826446421/8.0),
+ REAL_CONST(17079.197604680547/8.0),
+ REAL_CONST(17094.44178373563/8.0),
+ REAL_CONST(17109.689362094967/8.0),
+ REAL_CONST(17124.940338243552/8.0),
+ REAL_CONST(17140.194710668064/8.0),
+ REAL_CONST(17155.452477856852/8.0),
+ REAL_CONST(17170.713638299967/8.0),
+ REAL_CONST(17185.978190489128/8.0),
+ REAL_CONST(17201.246132917724/8.0),
+ REAL_CONST(17216.517464080825/8.0),
+ REAL_CONST(17231.792182475165/8.0),
+ REAL_CONST(17247.070286599141/8.0),
+ REAL_CONST(17262.351774952826/8.0),
+ REAL_CONST(17277.636646037936/8.0),
+ REAL_CONST(17292.924898357855/8.0),
+ REAL_CONST(17308.216530417623/8.0),
+ REAL_CONST(17323.511540723921/8.0),
+ REAL_CONST(17338.809927785089/8.0),
+ REAL_CONST(17354.111690111105/8.0),
+ REAL_CONST(17369.416826213594/8.0),
+ REAL_CONST(17384.725334605821/8.0),
+ REAL_CONST(17400.037213802683/8.0),
+ REAL_CONST(17415.352462320716/8.0),
+ REAL_CONST(17430.67107867809/8.0),
+ REAL_CONST(17445.993061394587/8.0),
+ REAL_CONST(17461.318408991636/8.0),
+ REAL_CONST(17476.647119992274/8.0),
+ REAL_CONST(17491.979192921168/8.0),
+ REAL_CONST(17507.314626304586/8.0),
+ REAL_CONST(17522.653418670423/8.0),
+ REAL_CONST(17537.995568548187/8.0),
+ REAL_CONST(17553.341074468986/8.0),
+ REAL_CONST(17568.689934965536/8.0),
+ REAL_CONST(17584.042148572156/8.0),
+ REAL_CONST(17599.397713824768/8.0),
+ REAL_CONST(17614.75662926089/8.0),
+ REAL_CONST(17630.118893419625/8.0),
+ REAL_CONST(17645.484504841683/8.0),
+ REAL_CONST(17660.853462069354/8.0),
+ REAL_CONST(17676.225763646511/8.0),
+ REAL_CONST(17691.601408118619/8.0),
+ REAL_CONST(17706.980394032718/8.0),
+ REAL_CONST(17722.362719937424/8.0),
+ REAL_CONST(17737.748384382936/8.0),
+ REAL_CONST(17753.137385921014/8.0),
+ REAL_CONST(17768.529723104999/8.0),
+ REAL_CONST(17783.92539448979/8.0),
+ REAL_CONST(17799.324398631856/8.0),
+ REAL_CONST(17814.726734089225/8.0),
+ REAL_CONST(17830.13239942148/8.0),
+ REAL_CONST(17845.541393189767/8.0),
+ REAL_CONST(17860.95371395678/8.0),
+ REAL_CONST(17876.369360286772/8.0),
+ REAL_CONST(17891.788330745527/8.0),
+ REAL_CONST(17907.210623900395/8.0),
+ REAL_CONST(17922.636238320254/8.0),
+ REAL_CONST(17938.065172575527/8.0),
+ REAL_CONST(17953.497425238176/8.0),
+ REAL_CONST(17968.932994881692/8.0),
+ REAL_CONST(17984.371880081104/8.0),
+ REAL_CONST(17999.814079412972/8.0),
+ REAL_CONST(18015.259591455371/8.0),
+ REAL_CONST(18030.708414787914/8.0),
+ REAL_CONST(18046.160547991731/8.0),
+ REAL_CONST(18061.615989649465/8.0),
+ REAL_CONST(18077.074738345284/8.0),
+ REAL_CONST(18092.536792664861/8.0),
+ REAL_CONST(18108.002151195393/8.0),
+ REAL_CONST(18123.470812525571/8.0),
+ REAL_CONST(18138.942775245599/8.0),
+ REAL_CONST(18154.418037947191/8.0),
+ REAL_CONST(18169.896599223546/8.0),
+ REAL_CONST(18185.37845766938/8.0),
+ REAL_CONST(18200.863611880886/8.0),
+ REAL_CONST(18216.352060455767/8.0),
+ REAL_CONST(18231.843801993204/8.0),
+ REAL_CONST(18247.338835093873/8.0),
+ REAL_CONST(18262.837158359936/8.0),
+ REAL_CONST(18278.338770395032/8.0),
+ REAL_CONST(18293.84366980429/8.0),
+ REAL_CONST(18309.351855194309/8.0),
+ REAL_CONST(18324.863325173166/8.0),
+ REAL_CONST(18340.378078350412/8.0),
+ REAL_CONST(18355.896113337069/8.0),
+ REAL_CONST(18371.417428745623/8.0),
+ REAL_CONST(18386.942023190033/8.0),
+ REAL_CONST(18402.469895285718/8.0),
+ REAL_CONST(18418.00104364955/8.0),
+ REAL_CONST(18433.53546689987/8.0),
+ REAL_CONST(18449.073163656474/8.0),
+ REAL_CONST(18464.614132540602/8.0),
+ REAL_CONST(18480.158372174956/8.0),
+ REAL_CONST(18495.705881183676/8.0),
+ REAL_CONST(18511.256658192357/8.0),
+ REAL_CONST(18526.810701828035/8.0),
+ REAL_CONST(18542.368010719183/8.0),
+ REAL_CONST(18557.928583495715/8.0),
+ REAL_CONST(18573.492418788985/8.0),
+ REAL_CONST(18589.059515231773/8.0),
+ REAL_CONST(18604.629871458303/8.0),
+ REAL_CONST(18620.203486104212/8.0),
+ REAL_CONST(18635.78035780658/8.0),
+ REAL_CONST(18651.360485203899/8.0),
+ REAL_CONST(18666.943866936086/8.0),
+ REAL_CONST(18682.53050164448/8.0),
+ REAL_CONST(18698.120387971841/8.0),
+ REAL_CONST(18713.713524562332/8.0),
+ REAL_CONST(18729.30991006154/8.0),
+ REAL_CONST(18744.909543116457/8.0),
+ REAL_CONST(18760.512422375479/8.0),
+ REAL_CONST(18776.118546488418/8.0),
+ REAL_CONST(18791.727914106479/8.0),
+ REAL_CONST(18807.340523882274/8.0),
+ REAL_CONST(18822.95637446981/8.0),
+ REAL_CONST(18838.575464524489/8.0),
+ REAL_CONST(18854.197792703111/8.0),
+ REAL_CONST(18869.823357663863/8.0),
+ REAL_CONST(18885.452158066328/8.0),
+ REAL_CONST(18901.08419257147/8.0),
+ REAL_CONST(18916.719459841639/8.0),
+ REAL_CONST(18932.357958540564/8.0),
+ REAL_CONST(18947.999687333362/8.0),
+ REAL_CONST(18963.644644886521/8.0),
+ REAL_CONST(18979.292829867907/8.0),
+ REAL_CONST(18994.944240946759/8.0),
+ REAL_CONST(19010.598876793687/8.0),
+ REAL_CONST(19026.256736080668/8.0),
+ REAL_CONST(19041.917817481048/8.0),
+ REAL_CONST(19057.582119669532/8.0),
+ REAL_CONST(19073.2496413222/8.0),
+ REAL_CONST(19088.920381116473/8.0),
+ REAL_CONST(19104.594337731145/8.0),
+ REAL_CONST(19120.271509846356/8.0),
+ REAL_CONST(19135.951896143604/8.0),
+ REAL_CONST(19151.635495305738/8.0),
+ REAL_CONST(19167.322306016948/8.0),
+ REAL_CONST(19183.012326962784/8.0),
+ REAL_CONST(19198.705556830122/8.0),
+ REAL_CONST(19214.401994307198/8.0),
+ REAL_CONST(19230.101638083579/8.0),
+ REAL_CONST(19245.804486850167/8.0),
+ REAL_CONST(19261.510539299208/8.0),
+ REAL_CONST(19277.219794124274/8.0),
+ REAL_CONST(19292.932250020265/8.0),
+ REAL_CONST(19308.647905683421/8.0),
+ REAL_CONST(19324.366759811302/8.0),
+ REAL_CONST(19340.088811102793/8.0),
+ REAL_CONST(19355.8140582581/8.0),
+ REAL_CONST(19371.542499978754/8.0),
+ REAL_CONST(19387.2741349676/8.0),
+ REAL_CONST(19403.008961928797/8.0),
+ REAL_CONST(19418.746979567823/8.0),
+ REAL_CONST(19434.488186591469/8.0),
+ REAL_CONST(19450.232581707827/8.0),
+ REAL_CONST(19465.980163626304/8.0),
+ REAL_CONST(19481.730931057613/8.0),
+ REAL_CONST(19497.484882713761/8.0),
+ REAL_CONST(19513.242017308068/8.0),
+ REAL_CONST(19529.002333555141/8.0),
+ REAL_CONST(19544.765830170898/8.0),
+ REAL_CONST(19560.532505872539/8.0),
+ REAL_CONST(19576.302359378566/8.0),
+ REAL_CONST(19592.075389408761/8.0),
+ REAL_CONST(19607.851594684209/8.0),
+ REAL_CONST(19623.630973927269/8.0),
+ REAL_CONST(19639.41352586159/8.0),
+ REAL_CONST(19655.199249212103/8.0),
+ REAL_CONST(19670.988142705017/8.0),
+ REAL_CONST(19686.780205067826/8.0),
+ REAL_CONST(19702.575435029288/8.0),
+ REAL_CONST(19718.373831319448/8.0),
+ REAL_CONST(19734.175392669615/8.0),
+ REAL_CONST(19749.980117812371/8.0),
+ REAL_CONST(19765.788005481569/8.0),
+ REAL_CONST(19781.599054412323/8.0),
+ REAL_CONST(19797.413263341008/8.0),
+ REAL_CONST(19813.230631005274/8.0),
+ REAL_CONST(19829.051156144014/8.0),
+ REAL_CONST(19844.874837497395/8.0),
+ REAL_CONST(19860.701673806827/8.0),
+ REAL_CONST(19876.531663814985/8.0),
+ REAL_CONST(19892.364806265789/8.0),
+ REAL_CONST(19908.201099904403/8.0),
+ REAL_CONST(19924.040543477258/8.0),
+ REAL_CONST(19939.883135732012/8.0),
+ REAL_CONST(19955.728875417579/8.0),
+ REAL_CONST(19971.577761284105/8.0),
+ REAL_CONST(19987.429792082985/8.0),
+ REAL_CONST(20003.284966566847/8.0),
+ REAL_CONST(20019.14328348956/8.0),
+ REAL_CONST(20035.004741606219/8.0),
+ REAL_CONST(20050.869339673161/8.0),
+ REAL_CONST(20066.737076447946/8.0),
+ REAL_CONST(20082.607950689362/8.0),
+ REAL_CONST(20098.481961157428/8.0),
+ REAL_CONST(20114.359106613385/8.0),
+ REAL_CONST(20130.239385819699/8.0),
+ REAL_CONST(20146.122797540058/8.0),
+ REAL_CONST(20162.009340539353/8.0),
+ REAL_CONST(20177.899013583716/8.0),
+ REAL_CONST(20193.791815440476/8.0),
+ REAL_CONST(20209.687744878182/8.0),
+ REAL_CONST(20225.586800666591/8.0),
+ REAL_CONST(20241.488981576669/8.0),
+ REAL_CONST(20257.394286380597/8.0),
+ REAL_CONST(20273.302713851754/8.0),
+ REAL_CONST(20289.214262764715/8.0),
+ REAL_CONST(20305.128931895277/8.0),
+ REAL_CONST(20321.046720020415/8.0),
+ REAL_CONST(20336.967625918318/8.0),
+ REAL_CONST(20352.891648368361/8.0),
+ REAL_CONST(20368.818786151114/8.0),
+ REAL_CONST(20384.749038048347/8.0),
+ REAL_CONST(20400.682402843009/8.0),
+ REAL_CONST(20416.618879319249/8.0),
+ REAL_CONST(20432.558466262391/8.0),
+ REAL_CONST(20448.501162458953/8.0),
+ REAL_CONST(20464.446966696629/8.0),
+ REAL_CONST(20480.395877764302/8.0),
+ REAL_CONST(20496.347894452025/8.0),
+ REAL_CONST(20512.303015551031/8.0),
+ REAL_CONST(20528.261239853735/8.0),
+ REAL_CONST(20544.22256615372/8.0),
+ REAL_CONST(20560.186993245738/8.0),
+ REAL_CONST(20576.15451992572/8.0),
+ REAL_CONST(20592.125144990758/8.0),
+ REAL_CONST(20608.098867239107/8.0),
+ REAL_CONST(20624.075685470198/8.0),
+ REAL_CONST(20640.055598484618/8.0),
+ REAL_CONST(20656.038605084115/8.0),
+ REAL_CONST(20672.024704071595/8.0),
+ REAL_CONST(20688.013894251126/8.0),
+ REAL_CONST(20704.006174427926/8.0),
+ REAL_CONST(20720.001543408373/8.0),
+ REAL_CONST(20735.999999999989/8.0),
+ REAL_CONST(20752.001543011454/8.0),
+ REAL_CONST(20768.006171252597/8.0),
+ REAL_CONST(20784.013883534382/8.0),
+ REAL_CONST(20800.024678668931/8.0),
+ REAL_CONST(20816.038555469506/8.0),
+ REAL_CONST(20832.055512750507/8.0),
+ REAL_CONST(20848.075549327474/8.0),
+ REAL_CONST(20864.098664017085/8.0),
+ REAL_CONST(20880.124855637161/8.0),
+ REAL_CONST(20896.154123006647/8.0),
+ REAL_CONST(20912.186464945626/8.0),
+ REAL_CONST(20928.221880275312/8.0),
+ REAL_CONST(20944.260367818049/8.0),
+ REAL_CONST(20960.301926397311/8.0),
+ REAL_CONST(20976.346554837684/8.0),
+ REAL_CONST(20992.394251964895/8.0),
+ REAL_CONST(21008.445016605787/8.0),
+ REAL_CONST(21024.498847588318/8.0),
+ REAL_CONST(21040.555743741574/8.0),
+ REAL_CONST(21056.615703895754/8.0),
+ REAL_CONST(21072.678726882168/8.0),
+ REAL_CONST(21088.744811533252/8.0),
+ REAL_CONST(21104.813956682538/8.0),
+ REAL_CONST(21120.886161164683/8.0),
+ REAL_CONST(21136.961423815443/8.0),
+ REAL_CONST(21153.039743471683/8.0),
+ REAL_CONST(21169.121118971379/8.0),
+ REAL_CONST(21185.205549153605/8.0),
+ REAL_CONST(21201.293032858535/8.0),
+ REAL_CONST(21217.383568927453/8.0),
+ REAL_CONST(21233.477156202731/8.0),
+ REAL_CONST(21249.573793527841/8.0),
+ REAL_CONST(21265.673479747358/8.0),
+ REAL_CONST(21281.776213706937/8.0),
+ REAL_CONST(21297.881994253334/8.0),
+ REAL_CONST(21313.990820234398/8.0),
+ REAL_CONST(21330.102690499054/8.0),
+ REAL_CONST(21346.21760389733/8.0),
+ REAL_CONST(21362.335559280327/8.0),
+ REAL_CONST(21378.456555500241/8.0),
+ REAL_CONST(21394.580591410333/8.0),
+ REAL_CONST(21410.707665864964/8.0),
+ REAL_CONST(21426.83777771956/8.0),
+ REAL_CONST(21442.970925830628/8.0),
+ REAL_CONST(21459.107109055756/8.0),
+ REAL_CONST(21475.246326253604/8.0),
+ REAL_CONST(21491.388576283895/8.0),
+ REAL_CONST(21507.533858007431/8.0),
+ REAL_CONST(21523.682170286087/8.0),
+ REAL_CONST(21539.833511982797/8.0),
+ REAL_CONST(21555.987881961566/8.0),
+ REAL_CONST(21572.145279087465/8.0),
+ REAL_CONST(21588.305702226615/8.0),
+ REAL_CONST(21604.469150246216/8.0),
+ REAL_CONST(21620.635622014521/8.0),
+ REAL_CONST(21636.805116400832/8.0),
+ REAL_CONST(21652.977632275521/8.0),
+ REAL_CONST(21669.153168510009/8.0),
+ REAL_CONST(21685.331723976764/8.0),
+ REAL_CONST(21701.513297549318/8.0),
+ REAL_CONST(21717.697888102244/8.0),
+ REAL_CONST(21733.885494511167/8.0),
+ REAL_CONST(21750.076115652759/8.0),
+ REAL_CONST(21766.269750404736/8.0),
+ REAL_CONST(21782.466397645861/8.0),
+ REAL_CONST(21798.666056255934/8.0),
+ REAL_CONST(21814.868725115801/8.0),
+ REAL_CONST(21831.074403107345/8.0),
+ REAL_CONST(21847.283089113484/8.0),
+ REAL_CONST(21863.494782018177/8.0),
+ REAL_CONST(21879.709480706417/8.0),
+ REAL_CONST(21895.927184064229/8.0),
+ REAL_CONST(21912.147890978667/8.0),
+ REAL_CONST(21928.371600337818/8.0),
+ REAL_CONST(21944.598311030797/8.0),
+ REAL_CONST(21960.828021947746/8.0),
+ REAL_CONST(21977.060731979829/8.0),
+ REAL_CONST(21993.296440019243/8.0),
+ REAL_CONST(22009.535144959198/8.0),
+ REAL_CONST(22025.77684569393/8.0),
+ REAL_CONST(22042.021541118691/8.0),
+ REAL_CONST(22058.269230129757/8.0),
+ REAL_CONST(22074.519911624411/8.0),
+ REAL_CONST(22090.773584500959/8.0),
+ REAL_CONST(22107.030247658717/8.0),
+ REAL_CONST(22123.289899998013/8.0),
+ REAL_CONST(22139.552540420187/8.0),
+ REAL_CONST(22155.818167827587/8.0),
+ REAL_CONST(22172.086781123569/8.0),
+ REAL_CONST(22188.358379212495/8.0),
+ REAL_CONST(22204.632960999726/8.0),
+ REAL_CONST(22220.910525391639/8.0),
+ REAL_CONST(22237.191071295601/8.0),
+ REAL_CONST(22253.474597619981/8.0),
+ REAL_CONST(22269.761103274148/8.0),
+ REAL_CONST(22286.050587168469/8.0),
+ REAL_CONST(22302.343048214312/8.0),
+ REAL_CONST(22318.638485324027/8.0),
+ REAL_CONST(22334.936897410968/8.0),
+ REAL_CONST(22351.23828338947/8.0),
+ REAL_CONST(22367.542642174871/8.0),
+ REAL_CONST(22383.849972683485/8.0),
+ REAL_CONST(22400.160273832618/8.0),
+ REAL_CONST(22416.473544540564/8.0),
+ REAL_CONST(22432.789783726603/8.0),
+ REAL_CONST(22449.108990310986/8.0),
+ REAL_CONST(22465.431163214958/8.0),
+ REAL_CONST(22481.75630136074/8.0),
+ REAL_CONST(22498.084403671528/8.0),
+ REAL_CONST(22514.415469071497/8.0),
+ REAL_CONST(22530.749496485802/8.0),
+ REAL_CONST(22547.086484840562/8.0),
+ REAL_CONST(22563.426433062879/8.0),
+ REAL_CONST(22579.769340080824/8.0),
+ REAL_CONST(22596.115204823436/8.0),
+ REAL_CONST(22612.464026220721/8.0),
+ REAL_CONST(22628.815803203655/8.0),
+ REAL_CONST(22645.170534704179/8.0),
+ REAL_CONST(22661.5282196552/8.0),
+ REAL_CONST(22677.888856990587/8.0),
+ REAL_CONST(22694.252445645168/8.0),
+ REAL_CONST(22710.618984554734/8.0),
+ REAL_CONST(22726.988472656034/8.0),
+ REAL_CONST(22743.360908886778/8.0),
+ REAL_CONST(22759.736292185622/8.0),
+ REAL_CONST(22776.114621492186/8.0),
+ REAL_CONST(22792.495895747044/8.0),
+ REAL_CONST(22808.880113891719/8.0),
+ REAL_CONST(22825.267274868678/8.0),
+ REAL_CONST(22841.657377621348/8.0),
+ REAL_CONST(22858.050421094096/8.0),
+ REAL_CONST(22874.446404232243/8.0),
+ REAL_CONST(22890.845325982053/8.0),
+ REAL_CONST(22907.247185290722/8.0),
+ REAL_CONST(22923.651981106406/8.0),
+ REAL_CONST(22940.059712378195/8.0),
+ REAL_CONST(22956.470378056114/8.0),
+ REAL_CONST(22972.883977091129/8.0),
+ REAL_CONST(22989.300508435153/8.0),
+ REAL_CONST(23005.719971041017/8.0),
+ REAL_CONST(23022.142363862498/8.0),
+ REAL_CONST(23038.567685854305/8.0),
+ REAL_CONST(23054.995935972078/8.0),
+ REAL_CONST(23071.427113172387/8.0),
+ REAL_CONST(23087.86121641273/8.0),
+ REAL_CONST(23104.298244651531/8.0),
+ REAL_CONST(23120.738196848146/8.0),
+ REAL_CONST(23137.181071962848/8.0),
+ REAL_CONST(23153.626868956846/8.0),
+ REAL_CONST(23170.075586792263/8.0),
+ REAL_CONST(23186.527224432142/8.0),
+ REAL_CONST(23202.981780840448/8.0),
+ REAL_CONST(23219.439254982066/8.0),
+ REAL_CONST(23235.899645822796/8.0),
+ REAL_CONST(23252.362952329357/8.0),
+ REAL_CONST(23268.829173469378/8.0),
+ REAL_CONST(23285.298308211408/8.0),
+ REAL_CONST(23301.770355524899/8.0),
+ REAL_CONST(23318.245314380223/8.0),
+ REAL_CONST(23334.723183748658/8.0),
+ REAL_CONST(23351.203962602387/8.0),
+ REAL_CONST(23367.687649914504/8.0),
+ REAL_CONST(23384.174244659007/8.0),
+ REAL_CONST(23400.663745810798/8.0),
+ REAL_CONST(23417.15615234568/8.0),
+ REAL_CONST(23433.651463240367/8.0),
+ REAL_CONST(23450.149677472462/8.0),
+ REAL_CONST(23466.650794020472/8.0),
+ REAL_CONST(23483.154811863806/8.0),
+ REAL_CONST(23499.661729982763/8.0),
+ REAL_CONST(23516.171547358543/8.0),
+ REAL_CONST(23532.684262973235/8.0),
+ REAL_CONST(23549.199875809823/8.0),
+ REAL_CONST(23565.718384852185/8.0),
+ REAL_CONST(23582.239789085092/8.0),
+ REAL_CONST(23598.764087494197/8.0),
+ REAL_CONST(23615.291279066041/8.0),
+ REAL_CONST(23631.821362788058/8.0),
+ REAL_CONST(23648.354337648565/8.0),
+ REAL_CONST(23664.890202636761/8.0),
+ REAL_CONST(23681.428956742733/8.0),
+ REAL_CONST(23697.970598957443/8.0),
+ REAL_CONST(23714.515128272738/8.0),
+ REAL_CONST(23731.062543681343/8.0),
+ REAL_CONST(23747.612844176863/8.0),
+ REAL_CONST(23764.166028753778/8.0),
+ REAL_CONST(23780.72209640744/8.0),
+ REAL_CONST(23797.281046134085/8.0),
+ REAL_CONST(23813.842876930816/8.0),
+ REAL_CONST(23830.407587795606/8.0),
+ REAL_CONST(23846.975177727301/8.0),
+ REAL_CONST(23863.545645725622/8.0),
+ REAL_CONST(23880.11899079115/8.0),
+ REAL_CONST(23896.695211925336/8.0),
+ REAL_CONST(23913.274308130498/8.0),
+ REAL_CONST(23929.856278409821/8.0),
+ REAL_CONST(23946.441121767348/8.0),
+ REAL_CONST(23963.028837207989/8.0),
+ REAL_CONST(23979.619423737513/8.0),
+ REAL_CONST(23996.212880362549/8.0),
+ REAL_CONST(24012.809206090584/8.0),
+ REAL_CONST(24029.408399929966/8.0),
+ REAL_CONST(24046.010460889898/8.0),
+ REAL_CONST(24062.615387980433/8.0),
+ REAL_CONST(24079.223180212492/8.0),
+ REAL_CONST(24095.833836597827/8.0),
+ REAL_CONST(24112.447356149063/8.0),
+ REAL_CONST(24129.063737879667/8.0),
+ REAL_CONST(24145.682980803951/8.0),
+ REAL_CONST(24162.305083937081/8.0),
+ REAL_CONST(24178.930046295067/8.0),
+ REAL_CONST(24195.557866894767/8.0),
+ REAL_CONST(24212.188544753884/8.0),
+ REAL_CONST(24228.822078890964/8.0),
+ REAL_CONST(24245.458468325389/8.0),
+ REAL_CONST(24262.097712077397/8.0),
+ REAL_CONST(24278.739809168052/8.0),
+ REAL_CONST(24295.384758619261/8.0),
+ REAL_CONST(24312.032559453768/8.0),
+ REAL_CONST(24328.683210695162/8.0),
+ REAL_CONST(24345.336711367858/8.0),
+ REAL_CONST(24361.993060497109/8.0),
+ REAL_CONST(24378.652257108995/8.0),
+ REAL_CONST(24395.314300230442/8.0),
+ REAL_CONST(24411.979188889192/8.0),
+ REAL_CONST(24428.646922113825/8.0),
+ REAL_CONST(24445.317498933746/8.0),
+ REAL_CONST(24461.990918379193/8.0),
+ REAL_CONST(24478.667179481225/8.0),
+ REAL_CONST(24495.346281271726/8.0),
+ REAL_CONST(24512.028222783407/8.0),
+ REAL_CONST(24528.713003049801/8.0),
+ REAL_CONST(24545.400621105266/8.0),
+ REAL_CONST(24562.091075984976/8.0),
+ REAL_CONST(24578.784366724925/8.0),
+ REAL_CONST(24595.480492361927/8.0),
+ REAL_CONST(24612.179451933614/8.0),
+ REAL_CONST(24628.881244478438/8.0),
+ REAL_CONST(24645.585869035654/8.0),
+ REAL_CONST(24662.293324645343/8.0),
+ REAL_CONST(24679.003610348394/8.0),
+ REAL_CONST(24695.716725186514/8.0),
+ REAL_CONST(24712.432668202211/8.0),
+ REAL_CONST(24729.151438438807/8.0),
+ REAL_CONST(24745.873034940436/8.0),
+ REAL_CONST(24762.597456752032/8.0),
+ REAL_CONST(24779.324702919344/8.0),
+ REAL_CONST(24796.054772488926/8.0),
+ REAL_CONST(24812.787664508123/8.0),
+ REAL_CONST(24829.5233780251/8.0),
+ REAL_CONST(24846.261912088819/8.0),
+ REAL_CONST(24863.003265749034/8.0),
+ REAL_CONST(24879.747438056307/8.0),
+ REAL_CONST(24896.494428062004/8.0),
+ REAL_CONST(24913.244234818278/8.0),
+ REAL_CONST(24929.996857378079/8.0),
+ REAL_CONST(24946.752294795166/8.0),
+ REAL_CONST(24963.510546124078/8.0),
+ REAL_CONST(24980.271610420157/8.0),
+ REAL_CONST(24997.035486739525/8.0),
+ REAL_CONST(25013.802174139113/8.0),
+ REAL_CONST(25030.571671676629/8.0),
+ REAL_CONST(25047.343978410572/8.0),
+ REAL_CONST(25064.119093400237/8.0),
+ REAL_CONST(25080.897015705697/8.0),
+ REAL_CONST(25097.677744387816/8.0),
+ REAL_CONST(25114.461278508239/8.0),
+ REAL_CONST(25131.2476171294/8.0),
+ REAL_CONST(25148.036759314517/8.0),
+ REAL_CONST(25164.828704127583/8.0),
+ REAL_CONST(25181.623450633375/8.0),
+ REAL_CONST(25198.42099789745/8.0),
+ REAL_CONST(25215.221344986145/8.0),
+ REAL_CONST(25232.024490966574/8.0),
+ REAL_CONST(25248.830434906627/8.0),
+ REAL_CONST(25265.639175874974/8.0),
+ REAL_CONST(25282.450712941049/8.0),
+ REAL_CONST(25299.265045175071/8.0),
+ REAL_CONST(25316.082171648024/8.0),
+ REAL_CONST(25332.902091431668/8.0),
+ REAL_CONST(25349.724803598532/8.0),
+ REAL_CONST(25366.550307221914/8.0),
+ REAL_CONST(25383.378601375884/8.0),
+ REAL_CONST(25400.209685135269/8.0),
+ REAL_CONST(25417.043557575678/8.0),
+ REAL_CONST(25433.880217773472/8.0),
+ REAL_CONST(25450.719664805783/8.0),
+ REAL_CONST(25467.561897750507/8.0),
+ REAL_CONST(25484.406915686297/8.0),
+ REAL_CONST(25501.254717692573/8.0),
+ REAL_CONST(25518.105302849512/8.0),
+ REAL_CONST(25534.958670238051/8.0),
+ REAL_CONST(25551.814818939893/8.0),
+ REAL_CONST(25568.67374803748/8.0),
+ REAL_CONST(25585.535456614027/8.0),
+ REAL_CONST(25602.399943753502/8.0),
+ REAL_CONST(25619.267208540619/8.0),
+ REAL_CONST(25636.137250060852/8.0),
+ REAL_CONST(25653.010067400432/8.0),
+ REAL_CONST(25669.885659646327/8.0),
+ REAL_CONST(25686.76402588627/8.0),
+ REAL_CONST(25703.645165208734/8.0),
+ REAL_CONST(25720.529076702944/8.0),
+ REAL_CONST(25737.415759458876/8.0),
+ REAL_CONST(25754.305212567244/8.0),
+ REAL_CONST(25771.197435119517/8.0),
+ REAL_CONST(25788.092426207899/8.0),
+ REAL_CONST(25804.990184925344/8.0),
+ REAL_CONST(25821.890710365547/8.0),
+ REAL_CONST(25838.794001622944/8.0),
+ REAL_CONST(25855.700057792714/8.0),
+ REAL_CONST(25872.608877970775/8.0),
+ REAL_CONST(25889.520461253778/8.0),
+ REAL_CONST(25906.434806739118/8.0),
+ REAL_CONST(25923.351913524923/8.0),
+ REAL_CONST(25940.271780710063/8.0),
+ REAL_CONST(25957.194407394138/8.0),
+ REAL_CONST(25974.11979267748/8.0),
+ REAL_CONST(25991.047935661154/8.0),
+ REAL_CONST(26007.978835446964/8.0),
+ REAL_CONST(26024.912491137442/8.0),
+ REAL_CONST(26041.848901835841/8.0),
+ REAL_CONST(26058.788066646157/8.0),
+ REAL_CONST(26075.729984673108/8.0),
+ REAL_CONST(26092.674655022136/8.0),
+ REAL_CONST(26109.622076799409/8.0),
+ REAL_CONST(26126.572249111829/8.0),
+ REAL_CONST(26143.525171067016/8.0),
+ REAL_CONST(26160.480841773315/8.0),
+ REAL_CONST(26177.43926033979/8.0),
+ REAL_CONST(26194.400425876229/8.0),
+ REAL_CONST(26211.364337493149/8.0),
+ REAL_CONST(26228.330994301767/8.0),
+ REAL_CONST(26245.30039541404/8.0),
+ REAL_CONST(26262.272539942627/8.0),
+ REAL_CONST(26279.247427000919/8.0),
+ REAL_CONST(26296.225055703002/8.0),
+ REAL_CONST(26313.205425163702/8.0),
+ REAL_CONST(26330.188534498539/8.0),
+ REAL_CONST(26347.174382823756/8.0),
+ REAL_CONST(26364.162969256304/8.0),
+ REAL_CONST(26381.154292913852/8.0),
+ REAL_CONST(26398.148352914774/8.0),
+ REAL_CONST(26415.145148378149/8.0),
+ REAL_CONST(26432.144678423778/8.0),
+ REAL_CONST(26449.146942172156/8.0),
+ REAL_CONST(26466.151938744493/8.0),
+ REAL_CONST(26483.159667262702/8.0),
+ REAL_CONST(26500.170126849403/8.0),
+ REAL_CONST(26517.183316627921/8.0),
+ REAL_CONST(26534.199235722277/8.0),
+ REAL_CONST(26551.217883257199/8.0),
+ REAL_CONST(26568.239258358124/8.0),
+ REAL_CONST(26585.263360151173/8.0),
+ REAL_CONST(26602.290187763181/8.0),
+ REAL_CONST(26619.319740321676/8.0),
+ REAL_CONST(26636.352016954883/8.0),
+ REAL_CONST(26653.387016791727/8.0),
+ REAL_CONST(26670.424738961825/8.0),
+ REAL_CONST(26687.465182595493/8.0),
+ REAL_CONST(26704.508346823739/8.0),
+ REAL_CONST(26721.554230778267/8.0),
+ REAL_CONST(26738.602833591467/8.0),
+ REAL_CONST(26755.65415439643/8.0),
+ REAL_CONST(26772.708192326929/8.0),
+ REAL_CONST(26789.764946517433/8.0),
+ REAL_CONST(26806.824416103096/8.0),
+ REAL_CONST(26823.886600219761/8.0),
+ REAL_CONST(26840.95149800396/8.0),
+ REAL_CONST(26858.019108592915/8.0),
+ REAL_CONST(26875.089431124517/8.0),
+ REAL_CONST(26892.162464737365/8.0),
+ REAL_CONST(26909.238208570721/8.0),
+ REAL_CONST(26926.316661764544/8.0),
+ REAL_CONST(26943.397823459472/8.0),
+ REAL_CONST(26960.481692796813/8.0),
+ REAL_CONST(26977.568268918571/8.0),
+ REAL_CONST(26994.657550967422/8.0),
+ REAL_CONST(27011.749538086722/8.0),
+ REAL_CONST(27028.844229420498/8.0),
+ REAL_CONST(27045.941624113464/8.0),
+ REAL_CONST(27063.041721311005/8.0),
+ REAL_CONST(27080.144520159181/8.0),
+ REAL_CONST(27097.250019804727/8.0),
+ REAL_CONST(27114.35821939505/8.0),
+ REAL_CONST(27131.469118078236/8.0),
+ REAL_CONST(27148.582715003027/8.0),
+ REAL_CONST(27165.699009318858/8.0),
+ REAL_CONST(27182.818000175819/8.0),
+ REAL_CONST(27199.939686724665/8.0),
+ REAL_CONST(27217.064068116837/8.0),
+ REAL_CONST(27234.191143504428/8.0),
+ REAL_CONST(27251.320912040203/8.0),
+ REAL_CONST(27268.453372877593/8.0),
+ REAL_CONST(27285.588525170693/8.0),
+ REAL_CONST(27302.726368074269/8.0),
+ REAL_CONST(27319.866900743735/8.0),
+ REAL_CONST(27337.010122335181/8.0),
+ REAL_CONST(27354.156032005358/8.0),
+ REAL_CONST(27371.304628911668/8.0),
+ REAL_CONST(27388.455912212183/8.0),
+ REAL_CONST(27405.609881065626/8.0),
+ REAL_CONST(27422.766534631384/8.0),
+ REAL_CONST(27439.925872069507/8.0),
+ REAL_CONST(27457.087892540683/8.0),
+ REAL_CONST(27474.252595206275/8.0),
+ REAL_CONST(27491.419979228293/8.0),
+ REAL_CONST(27508.5900437694/8.0),
+ REAL_CONST(27525.762787992917/8.0),
+ REAL_CONST(27542.93821106281/8.0),
+ REAL_CONST(27560.116312143706/8.0),
+ REAL_CONST(27577.297090400876/8.0),
+ REAL_CONST(27594.480545000242/8.0),
+ REAL_CONST(27611.666675108383/8.0),
+ REAL_CONST(27628.855479892518/8.0),
+ REAL_CONST(27646.046958520514/8.0),
+ REAL_CONST(27663.241110160889/8.0),
+ REAL_CONST(27680.437933982801/8.0),
+ REAL_CONST(27697.637429156068/8.0),
+ REAL_CONST(27714.839594851132/8.0),
+ REAL_CONST(27732.04443023909/8.0),
+ REAL_CONST(27749.251934491687/8.0),
+ REAL_CONST(27766.462106781299/8.0),
+ REAL_CONST(27783.674946280949/8.0),
+ REAL_CONST(27800.890452164302/8.0),
+ REAL_CONST(27818.108623605654/8.0),
+ REAL_CONST(27835.329459779954/8.0),
+ REAL_CONST(27852.55295986278/8.0),
+ REAL_CONST(27869.779123030345/8.0),
+ REAL_CONST(27887.007948459504/8.0),
+ REAL_CONST(27904.239435327745/8.0),
+ REAL_CONST(27921.473582813196/8.0),
+ REAL_CONST(27938.710390094613/8.0),
+ REAL_CONST(27955.949856351392/8.0),
+ REAL_CONST(27973.19198076355/8.0),
+ REAL_CONST(27990.436762511745/8.0),
+ REAL_CONST(28007.684200777272/8.0),
+ REAL_CONST(28024.934294742041/8.0),
+ REAL_CONST(28042.187043588601/8.0),
+ REAL_CONST(28059.442446500128/8.0),
+ REAL_CONST(28076.700502660427/8.0),
+ REAL_CONST(28093.961211253929/8.0),
+ REAL_CONST(28111.224571465693/8.0),
+ REAL_CONST(28128.490582481401/8.0),
+ REAL_CONST(28145.759243487362/8.0),
+ REAL_CONST(28163.030553670509/8.0),
+ REAL_CONST(28180.304512218394/8.0),
+ REAL_CONST(28197.581118319198/8.0),
+ REAL_CONST(28214.860371161725/8.0),
+ REAL_CONST(28232.14226993539/8.0),
+ REAL_CONST(28249.42681383024/8.0),
+ REAL_CONST(28266.71400203693/8.0),
+ REAL_CONST(28284.003833746745/8.0),
+ REAL_CONST(28301.296308151585/8.0),
+ REAL_CONST(28318.591424443959/8.0),
+ REAL_CONST(28335.889181817001/8.0),
+ REAL_CONST(28353.189579464462/8.0),
+ REAL_CONST(28370.492616580705/8.0),
+ REAL_CONST(28387.798292360701/8.0),
+ REAL_CONST(28405.106606000048/8.0),
+ REAL_CONST(28422.417556694945/8.0),
+ REAL_CONST(28439.731143642206/8.0),
+ REAL_CONST(28457.047366039264/8.0),
+ REAL_CONST(28474.366223084147/8.0),
+ REAL_CONST(28491.687713975512/8.0),
+ REAL_CONST(28509.011837912611/8.0),
+ REAL_CONST(28526.338594095305/8.0),
+ REAL_CONST(28543.667981724069/8.0),
+ REAL_CONST(28560.999999999982/8.0),
+ REAL_CONST(28578.334648124732/8.0),
+ REAL_CONST(28595.671925300605/8.0),
+ REAL_CONST(28613.011830730498/8.0),
+ REAL_CONST(28630.354363617909/8.0),
+ REAL_CONST(28647.699523166943/8.0),
+ REAL_CONST(28665.0473085823/8.0),
+ REAL_CONST(28682.397719069289/8.0),
+ REAL_CONST(28699.750753833818/8.0),
+ REAL_CONST(28717.10641208239/8.0),
+ REAL_CONST(28734.464693022121/8.0),
+ REAL_CONST(28751.825595860708/8.0),
+ REAL_CONST(28769.189119806462/8.0),
+ REAL_CONST(28786.55526406828/8.0),
+ REAL_CONST(28803.924027855664/8.0),
+ REAL_CONST(28821.295410378701/8.0),
+ REAL_CONST(28838.669410848088/8.0),
+ REAL_CONST(28856.046028475103/8.0),
+ REAL_CONST(28873.425262471628/8.0),
+ REAL_CONST(28890.80711205013/8.0),
+ REAL_CONST(28908.191576423673/8.0),
+ REAL_CONST(28925.578654805915/8.0),
+ REAL_CONST(28942.968346411097/8.0),
+ REAL_CONST(28960.360650454055/8.0),
+ REAL_CONST(28977.755566150216/8.0),
+ REAL_CONST(28995.153092715591/8.0),
+ REAL_CONST(29012.553229366786/8.0),
+ REAL_CONST(29029.955975320987/8.0),
+ REAL_CONST(29047.361329795975/8.0),
+ REAL_CONST(29064.769292010107/8.0),
+ REAL_CONST(29082.179861182336/8.0),
+ REAL_CONST(29099.593036532187/8.0),
+ REAL_CONST(29117.00881727978/8.0),
+ REAL_CONST(29134.427202645813/8.0),
+ REAL_CONST(29151.848191851568/8.0),
+ REAL_CONST(29169.271784118911/8.0),
+ REAL_CONST(29186.697978670283/8.0),
+ REAL_CONST(29204.126774728706/8.0),
+ REAL_CONST(29221.55817151779/8.0),
+ REAL_CONST(29238.992168261717/8.0),
+ REAL_CONST(29256.42876418525/8.0),
+ REAL_CONST(29273.867958513725/8.0),
+ REAL_CONST(29291.309750473058/8.0),
+ REAL_CONST(29308.754139289747/8.0),
+ REAL_CONST(29326.201124190855/8.0),
+ REAL_CONST(29343.65070440403/8.0),
+ REAL_CONST(29361.102879157483/8.0),
+ REAL_CONST(29378.557647680012/8.0),
+ REAL_CONST(29396.015009200975/8.0),
+ REAL_CONST(29413.474962950309/8.0),
+ REAL_CONST(29430.937508158524/8.0),
+ REAL_CONST(29448.402644056692/8.0),
+ REAL_CONST(29465.870369876469/8.0),
+ REAL_CONST(29483.340684850071/8.0),
+ REAL_CONST(29500.81358821028/8.0),
+ REAL_CONST(29518.289079190454/8.0),
+ REAL_CONST(29535.767157024511/8.0),
+ REAL_CONST(29553.247820946945/8.0),
+ REAL_CONST(29570.731070192807/8.0),
+ REAL_CONST(29588.216903997723/8.0),
+ REAL_CONST(29605.70532159787/8.0),
+ REAL_CONST(29623.19632223/8.0),
+ REAL_CONST(29640.689905131429/8.0),
+ REAL_CONST(29658.186069540028/8.0),
+ REAL_CONST(29675.684814694236/8.0),
+ REAL_CONST(29693.186139833047/8.0),
+ REAL_CONST(29710.690044196028/8.0),
+ REAL_CONST(29728.196527023298/8.0),
+ REAL_CONST(29745.705587555527/8.0),
+ REAL_CONST(29763.217225033964/8.0),
+ REAL_CONST(29780.731438700397/8.0),
+ REAL_CONST(29798.248227797183/8.0),
+ REAL_CONST(29815.76759156723/8.0),
+ REAL_CONST(29833.289529254005/8.0),
+ REAL_CONST(29850.81404010153/8.0),
+ REAL_CONST(29868.341123354381/8.0),
+ REAL_CONST(29885.870778257693/8.0),
+ REAL_CONST(29903.403004057145/8.0),
+ REAL_CONST(29920.937799998974/8.0),
+ REAL_CONST(29938.475165329975/8.0),
+ REAL_CONST(29956.015099297485/8.0),
+ REAL_CONST(29973.557601149394/8.0),
+ REAL_CONST(29991.102670134147/8.0),
+ REAL_CONST(30008.650305500738/8.0),
+ REAL_CONST(30026.200506498706/8.0),
+ REAL_CONST(30043.753272378144/8.0),
+ REAL_CONST(30061.308602389683/8.0),
+ REAL_CONST(30078.866495784507/8.0),
+ REAL_CONST(30096.426951814352/8.0),
+ REAL_CONST(30113.989969731494/8.0),
+ REAL_CONST(30131.55554878875/8.0),
+ REAL_CONST(30149.123688239491/8.0),
+ REAL_CONST(30166.694387337629/8.0),
+ REAL_CONST(30184.267645337608/8.0),
+ REAL_CONST(30201.843461494434/8.0),
+ REAL_CONST(30219.42183506364/8.0),
+ REAL_CONST(30237.002765301309/8.0),
+ REAL_CONST(30254.586251464058/8.0),
+ REAL_CONST(30272.172292809046/8.0),
+ REAL_CONST(30289.760888593977/8.0),
+ REAL_CONST(30307.35203807709/8.0),
+ REAL_CONST(30324.94574051716/8.0),
+ REAL_CONST(30342.541995173502/8.0),
+ REAL_CONST(30360.140801305966/8.0),
+ REAL_CONST(30377.742158174944/8.0),
+ REAL_CONST(30395.346065041358/8.0),
+ REAL_CONST(30412.952521166666/8.0),
+ REAL_CONST(30430.561525812864/8.0),
+ REAL_CONST(30448.173078242475/8.0),
+ REAL_CONST(30465.787177718561/8.0),
+ REAL_CONST(30483.403823504719/8.0),
+ REAL_CONST(30501.02301486507/8.0),
+ REAL_CONST(30518.644751064272/8.0),
+ REAL_CONST(30536.269031367516/8.0),
+ REAL_CONST(30553.895855040515/8.0),
+ REAL_CONST(30571.525221349519/8.0),
+ REAL_CONST(30589.157129561307/8.0),
+ REAL_CONST(30606.791578943175/8.0),
+ REAL_CONST(30624.428568762964/8.0),
+ REAL_CONST(30642.06809828903/8.0),
+ REAL_CONST(30659.710166790261/8.0),
+ REAL_CONST(30677.35477353607/8.0),
+ REAL_CONST(30695.001917796391/8.0),
+ REAL_CONST(30712.651598841687/8.0),
+ REAL_CONST(30730.303815942945/8.0),
+ REAL_CONST(30747.958568371676/8.0),
+ REAL_CONST(30765.615855399912/8.0),
+ REAL_CONST(30783.275676300211/8.0),
+ REAL_CONST(30800.938030345646/8.0),
+ REAL_CONST(30818.602916809814/8.0),
+ REAL_CONST(30836.270334966837/8.0),
+ REAL_CONST(30853.940284091354/8.0),
+ REAL_CONST(30871.612763458521/8.0),
+ REAL_CONST(30889.287772344011/8.0),
+ REAL_CONST(30906.965310024025/8.0),
+ REAL_CONST(30924.645375775272/8.0),
+ REAL_CONST(30942.327968874983/8.0),
+ REAL_CONST(30960.013088600903/8.0),
+ REAL_CONST(30977.700734231294/8.0),
+ REAL_CONST(30995.390905044929/8.0),
+ REAL_CONST(31013.083600321101/8.0),
+ REAL_CONST(31030.778819339619/8.0),
+ REAL_CONST(31048.476561380798/8.0),
+ REAL_CONST(31066.17682572547/8.0),
+ REAL_CONST(31083.879611654978/8.0),
+ REAL_CONST(31101.584918451179/8.0),
+ REAL_CONST(31119.29274539644/8.0),
+ REAL_CONST(31137.003091773637/8.0),
+ REAL_CONST(31154.715956866155/8.0),
+ REAL_CONST(31172.431339957893/8.0),
+ REAL_CONST(31190.14924033326/8.0),
+ REAL_CONST(31207.869657277162/8.0),
+ REAL_CONST(31225.592590075023/8.0),
+ REAL_CONST(31243.318038012771/8.0),
+ REAL_CONST(31261.046000376838/8.0),
+ REAL_CONST(31278.776476454172/8.0),
+ REAL_CONST(31296.50946553221/8.0),
+ REAL_CONST(31314.24496689891/8.0),
+ REAL_CONST(31331.98297984272/8.0),
+ REAL_CONST(31349.7235036526/8.0),
+ REAL_CONST(31367.466537618013/8.0),
+ REAL_CONST(31385.212081028923/8.0),
+ REAL_CONST(31402.960133175795/8.0),
+ REAL_CONST(31420.710693349596/8.0),
+ REAL_CONST(31438.463760841791/8.0),
+ REAL_CONST(31456.219334944351/8.0),
+ REAL_CONST(31473.977414949743/8.0),
+ REAL_CONST(31491.738000150934/8.0),
+ REAL_CONST(31509.501089841389/8.0),
+ REAL_CONST(31527.266683315069/8.0),
+ REAL_CONST(31545.034779866437/8.0),
+ REAL_CONST(31562.80537879045/8.0),
+ REAL_CONST(31580.578479382562/8.0),
+ REAL_CONST(31598.35408093872/8.0),
+ REAL_CONST(31616.132182755369/8.0),
+ REAL_CONST(31633.91278412945/8.0),
+ REAL_CONST(31651.695884358396/8.0),
+ REAL_CONST(31669.481482740131/8.0),
+ REAL_CONST(31687.269578573076/8.0),
+ REAL_CONST(31705.060171156143/8.0),
+ REAL_CONST(31722.853259788735/8.0),
+ REAL_CONST(31740.648843770748/8.0),
+ REAL_CONST(31758.446922402567/8.0),
+ REAL_CONST(31776.247494985066/8.0),
+ REAL_CONST(31794.050560819614/8.0),
+ REAL_CONST(31811.85611920806/8.0),
+ REAL_CONST(31829.664169452753/8.0),
+ REAL_CONST(31847.474710856521/8.0),
+ REAL_CONST(31865.287742722685/8.0),
+ REAL_CONST(31883.103264355046/8.0),
+ REAL_CONST(31900.921275057899/8.0),
+ REAL_CONST(31918.741774136019/8.0),
+ REAL_CONST(31936.564760894671/8.0),
+ REAL_CONST(31954.390234639599/8.0),
+ REAL_CONST(31972.21819467704/8.0),
+ REAL_CONST(31990.048640313704/8.0),
+ REAL_CONST(32007.881570856793/8.0),
+ REAL_CONST(32025.716985613984/8.0),
+ REAL_CONST(32043.554883893445/8.0),
+ REAL_CONST(32061.395265003815/8.0),
+ REAL_CONST(32079.238128254223/8.0),
+ REAL_CONST(32097.083472954269/8.0),
+ REAL_CONST(32114.931298414049/8.0),
+ REAL_CONST(32132.781603944117/8.0),
+ REAL_CONST(32150.634388855524/8.0),
+ REAL_CONST(32168.48965245979/8.0),
+ REAL_CONST(32186.347394068915/8.0),
+ REAL_CONST(32204.207612995371/8.0),
+ REAL_CONST(32222.07030855212/8.0),
+ REAL_CONST(32239.935480052583/8.0),
+ REAL_CONST(32257.803126810672/8.0),
+ REAL_CONST(32275.673248140767/8.0),
+ REAL_CONST(32293.545843357719/8.0),
+ REAL_CONST(32311.420911776862/8.0),
+ REAL_CONST(32329.298452713996/8.0),
+ REAL_CONST(32347.178465485395/8.0),
+ REAL_CONST(32365.060949407813/8.0),
+ REAL_CONST(32382.945903798463/8.0),
+ REAL_CONST(32400.83332797504/8.0),
+ REAL_CONST(32418.723221255706/8.0),
+ REAL_CONST(32436.615582959093/8.0),
+ REAL_CONST(32454.510412404306/8.0),
+ REAL_CONST(32472.407708910916/8.0),
+ REAL_CONST(32490.307471798966/8.0),
+ REAL_CONST(32508.209700388961/8.0),
+ REAL_CONST(32526.114394001877/8.0),
+ REAL_CONST(32544.021551959166/8.0),
+ REAL_CONST(32561.931173582732/8.0),
+ REAL_CONST(32579.843258194956/8.0),
+ REAL_CONST(32597.757805118679/8.0),
+ REAL_CONST(32615.674813677211/8.0),
+ REAL_CONST(32633.594283194328/8.0),
+ REAL_CONST(32651.516212994258/8.0),
+ REAL_CONST(32669.440602401712/8.0),
+ REAL_CONST(32687.367450741847/8.0),
+ REAL_CONST(32705.296757340297/8.0),
+ REAL_CONST(32723.228521523146/8.0),
+ REAL_CONST(32741.162742616943/8.0),
+ REAL_CONST(32759.099419948703/8.0),
+ REAL_CONST(32777.038552845901/8.0),
+ REAL_CONST(32794.980140636464/8.0),
+ REAL_CONST(32812.924182648792/8.0),
+ REAL_CONST(32830.87067821173/8.0),
+ REAL_CONST(32848.819626654593/8.0),
+ REAL_CONST(32866.77102730715/8.0),
+ REAL_CONST(32884.724879499619/8.0),
+ REAL_CONST(32902.681182562686/8.0),
+ REAL_CONST(32920.639935827494/8.0),
+ REAL_CONST(32938.601138625643/8.0),
+ REAL_CONST(32956.56479028918/8.0),
+ REAL_CONST(32974.530890150607/8.0),
+ REAL_CONST(32992.499437542894/8.0),
+ REAL_CONST(33010.470431799447/8.0),
+ REAL_CONST(33028.443872254145/8.0),
+ REAL_CONST(33046.419758241311/8.0),
+ REAL_CONST(33064.39808909571/8.0),
+ REAL_CONST(33082.378864152583/8.0),
+ REAL_CONST(33100.36208274759/8.0),
+ REAL_CONST(33118.347744216881/8.0),
+ REAL_CONST(33136.335847897026/8.0),
+ REAL_CONST(33154.326393125062/8.0),
+ REAL_CONST(33172.31937923847/8.0),
+ REAL_CONST(33190.314805575174/8.0),
+ REAL_CONST(33208.312671473555/8.0),
+ REAL_CONST(33226.312976272442/8.0),
+ REAL_CONST(33244.315719311111/8.0),
+ REAL_CONST(33262.320899929284/8.0),
+ REAL_CONST(33280.328517467125/8.0),
+ REAL_CONST(33298.33857126526/8.0),
+ REAL_CONST(33316.351060664747/8.0),
+ REAL_CONST(33334.365985007091/8.0),
+ REAL_CONST(33352.383343634239/8.0),
+ REAL_CONST(33370.403135888591/8.0),
+ REAL_CONST(33388.42536111299/8.0),
+ REAL_CONST(33406.450018650721/8.0),
+ REAL_CONST(33424.477107845501/8.0),
+ REAL_CONST(33442.506628041512/8.0),
+ REAL_CONST(33460.53857858335/8.0),
+ REAL_CONST(33478.572958816083/8.0),
+ REAL_CONST(33496.609768085189/8.0),
+ REAL_CONST(33514.649005736617/8.0),
+ REAL_CONST(33532.690671116739/8.0),
+ REAL_CONST(33550.734763572356/8.0),
+ REAL_CONST(33568.781282450735/8.0),
+ REAL_CONST(33586.830227099563/8.0),
+ REAL_CONST(33604.881596866973/8.0),
+ REAL_CONST(33622.935391101528/8.0),
+ REAL_CONST(33640.991609152239/8.0),
+ REAL_CONST(33659.050250368542/8.0),
+ REAL_CONST(33677.111314100322/8.0),
+ REAL_CONST(33695.174799697881/8.0),
+ REAL_CONST(33713.240706511984/8.0),
+ REAL_CONST(33731.309033893805/8.0),
+ REAL_CONST(33749.37978119497/8.0),
+ REAL_CONST(33767.452947767531/8.0),
+ REAL_CONST(33785.528532963974/8.0),
+ REAL_CONST(33803.606536137209/8.0),
+ REAL_CONST(33821.686956640602/8.0),
+ REAL_CONST(33839.769793827938/8.0),
+ REAL_CONST(33857.855047053425/8.0),
+ REAL_CONST(33875.942715671707/8.0),
+ REAL_CONST(33894.032799037872/8.0),
+ REAL_CONST(33912.125296507431/8.0),
+ REAL_CONST(33930.220207436316/8.0),
+ REAL_CONST(33948.317531180888/8.0),
+ REAL_CONST(33966.417267097961/8.0),
+ REAL_CONST(33984.519414544746/8.0),
+ REAL_CONST(34002.623972878901/8.0),
+ REAL_CONST(34020.730941458511/8.0),
+ REAL_CONST(34038.840319642077/8.0),
+ REAL_CONST(34056.952106788536/8.0),
+ REAL_CONST(34075.066302257255/8.0),
+ REAL_CONST(34093.182905408015/8.0),
+ REAL_CONST(34111.301915601027/8.0),
+ REAL_CONST(34129.42333219693/8.0),
+ REAL_CONST(34147.547154556785/8.0),
+ REAL_CONST(34165.673382042078/8.0),
+ REAL_CONST(34183.80201401472/8.0),
+ REAL_CONST(34201.933049837033/8.0),
+ REAL_CONST(34220.06648887178/8.0),
+ REAL_CONST(34238.202330482141/8.0),
+ REAL_CONST(34256.340574031703/8.0),
+ REAL_CONST(34274.481218884495/8.0),
+ REAL_CONST(34292.624264404949/8.0),
+ REAL_CONST(34310.769709957938/8.0),
+ REAL_CONST(34328.91755490873/8.0),
+ REAL_CONST(34347.067798623029/8.0),
+ REAL_CONST(34365.220440466954/8.0),
+ REAL_CONST(34383.375479807051/8.0),
+ REAL_CONST(34401.532916010263/8.0),
+ REAL_CONST(34419.692748443973/8.0),
+ REAL_CONST(34437.854976475966/8.0),
+ REAL_CONST(34456.01959947445/8.0),
+ REAL_CONST(34474.18661680806/8.0),
+ REAL_CONST(34492.356027845817/8.0),
+ REAL_CONST(34510.527831957188/8.0),
+ REAL_CONST(34528.702028512052/8.0),
+ REAL_CONST(34546.878616880676/8.0),
+ REAL_CONST(34565.05759643377/8.0),
+ REAL_CONST(34583.238966542449/8.0),
+ REAL_CONST(34601.422726578232/8.0),
+ REAL_CONST(34619.608875913065/8.0),
+ REAL_CONST(34637.797413919296/8.0),
+ REAL_CONST(34655.988339969692/8.0),
+ REAL_CONST(34674.181653437423/8.0),
+ REAL_CONST(34692.37735369608/8.0),
+ REAL_CONST(34710.575440119668/8.0),
+ REAL_CONST(34728.775912082579/8.0),
+ REAL_CONST(34746.978768959649/8.0),
+ REAL_CONST(34765.184010126082/8.0),
+ REAL_CONST(34783.391634957537/8.0),
+ REAL_CONST(34801.60164283005/8.0),
+ REAL_CONST(34819.814033120063/8.0),
+ REAL_CONST(34838.028805204456/8.0),
+ REAL_CONST(34856.24595846048/8.0),
+ REAL_CONST(34874.465492265823/8.0),
+ REAL_CONST(34892.687405998557/8.0),
+ REAL_CONST(34910.911699037177/8.0),
+ REAL_CONST(34929.138370760564/8.0),
+ REAL_CONST(34947.367420548027/8.0),
+ REAL_CONST(34965.598847779271/8.0),
+ REAL_CONST(34983.832651834389/8.0),
+ REAL_CONST(35002.068832093908/8.0),
+ REAL_CONST(35020.307387938738/8.0),
+ REAL_CONST(35038.548318750189/8.0),
+ REAL_CONST(35056.79162390998/8.0),
+ REAL_CONST(35075.03730280025/8.0),
+ REAL_CONST(35093.285354803513/8.0),
+ REAL_CONST(35111.535779302685/8.0),
+ REAL_CONST(35129.788575681116/8.0),
+ REAL_CONST(35148.043743322516/8.0),
+ REAL_CONST(35166.301281611013/8.0),
+ REAL_CONST(35184.561189931141/8.0),
+ REAL_CONST(35202.823467667826/8.0),
+ REAL_CONST(35221.088114206388/8.0),
+ REAL_CONST(35239.355128932555/8.0),
+ REAL_CONST(35257.624511232447/8.0),
+ REAL_CONST(35275.896260492584/8.0),
+ REAL_CONST(35294.170376099886/8.0),
+ REAL_CONST(35312.446857441668/8.0),
+ REAL_CONST(35330.725703905628/8.0),
+ REAL_CONST(35349.006914879887/8.0),
+ REAL_CONST(35367.290489752944/8.0),
+ REAL_CONST(35385.576427913686/8.0),
+ REAL_CONST(35403.864728751418/8.0),
+ REAL_CONST(35422.155391655811/8.0),
+ REAL_CONST(35440.448416016967/8.0),
+ REAL_CONST(35458.743801225341/8.0),
+ REAL_CONST(35477.041546671804/8.0),
+ REAL_CONST(35495.341651747622/8.0),
+ REAL_CONST(35513.644115844436/8.0),
+ REAL_CONST(35531.948938354304/8.0),
+ REAL_CONST(35550.256118669655/8.0),
+ REAL_CONST(35568.565656183309/8.0),
+ REAL_CONST(35586.877550288496/8.0),
+ REAL_CONST(35605.191800378816/8.0),
+ REAL_CONST(35623.508405848268/8.0),
+ REAL_CONST(35641.827366091238/8.0),
+ REAL_CONST(35660.148680502505/8.0),
+ REAL_CONST(35678.472348477233/8.0),
+ REAL_CONST(35696.798369410979/8.0),
+ REAL_CONST(35715.126742699678/8.0),
+ REAL_CONST(35733.457467739659/8.0),
+ REAL_CONST(35751.790543927644/8.0),
+ REAL_CONST(35770.125970660738/8.0),
+ REAL_CONST(35788.46374733642/8.0),
+ REAL_CONST(35806.803873352568/8.0),
+ REAL_CONST(35825.146348107453/8.0),
+ REAL_CONST(35843.49117099971/8.0),
+ REAL_CONST(35861.838341428367/8.0),
+ REAL_CONST(35880.187858792851/8.0),
+ REAL_CONST(35898.539722492955/8.0),
+ REAL_CONST(35916.893931928862/8.0),
+ REAL_CONST(35935.250486501129/8.0),
+ REAL_CONST(35953.609385610718/8.0),
+ REAL_CONST(35971.970628658957/8.0),
+ REAL_CONST(35990.334215047558/8.0),
+ REAL_CONST(36008.700144178612/8.0),
+ REAL_CONST(36027.068415454596/8.0),
+ REAL_CONST(36045.439028278372/8.0),
+ REAL_CONST(36063.811982053165/8.0),
+ REAL_CONST(36082.187276182609/8.0),
+ REAL_CONST(36100.564910070694/8.0),
+ REAL_CONST(36118.944883121789/8.0),
+ REAL_CONST(36137.327194740654/8.0),
+ REAL_CONST(36155.711844332429/8.0),
+ REAL_CONST(36174.098831302617/8.0),
+ REAL_CONST(36192.488155057115/8.0),
+ REAL_CONST(36210.87981500219/8.0),
+ REAL_CONST(36229.273810544473/8.0),
+ REAL_CONST(36247.670141091003/8.0),
+ REAL_CONST(36266.068806049167/8.0),
+ REAL_CONST(36284.469804826738/8.0),
+ REAL_CONST(36302.873136831862/8.0),
+ REAL_CONST(36321.278801473069/8.0),
+ REAL_CONST(36339.686798159251/8.0),
+ REAL_CONST(36358.097126299683/8.0),
+ REAL_CONST(36376.509785304013/8.0),
+ REAL_CONST(36394.924774582258/8.0),
+ REAL_CONST(36413.342093544816/8.0),
+ REAL_CONST(36431.761741602444/8.0),
+ REAL_CONST(36450.183718166292/8.0),
+ REAL_CONST(36468.608022647859/8.0),
+ REAL_CONST(36487.034654459028/8.0),
+ REAL_CONST(36505.463613012063/8.0),
+ REAL_CONST(36523.894897719583/8.0),
+ REAL_CONST(36542.328507994578/8.0),
+ REAL_CONST(36560.764443250409/8.0),
+ REAL_CONST(36579.202702900831/8.0),
+ REAL_CONST(36597.643286359926/8.0),
+ REAL_CONST(36616.086193042182/8.0),
+ REAL_CONST(36634.531422362437/8.0),
+ REAL_CONST(36652.978973735895/8.0),
+ REAL_CONST(36671.428846578143/8.0),
+ REAL_CONST(36689.881040305125/8.0),
+ REAL_CONST(36708.335554333149/8.0),
+ REAL_CONST(36726.792388078902/8.0),
+ REAL_CONST(36745.251540959427/8.0),
+ REAL_CONST(36763.713012392138/8.0),
+ REAL_CONST(36782.176801794812/8.0),
+ REAL_CONST(36800.642908585593/8.0),
+ REAL_CONST(36819.111332182983/8.0),
+ REAL_CONST(36837.582072005869/8.0),
+ REAL_CONST(36856.055127473483/8.0),
+ REAL_CONST(36874.530498005421/8.0),
+ REAL_CONST(36893.008183021651/8.0),
+ REAL_CONST(36911.488181942506/8.0),
+ REAL_CONST(36929.970494188674/8.0),
+ REAL_CONST(36948.455119181206/8.0),
+ REAL_CONST(36966.942056341519/8.0),
+ REAL_CONST(36985.431305091392/8.0),
+ REAL_CONST(37003.922864852961/8.0),
+ REAL_CONST(37022.416735048733/8.0),
+ REAL_CONST(37040.912915101559/8.0),
+ REAL_CONST(37059.411404434657/8.0),
+ REAL_CONST(37077.91220247162/8.0),
+ REAL_CONST(37096.415308636388/8.0),
+ REAL_CONST(37114.920722353243/8.0),
+ REAL_CONST(37133.428443046862/8.0),
+ REAL_CONST(37151.938470142253/8.0),
+ REAL_CONST(37170.450803064785/8.0),
+ REAL_CONST(37188.965441240209/8.0),
+ REAL_CONST(37207.482384094597/8.0),
+ REAL_CONST(37226.001631054402/8.0),
+ REAL_CONST(37244.523181546429/8.0),
+ REAL_CONST(37263.047034997842/8.0),
+ REAL_CONST(37281.573190836149/8.0),
+ REAL_CONST(37300.101648489224/8.0),
+ REAL_CONST(37318.632407385296/8.0),
+ REAL_CONST(37337.165466952945/8.0),
+ REAL_CONST(37355.700826621112/8.0),
+ REAL_CONST(37374.238485819085/8.0),
+ REAL_CONST(37392.778443976509/8.0),
+ REAL_CONST(37411.320700523385/8.0),
+ REAL_CONST(37429.865254890057/8.0),
+ REAL_CONST(37448.412106507232/8.0),
+ REAL_CONST(37466.961254805974/8.0),
+ REAL_CONST(37485.512699217681/8.0),
+ REAL_CONST(37504.066439174116/8.0),
+ REAL_CONST(37522.622474107404/8.0),
+ REAL_CONST(37541.180803449992/8.0),
+ REAL_CONST(37559.741426634704/8.0),
+ REAL_CONST(37578.304343094693/8.0),
+ REAL_CONST(37596.869552263488/8.0),
+ REAL_CONST(37615.43705357494/8.0),
+ REAL_CONST(37634.006846463279/8.0),
+ REAL_CONST(37652.578930363044/8.0),
+ REAL_CONST(37671.153304709165/8.0),
+ REAL_CONST(37689.729968936896/8.0),
+ REAL_CONST(37708.308922481847/8.0),
+ REAL_CONST(37726.890164779965/8.0),
+ REAL_CONST(37745.473695267559/8.0),
+ REAL_CONST(37764.059513381275/8.0),
+ REAL_CONST(37782.647618558112/8.0),
+ REAL_CONST(37801.238010235415/8.0),
+ REAL_CONST(37819.830687850859/8.0),
+ REAL_CONST(37838.425650842495/8.0),
+ REAL_CONST(37857.022898648691/8.0),
+ REAL_CONST(37875.622430708172/8.0),
+ REAL_CONST(37894.224246460013/8.0),
+ REAL_CONST(37912.828345343616/8.0),
+ REAL_CONST(37931.434726798747/8.0),
+ REAL_CONST(37950.043390265506/8.0),
+ REAL_CONST(37968.654335184328/8.0),
+ REAL_CONST(37987.267560995999/8.0),
+ REAL_CONST(38005.883067141665/8.0),
+ REAL_CONST(38024.500853062775/8.0),
+ REAL_CONST(38043.120918201159/8.0),
+ REAL_CONST(38061.743261998963/8.0),
+ REAL_CONST(38080.367883898682/8.0),
+ REAL_CONST(38098.994783343158/8.0),
+ REAL_CONST(38117.623959775563/8.0),
+ REAL_CONST(38136.255412639417/8.0),
+ REAL_CONST(38154.889141378575/8.0),
+ REAL_CONST(38173.525145437234/8.0),
+ REAL_CONST(38192.163424259939/8.0),
+ REAL_CONST(38210.803977291551/8.0),
+ REAL_CONST(38229.446803977284/8.0),
+ REAL_CONST(38248.091903762703/8.0),
+ REAL_CONST(38266.739276093685/8.0),
+ REAL_CONST(38285.388920416466/8.0),
+ REAL_CONST(38304.040836177606/8.0),
+ REAL_CONST(38322.695022824002/8.0),
+ REAL_CONST(38341.351479802899/8.0),
+ REAL_CONST(38360.010206561863/8.0),
+ REAL_CONST(38378.671202548816/8.0),
+ REAL_CONST(38397.334467211993/8.0),
+ REAL_CONST(38415.999999999978/8.0),
+ REAL_CONST(38434.667800361683/8.0),
+ REAL_CONST(38453.33786774637/8.0),
+ REAL_CONST(38472.010201603611/8.0),
+ REAL_CONST(38490.684801383337/8.0),
+ REAL_CONST(38509.361666535784/8.0),
+ REAL_CONST(38528.040796511552/8.0),
+ REAL_CONST(38546.722190761553/8.0),
+ REAL_CONST(38565.405848737035/8.0),
+ REAL_CONST(38584.091769889594/8.0),
+ REAL_CONST(38602.779953671132/8.0),
+ REAL_CONST(38621.470399533908/8.0),
+ REAL_CONST(38640.163106930493/8.0),
+ REAL_CONST(38658.858075313794/8.0),
+ REAL_CONST(38677.555304137059/8.0),
+ REAL_CONST(38696.254792853862/8.0),
+ REAL_CONST(38714.956540918094/8.0),
+ REAL_CONST(38733.660547783991/8.0),
+ REAL_CONST(38752.366812906112/8.0),
+ REAL_CONST(38771.075335739348/8.0),
+ REAL_CONST(38789.78611573892/8.0),
+ REAL_CONST(38808.499152360368/8.0),
+ REAL_CONST(38827.214445059573/8.0),
+ REAL_CONST(38845.931993292739/8.0),
+ REAL_CONST(38864.651796516388/8.0),
+ REAL_CONST(38883.373854187383/8.0),
+ REAL_CONST(38902.098165762916/8.0),
+ REAL_CONST(38920.824730700486/8.0),
+ REAL_CONST(38939.553548457938/8.0),
+ REAL_CONST(38958.284618493431/8.0),
+ REAL_CONST(38977.017940265461/8.0),
+ REAL_CONST(38995.753513232834/8.0),
+ REAL_CONST(39014.491336854699/8.0),
+ REAL_CONST(39033.231410590517/8.0),
+ REAL_CONST(39051.973733900079/8.0),
+ REAL_CONST(39070.718306243485/8.0),
+ REAL_CONST(39089.465127081188/8.0),
+ REAL_CONST(39108.214195873945/8.0),
+ REAL_CONST(39126.965512082832/8.0),
+ REAL_CONST(39145.719075169261/8.0),
+ REAL_CONST(39164.474884594965/8.0),
+ REAL_CONST(39183.232939821988/8.0),
+ REAL_CONST(39201.99324031271/8.0),
+ REAL_CONST(39220.755785529815/8.0),
+ REAL_CONST(39239.52057493633/8.0),
+ REAL_CONST(39258.287607995589/8.0),
+ REAL_CONST(39277.056884171245/8.0),
+ REAL_CONST(39295.828402927284/8.0),
+ REAL_CONST(39314.602163728006/8.0),
+ REAL_CONST(39333.378166038019/8.0),
+ REAL_CONST(39352.15640932227/8.0),
+ REAL_CONST(39370.936893046004/8.0),
+ REAL_CONST(39389.719616674811/8.0),
+ REAL_CONST(39408.504579674584/8.0),
+ REAL_CONST(39427.291781511522/8.0),
+ REAL_CONST(39446.081221652174/8.0),
+ REAL_CONST(39464.872899563372/8.0),
+ REAL_CONST(39483.666814712291/8.0),
+ REAL_CONST(39502.462966566411/8.0),
+ REAL_CONST(39521.261354593538/8.0),
+ REAL_CONST(39540.06197826178/8.0),
+ REAL_CONST(39558.864837039568/8.0),
+ REAL_CONST(39577.669930395656/8.0),
+ REAL_CONST(39596.47725779911/8.0),
+ REAL_CONST(39615.286818719302/8.0),
+ REAL_CONST(39634.098612625923/8.0),
+ REAL_CONST(39652.912638988993/8.0),
+ REAL_CONST(39671.728897278823/8.0),
+ REAL_CONST(39690.547386966064/8.0),
+ REAL_CONST(39709.368107521652/8.0),
+ REAL_CONST(39728.191058416858/8.0),
+ REAL_CONST(39747.016239123259/8.0),
+ REAL_CONST(39765.84364911275/8.0),
+ REAL_CONST(39784.673287857528/8.0),
+ REAL_CONST(39803.505154830105/8.0),
+ REAL_CONST(39822.339249503319/8.0),
+ REAL_CONST(39841.175571350293/8.0),
+ REAL_CONST(39860.014119844491/8.0),
+ REAL_CONST(39878.854894459677/8.0),
+ REAL_CONST(39897.697894669909/8.0),
+ REAL_CONST(39916.54311994958/8.0),
+ REAL_CONST(39935.390569773372/8.0),
+ REAL_CONST(39954.240243616303/8.0),
+ REAL_CONST(39973.092140953675/8.0),
+ REAL_CONST(39991.946261261117/8.0),
+ REAL_CONST(40010.802604014549/8.0),
+ REAL_CONST(40029.661168690225/8.0),
+ REAL_CONST(40048.521954764678/8.0),
+ REAL_CONST(40067.384961714779/8.0),
+ REAL_CONST(40086.250189017679/8.0),
+ REAL_CONST(40105.117636150855/8.0),
+ REAL_CONST(40123.98730259209/8.0),
+ REAL_CONST(40142.859187819471/8.0),
+ REAL_CONST(40161.733291311379/8.0),
+ REAL_CONST(40180.609612546526/8.0),
+ REAL_CONST(40199.488151003912/8.0),
+ REAL_CONST(40218.368906162854/8.0),
+ REAL_CONST(40237.25187750296/8.0),
+ REAL_CONST(40256.137064504153/8.0),
+ REAL_CONST(40275.024466646668/8.0),
+ REAL_CONST(40293.914083411029/8.0),
+ REAL_CONST(40312.805914278084/8.0),
+ REAL_CONST(40331.699958728961/8.0),
+ REAL_CONST(40350.596216245103/8.0),
+ REAL_CONST(40369.494686308273/8.0),
+ REAL_CONST(40388.39536840051/8.0),
+ REAL_CONST(40407.298262004173/8.0),
+ REAL_CONST(40426.20336660192/8.0),
+ REAL_CONST(40445.110681676706/8.0),
+ REAL_CONST(40464.020206711793/8.0),
+ REAL_CONST(40482.931941190756/8.0),
+ REAL_CONST(40501.845884597446/8.0),
+ REAL_CONST(40520.762036416032/8.0),
+ REAL_CONST(40539.680396130985/8.0),
+ REAL_CONST(40558.600963227072/8.0),
+ REAL_CONST(40577.523737189367/8.0),
+ REAL_CONST(40596.448717503234/8.0),
+ REAL_CONST(40615.375903654342/8.0),
+ REAL_CONST(40634.305295128659/8.0),
+ REAL_CONST(40653.236891412453/8.0),
+ REAL_CONST(40672.170691992294/8.0),
+ REAL_CONST(40691.106696355047/8.0),
+ REAL_CONST(40710.044903987873/8.0),
+ REAL_CONST(40728.985314378238/8.0),
+ REAL_CONST(40747.927927013901/8.0),
+ REAL_CONST(40766.872741382918/8.0),
+ REAL_CONST(40785.819756973651/8.0),
+ REAL_CONST(40804.768973274746/8.0),
+ REAL_CONST(40823.720389775161/8.0),
+ REAL_CONST(40842.674005964131/8.0),
+ REAL_CONST(40861.629821331211/8.0),
+ REAL_CONST(40880.587835366234/8.0),
+ REAL_CONST(40899.548047559321/8.0),
+ REAL_CONST(40918.510457400931/8.0),
+ REAL_CONST(40937.475064381761/8.0),
+ REAL_CONST(40956.441867992849/8.0),
+ REAL_CONST(40975.410867725499/8.0),
+ REAL_CONST(40994.382063071331/8.0),
+ REAL_CONST(41013.355453522236/8.0),
+ REAL_CONST(41032.331038570417/8.0),
+ REAL_CONST(41051.308817708363/8.0),
+ REAL_CONST(41070.288790428858/8.0),
+ REAL_CONST(41089.270956224987/8.0),
+ REAL_CONST(41108.255314590111/8.0),
+ REAL_CONST(41127.241865017888/8.0),
+ REAL_CONST(41146.23060700229/8.0),
+ REAL_CONST(41165.221540037543/8.0),
+ REAL_CONST(41184.214663618193/8.0),
+ REAL_CONST(41203.209977239079/8.0),
+ REAL_CONST(41222.207480395307/8.0),
+ REAL_CONST(41241.207172582297/8.0),
+ REAL_CONST(41260.209053295752/8.0),
+ REAL_CONST(41279.213122031659/8.0),
+ REAL_CONST(41298.219378286303/8.0),
+ REAL_CONST(41317.227821556255/8.0),
+ REAL_CONST(41336.23845133838/8.0),
+ REAL_CONST(41355.251267129832/8.0),
+ REAL_CONST(41374.266268428037/8.0),
+ REAL_CONST(41393.283454730743/8.0),
+ REAL_CONST(41412.302825535953/8.0),
+ REAL_CONST(41431.324380341983/8.0),
+ REAL_CONST(41450.348118647416/8.0),
+ REAL_CONST(41469.374039951144/8.0),
+ REAL_CONST(41488.402143752326/8.0),
+ REAL_CONST(41507.432429550427/8.0),
+ REAL_CONST(41526.464896845187/8.0),
+ REAL_CONST(41545.499545136627/8.0),
+ REAL_CONST(41564.536373925075/8.0),
+ REAL_CONST(41583.575382711126/8.0),
+ REAL_CONST(41602.616570995662/8.0),
+ REAL_CONST(41621.659938279874/8.0),
+ REAL_CONST(41640.705484065205/8.0),
+ REAL_CONST(41659.753207853406/8.0),
+ REAL_CONST(41678.803109146495/8.0),
+ REAL_CONST(41697.855187446803/8.0),
+ REAL_CONST(41716.909442256911/8.0),
+ REAL_CONST(41735.965873079709/8.0),
+ REAL_CONST(41755.02447941836/8.0),
+ REAL_CONST(41774.085260776315/8.0),
+ REAL_CONST(41793.148216657297/8.0),
+ REAL_CONST(41812.213346565331/8.0),
+ REAL_CONST(41831.280650004708/8.0),
+ REAL_CONST(41850.350126480014/8.0),
+ REAL_CONST(41869.421775496106/8.0),
+ REAL_CONST(41888.495596558132/8.0),
+ REAL_CONST(41907.571589171515/8.0),
+ REAL_CONST(41926.649752841957/8.0),
+ REAL_CONST(41945.730087075463/8.0),
+ REAL_CONST(41964.812591378286/8.0),
+ REAL_CONST(41983.897265256979/8.0),
+ REAL_CONST(42002.984108218378/8.0),
+ REAL_CONST(42022.073119769593/8.0),
+ REAL_CONST(42041.164299418015/8.0),
+ REAL_CONST(42060.257646671307/8.0),
+ REAL_CONST(42079.353161037419/8.0),
+ REAL_CONST(42098.450842024591/8.0),
+ REAL_CONST(42117.550689141324/8.0),
+ REAL_CONST(42136.652701896404/8.0),
+ REAL_CONST(42155.756879798893/8.0),
+ REAL_CONST(42174.863222358137/8.0),
+ REAL_CONST(42193.971729083758/8.0),
+ REAL_CONST(42213.082399485655/8.0),
+ REAL_CONST(42232.195233074002/8.0),
+ REAL_CONST(42251.310229359246/8.0),
+ REAL_CONST(42270.427387852127/8.0),
+ REAL_CONST(42289.546708063644/8.0),
+ REAL_CONST(42308.668189505079/8.0),
+ REAL_CONST(42327.791831687995/8.0),
+ REAL_CONST(42346.917634124227/8.0),
+ REAL_CONST(42366.045596325886/8.0),
+ REAL_CONST(42385.175717805352/8.0),
+ REAL_CONST(42404.307998075295/8.0),
+ REAL_CONST(42423.442436648642/8.0),
+ REAL_CONST(42442.579033038608/8.0),
+ REAL_CONST(42461.717786758672/8.0),
+ REAL_CONST(42480.858697322597/8.0),
+ REAL_CONST(42500.001764244422/8.0),
+ REAL_CONST(42519.146987038446/8.0),
+ REAL_CONST(42538.294365219248/8.0),
+ REAL_CONST(42557.443898301688/8.0),
+ REAL_CONST(42576.595585800882/8.0),
+ REAL_CONST(42595.749427232236/8.0),
+ REAL_CONST(42614.90542211142/8.0),
+ REAL_CONST(42634.063569954378/8.0),
+ REAL_CONST(42653.223870277317/8.0),
+ REAL_CONST(42672.386322596729/8.0),
+ REAL_CONST(42691.55092642938/8.0),
+ REAL_CONST(42710.717681292292/8.0),
+ REAL_CONST(42729.886586702756/8.0),
+ REAL_CONST(42749.057642178363/8.0),
+ REAL_CONST(42768.23084723694/8.0),
+ REAL_CONST(42787.406201396603/8.0),
+ REAL_CONST(42806.58370417574/8.0),
+ REAL_CONST(42825.76335509299/8.0),
+ REAL_CONST(42844.945153667286/8.0),
+ REAL_CONST(42864.129099417805/8.0),
+ REAL_CONST(42883.315191864014/8.0),
+ REAL_CONST(42902.503430525649/8.0),
+ REAL_CONST(42921.693814922692/8.0),
+ REAL_CONST(42940.88634457541/8.0),
+ REAL_CONST(42960.081019004348/8.0),
+ REAL_CONST(42979.277837730297/8.0),
+ REAL_CONST(42998.476800274322/8.0),
+ REAL_CONST(43017.677906157769/8.0),
+ REAL_CONST(43036.881154902228/8.0),
+ REAL_CONST(43056.086546029583/8.0),
+ REAL_CONST(43075.294079061961/8.0),
+ REAL_CONST(43094.503753521763/8.0),
+ REAL_CONST(43113.715568931671/8.0),
+ REAL_CONST(43132.929524814601/8.0),
+ REAL_CONST(43152.145620693766/8.0),
+ REAL_CONST(43171.363856092619/8.0),
+ REAL_CONST(43190.584230534907/8.0),
+ REAL_CONST(43209.806743544621/8.0),
+ REAL_CONST(43229.031394646016/8.0),
+ REAL_CONST(43248.258183363621/8.0),
+ REAL_CONST(43267.487109222224/8.0),
+ REAL_CONST(43286.718171746885/8.0),
+ REAL_CONST(43305.951370462906/8.0),
+ REAL_CONST(43325.186704895881/8.0),
+ REAL_CONST(43344.42417457165/8.0),
+ REAL_CONST(43363.663779016322/8.0),
+ REAL_CONST(43382.905517756262/8.0),
+ REAL_CONST(43402.149390318104/8.0),
+ REAL_CONST(43421.395396228749/8.0),
+ REAL_CONST(43440.643535015348/8.0),
+ REAL_CONST(43459.89380620532/8.0),
+ REAL_CONST(43479.146209326354/8.0),
+ REAL_CONST(43498.400743906379/8.0),
+ REAL_CONST(43517.657409473606/8.0),
+ REAL_CONST(43536.916205556496/8.0),
+ REAL_CONST(43556.177131683784/8.0),
+ REAL_CONST(43575.44018738444/8.0),
+ REAL_CONST(43594.705372187724/8.0),
+ REAL_CONST(43613.972685623135/8.0),
+ REAL_CONST(43633.242127220445/8.0),
+ REAL_CONST(43652.513696509668/8.0),
+ REAL_CONST(43671.787393021099/8.0),
+ REAL_CONST(43691.063216285271/8.0),
+ REAL_CONST(43710.341165833001/8.0),
+ REAL_CONST(43729.621241195346/8.0),
+ REAL_CONST(43748.903441903625/8.0),
+ REAL_CONST(43768.187767489413/8.0),
+ REAL_CONST(43787.474217484552/8.0),
+ REAL_CONST(43806.762791421126/8.0),
+ REAL_CONST(43826.053488831501/8.0),
+ REAL_CONST(43845.346309248278/8.0),
+ REAL_CONST(43864.641252204325/8.0),
+ REAL_CONST(43883.938317232765/8.0),
+ REAL_CONST(43903.237503866971/8.0),
+ REAL_CONST(43922.538811640596/8.0),
+ REAL_CONST(43941.842240087513/8.0),
+ REAL_CONST(43961.147788741881/8.0),
+ REAL_CONST(43980.455457138101/8.0),
+ REAL_CONST(43999.765244810835/8.0),
+ REAL_CONST(44019.077151295001/8.0),
+ REAL_CONST(44038.391176125755/8.0),
+ REAL_CONST(44057.70731883854/8.0),
+ REAL_CONST(44077.02557896902/8.0),
+ REAL_CONST(44096.345956053141/8.0),
+ REAL_CONST(44115.668449627083/8.0),
+ REAL_CONST(44134.993059227287/8.0),
+ REAL_CONST(44154.319784390456/8.0),
+ REAL_CONST(44173.648624653535/8.0),
+ REAL_CONST(44192.979579553728/8.0),
+ REAL_CONST(44212.312648628489/8.0),
+ REAL_CONST(44231.647831415532/8.0),
+ REAL_CONST(44250.985127452805/8.0),
+ REAL_CONST(44270.324536278538/8.0),
+ REAL_CONST(44289.666057431183/8.0),
+ REAL_CONST(44309.009690449464/8.0),
+ REAL_CONST(44328.355434872348/8.0),
+ REAL_CONST(44347.703290239064/8.0),
+ REAL_CONST(44367.053256089079/8.0),
+ REAL_CONST(44386.405331962109/8.0),
+ REAL_CONST(44405.759517398139/8.0),
+ REAL_CONST(44425.115811937387/8.0),
+ REAL_CONST(44444.474215120332/8.0),
+ REAL_CONST(44463.834726487694/8.0),
+ REAL_CONST(44483.197345580462/8.0),
+ REAL_CONST(44502.562071939843/8.0),
+ REAL_CONST(44521.928905107328/8.0),
+ REAL_CONST(44541.297844624634/8.0),
+ REAL_CONST(44560.668890033732/8.0),
+ REAL_CONST(44580.042040876848/8.0),
+ REAL_CONST(44599.417296696454/8.0),
+ REAL_CONST(44618.794657035272/8.0),
+ REAL_CONST(44638.174121436256/8.0),
+ REAL_CONST(44657.555689442641/8.0),
+ REAL_CONST(44676.939360597877/8.0),
+ REAL_CONST(44696.325134445673/8.0),
+ REAL_CONST(44715.713010530002/8.0),
+ REAL_CONST(44735.102988395054/8.0),
+ REAL_CONST(44754.495067585296/8.0),
+ REAL_CONST(44773.88924764542/8.0),
+ REAL_CONST(44793.285528120374/8.0),
+ REAL_CONST(44812.683908555344/8.0),
+ REAL_CONST(44832.084388495779/8.0),
+ REAL_CONST(44851.486967487363/8.0),
+ REAL_CONST(44870.891645076015/8.0),
+ REAL_CONST(44890.298420807922/8.0),
+ REAL_CONST(44909.707294229491/8.0),
+ REAL_CONST(44929.118264887409/8.0),
+ REAL_CONST(44948.531332328566/8.0),
+ REAL_CONST(44967.946496100136/8.0),
+ REAL_CONST(44987.363755749502/8.0),
+ REAL_CONST(45006.783110824319/8.0),
+ REAL_CONST(45026.204560872473/8.0),
+ REAL_CONST(45045.628105442098/8.0),
+ REAL_CONST(45065.053744081561/8.0),
+ REAL_CONST(45084.48147633949/8.0),
+ REAL_CONST(45103.911301764747/8.0),
+ REAL_CONST(45123.343219906426/8.0),
+ REAL_CONST(45142.777230313885/8.0),
+ REAL_CONST(45162.21333253671/8.0),
+ REAL_CONST(45181.651526124733/8.0),
+ REAL_CONST(45201.091810628037/8.0),
+ REAL_CONST(45220.534185596924/8.0),
+ REAL_CONST(45239.978650581965/8.0),
+ REAL_CONST(45259.425205133957/8.0),
+ REAL_CONST(45278.873848803938/8.0),
+ REAL_CONST(45298.324581143192/8.0),
+ REAL_CONST(45317.777401703235/8.0),
+ REAL_CONST(45337.232310035848/8.0),
+ REAL_CONST(45356.68930569302/8.0),
+ REAL_CONST(45376.148388226997/8.0),
+ REAL_CONST(45395.60955719027/8.0),
+ REAL_CONST(45415.072812135557/8.0),
+ REAL_CONST(45434.538152615823/8.0),
+ REAL_CONST(45454.005578184282/8.0),
+ REAL_CONST(45473.475088394356/8.0),
+ REAL_CONST(45492.946682799746/8.0),
+ REAL_CONST(45512.420360954362/8.0),
+ REAL_CONST(45531.896122412363/8.0),
+ REAL_CONST(45551.373966728155/8.0),
+ REAL_CONST(45570.853893456362/8.0),
+ REAL_CONST(45590.33590215187/8.0),
+ REAL_CONST(45609.819992369776/8.0),
+ REAL_CONST(45629.306163665438/8.0),
+ REAL_CONST(45648.794415594442/8.0),
+ REAL_CONST(45668.284747712612/8.0),
+ REAL_CONST(45687.777159576006/8.0),
+ REAL_CONST(45707.27165074092/8.0),
+ REAL_CONST(45726.768220763894/8.0),
+ REAL_CONST(45746.266869201696/8.0),
+ REAL_CONST(45765.767595611323/8.0),
+ REAL_CONST(45785.270399550034/8.0),
+ REAL_CONST(45804.775280575297/8.0),
+ REAL_CONST(45824.282238244828/8.0),
+ REAL_CONST(45843.79127211657/8.0),
+ REAL_CONST(45863.302381748719/8.0),
+ REAL_CONST(45882.815566699683/8.0),
+ REAL_CONST(45902.33082652813/8.0),
+ REAL_CONST(45921.848160792935/8.0),
+ REAL_CONST(45941.367569053225/8.0),
+ REAL_CONST(45960.889050868354/8.0),
+ REAL_CONST(45980.41260579793/8.0),
+ REAL_CONST(45999.938233401757/8.0),
+ REAL_CONST(46019.465933239902/8.0),
+ REAL_CONST(46038.995704872657/8.0),
+ REAL_CONST(46058.527547860547/8.0),
+ REAL_CONST(46078.06146176433/8.0),
+ REAL_CONST(46097.597446144995/8.0),
+ REAL_CONST(46117.135500563774/8.0),
+ REAL_CONST(46136.675624582109/8.0),
+ REAL_CONST(46156.217817761702/8.0),
+ REAL_CONST(46175.762079664462/8.0),
+ REAL_CONST(46195.308409852543/8.0),
+ REAL_CONST(46214.856807888333/8.0),
+ REAL_CONST(46234.407273334444/8.0),
+ REAL_CONST(46253.959805753715/8.0),
+ REAL_CONST(46273.51440470924/8.0),
+ REAL_CONST(46293.071069764315/8.0),
+ REAL_CONST(46312.629800482478/8.0),
+ REAL_CONST(46332.190596427499/8.0),
+ REAL_CONST(46351.753457163381/8.0),
+ REAL_CONST(46371.318382254351/8.0),
+ REAL_CONST(46390.885371264863/8.0),
+ REAL_CONST(46410.45442375962/8.0),
+ REAL_CONST(46430.025539303526/8.0),
+ REAL_CONST(46449.598717461733/8.0),
+ REAL_CONST(46469.17395779962/8.0),
+ REAL_CONST(46488.751259882782/8.0),
+ REAL_CONST(46508.33062327707/8.0),
+ REAL_CONST(46527.912047548532/8.0),
+ REAL_CONST(46547.495532263471/8.0),
+ REAL_CONST(46567.081076988397/8.0),
+ REAL_CONST(46586.668681290059/8.0),
+ REAL_CONST(46606.258344735434/8.0),
+ REAL_CONST(46625.850066891719/8.0),
+ REAL_CONST(46645.443847326351/8.0),
+ REAL_CONST(46665.039685606986/8.0),
+ REAL_CONST(46684.637581301497/8.0),
+ REAL_CONST(46704.237533978005/8.0),
+ REAL_CONST(46723.839543204842/8.0),
+ REAL_CONST(46743.443608550573/8.0),
+ REAL_CONST(46763.049729583989/8.0),
+ REAL_CONST(46782.657905874104/8.0),
+ REAL_CONST(46802.268136990162/8.0),
+ REAL_CONST(46821.880422501628/8.0),
+ REAL_CONST(46841.494761978196/8.0),
+ REAL_CONST(46861.111154989776/8.0),
+ REAL_CONST(46880.729601106526/8.0),
+ REAL_CONST(46900.350099898795/8.0),
+ REAL_CONST(46919.97265093719/8.0),
+ REAL_CONST(46939.597253792526/8.0),
+ REAL_CONST(46959.223908035841/8.0),
+ REAL_CONST(46978.852613238392/8.0),
+ REAL_CONST(46998.483368971691/8.0),
+ REAL_CONST(47018.11617480743/8.0),
+ REAL_CONST(47037.751030317551/8.0),
+ REAL_CONST(47057.387935074221/8.0),
+ REAL_CONST(47077.026888649809/8.0),
+ REAL_CONST(47096.66789061694/8.0),
+ REAL_CONST(47116.310940548428/8.0),
+ REAL_CONST(47135.956038017328/8.0),
+ REAL_CONST(47155.603182596918/8.0),
+ REAL_CONST(47175.252373860698/8.0),
+ REAL_CONST(47194.903611382375/8.0),
+ REAL_CONST(47214.556894735892/8.0),
+ REAL_CONST(47234.212223495422/8.0),
+ REAL_CONST(47253.869597235338/8.0),
+ REAL_CONST(47273.52901553025/8.0),
+ REAL_CONST(47293.19047795498/8.0),
+ REAL_CONST(47312.853984084577/8.0),
+ REAL_CONST(47332.519533494306/8.0),
+ REAL_CONST(47352.187125759658/8.0),
+ REAL_CONST(47371.856760456343/8.0),
+ REAL_CONST(47391.528437160297/8.0),
+ REAL_CONST(47411.202155447652/8.0),
+ REAL_CONST(47430.877914894787/8.0),
+ REAL_CONST(47450.555715078299/8.0),
+ REAL_CONST(47470.235555574982/8.0),
+ REAL_CONST(47489.917435961863/8.0),
+ REAL_CONST(47509.601355816201/8.0),
+ REAL_CONST(47529.287314715453/8.0),
+ REAL_CONST(47548.975312237308/8.0),
+ REAL_CONST(47568.665347959672/8.0),
+ REAL_CONST(47588.357421460656/8.0),
+ REAL_CONST(47608.051532318605/8.0),
+ REAL_CONST(47627.747680112072/8.0),
+ REAL_CONST(47647.445864419846/8.0),
+ REAL_CONST(47667.14608482091/8.0),
+ REAL_CONST(47686.848340894474/8.0),
+ REAL_CONST(47706.552632219973/8.0),
+ REAL_CONST(47726.258958377046/8.0),
+ REAL_CONST(47745.967318945557/8.0),
+ REAL_CONST(47765.677713505589/8.0),
+ REAL_CONST(47785.390141637428/8.0),
+ REAL_CONST(47805.104602921601/8.0),
+ REAL_CONST(47824.821096938824/8.0),
+ REAL_CONST(47844.539623270044/8.0),
+ REAL_CONST(47864.260181496429/8.0),
+ REAL_CONST(47883.982771199349/8.0),
+ REAL_CONST(47903.707391960394/8.0),
+ REAL_CONST(47923.434043361369/8.0),
+ REAL_CONST(47943.162724984308/8.0),
+ REAL_CONST(47962.893436411439/8.0),
+ REAL_CONST(47982.626177225218/8.0),
+ REAL_CONST(48002.36094700831/8.0),
+ REAL_CONST(48022.097745343599/8.0),
+ REAL_CONST(48041.836571814172/8.0),
+ REAL_CONST(48061.57742600335/8.0),
+ REAL_CONST(48081.32030749465/8.0),
+ REAL_CONST(48101.065215871815/8.0),
+ REAL_CONST(48120.81215071879/8.0),
+ REAL_CONST(48140.56111161974/8.0),
+ REAL_CONST(48160.312098159047/8.0),
+ REAL_CONST(48180.065109921306/8.0),
+ REAL_CONST(48199.820146491307/8.0),
+ REAL_CONST(48219.577207454073/8.0),
+ REAL_CONST(48239.336292394844/8.0),
+ REAL_CONST(48259.097400899045/8.0),
+ REAL_CONST(48278.860532552339/8.0),
+ REAL_CONST(48298.625686940592/8.0),
+ REAL_CONST(48318.392863649875/8.0),
+ REAL_CONST(48338.162062266485/8.0),
+ REAL_CONST(48357.933282376915/8.0),
+ REAL_CONST(48377.706523567889/8.0),
+ REAL_CONST(48397.481785426316/8.0),
+ REAL_CONST(48417.259067539344/8.0),
+ REAL_CONST(48437.038369494308/8.0),
+ REAL_CONST(48456.819690878765/8.0),
+ REAL_CONST(48476.603031280487/8.0),
+ REAL_CONST(48496.388390287451/8.0),
+ REAL_CONST(48516.175767487839/8.0),
+ REAL_CONST(48535.965162470042/8.0),
+ REAL_CONST(48555.756574822684/8.0),
+ REAL_CONST(48575.550004134566/8.0),
+ REAL_CONST(48595.345449994718/8.0),
+ REAL_CONST(48615.142911992378/8.0),
+ REAL_CONST(48634.942389716991/8.0),
+ REAL_CONST(48654.743882758201/8.0),
+ REAL_CONST(48674.547390705877/8.0),
+ REAL_CONST(48694.352913150084/8.0),
+ REAL_CONST(48714.160449681112/8.0),
+ REAL_CONST(48733.969999889443/8.0),
+ REAL_CONST(48753.781563365759/8.0),
+ REAL_CONST(48773.595139700978/8.0),
+ REAL_CONST(48793.410728486211/8.0),
+ REAL_CONST(48813.228329312769/8.0),
+ REAL_CONST(48833.047941772187/8.0),
+ REAL_CONST(48852.869565456189/8.0),
+ REAL_CONST(48872.693199956717/8.0),
+ REAL_CONST(48892.518844865925/8.0),
+ REAL_CONST(48912.346499776155/8.0),
+ REAL_CONST(48932.176164279976/8.0),
+ REAL_CONST(48952.007837970152/8.0),
+ REAL_CONST(48971.841520439666/8.0),
+ REAL_CONST(48991.677211281676/8.0),
+ REAL_CONST(49011.514910089587/8.0),
+ REAL_CONST(49031.354616456978/8.0),
+ REAL_CONST(49051.196329977654/8.0),
+ REAL_CONST(49071.04005024561/8.0),
+ REAL_CONST(49090.885776855059/8.0),
+ REAL_CONST(49110.733509400408/8.0),
+ REAL_CONST(49130.583247476279/8.0),
+ REAL_CONST(49150.434990677488/8.0),
+ REAL_CONST(49170.288738599062/8.0),
+ REAL_CONST(49190.144490836232/8.0),
+ REAL_CONST(49210.002246984441/8.0),
+ REAL_CONST(49229.86200663932/8.0),
+ REAL_CONST(49249.723769396718/8.0),
+ REAL_CONST(49269.587534852675/8.0),
+ REAL_CONST(49289.453302603448/8.0),
+ REAL_CONST(49309.32107224549/8.0),
+ REAL_CONST(49329.190843375451/8.0),
+ REAL_CONST(49349.062615590192/8.0),
+ REAL_CONST(49368.936388486785/8.0),
+ REAL_CONST(49388.812161662492/8.0),
+ REAL_CONST(49408.689934714785/8.0),
+ REAL_CONST(49428.569707241324/8.0),
+ REAL_CONST(49448.45147883999/8.0),
+ REAL_CONST(49468.335249108866/8.0),
+ REAL_CONST(49488.22101764621/8.0),
+ REAL_CONST(49508.108784050521/8.0),
+ REAL_CONST(49527.99854792047/8.0),
+ REAL_CONST(49547.890308854934/8.0),
+ REAL_CONST(49567.784066453009/8.0),
+ REAL_CONST(49587.679820313977/8.0),
+ REAL_CONST(49607.57757003732/8.0),
+ REAL_CONST(49627.477315222721/8.0),
+ REAL_CONST(49647.379055470075/8.0),
+ REAL_CONST(49667.28279037946/8.0),
+ REAL_CONST(49687.188519551179/8.0),
+ REAL_CONST(49707.096242585707/8.0),
+ REAL_CONST(49727.005959083741/8.0),
+ REAL_CONST(49746.917668646165/8.0),
+ REAL_CONST(49766.831370874068/8.0),
+ REAL_CONST(49786.747065368734/8.0),
+ REAL_CONST(49806.66475173166/8.0),
+ REAL_CONST(49826.584429564515/8.0),
+ REAL_CONST(49846.506098469203/8.0),
+ REAL_CONST(49866.429758047794/8.0),
+ REAL_CONST(49886.355407902578/8.0),
+ REAL_CONST(49906.283047636032/8.0),
+ REAL_CONST(49926.212676850846/8.0),
+ REAL_CONST(49946.144295149883/8.0),
+ REAL_CONST(49966.077902136225/8.0),
+ REAL_CONST(49986.013497413151/8.0),
+ REAL_CONST(50005.951080584135/8.0),
+ REAL_CONST(50025.890651252834/8.0),
+ REAL_CONST(50045.832209023123/8.0),
+ REAL_CONST(50065.775753499074/8.0),
+ REAL_CONST(50085.721284284933/8.0),
+ REAL_CONST(50105.668800985164/8.0),
+ REAL_CONST(50125.618303204428/8.0),
+ REAL_CONST(50145.569790547575/8.0),
+ REAL_CONST(50165.523262619652/8.0),
+ REAL_CONST(50185.478719025901/8.0),
+ REAL_CONST(50205.436159371769/8.0),
+ REAL_CONST(50225.395583262893/8.0),
+ REAL_CONST(50245.356990305103/8.0),
+ REAL_CONST(50265.320380104429/8.0),
+ REAL_CONST(50285.285752267104/8.0),
+ REAL_CONST(50305.253106399534/8.0),
+ REAL_CONST(50325.222442108337/8.0),
+ REAL_CONST(50345.193759000336/8.0),
+ REAL_CONST(50365.16705668252/8.0),
+ REAL_CONST(50385.142334762102/8.0),
+ REAL_CONST(50405.119592846473/8.0),
+ REAL_CONST(50425.098830543218/8.0),
+ REAL_CONST(50445.080047460127/8.0),
+ REAL_CONST(50465.063243205179/8.0),
+ REAL_CONST(50485.048417386541/8.0),
+ REAL_CONST(50505.035569612577/8.0),
+ REAL_CONST(50525.024699491856/8.0),
+ REAL_CONST(50545.015806633128/8.0),
+ REAL_CONST(50565.008890645338/8.0),
+ REAL_CONST(50585.003951137631/8.0),
+ REAL_CONST(50605.00098771933/8.0),
+ REAL_CONST(50624.999999999971/8.0),
+ REAL_CONST(50645.000987589265/8.0),
+ REAL_CONST(50665.003950097132/8.0),
+ REAL_CONST(50685.008887133677/8.0),
+ REAL_CONST(50705.015798309192/8.0),
+ REAL_CONST(50725.024683234165/8.0),
+ REAL_CONST(50745.035541519283/8.0),
+ REAL_CONST(50765.048372775411/8.0),
+ REAL_CONST(50785.063176613621/8.0),
+ REAL_CONST(50805.079952645159/8.0),
+ REAL_CONST(50825.098700481489/8.0),
+ REAL_CONST(50845.119419734241/8.0),
+ REAL_CONST(50865.142110015244/8.0),
+ REAL_CONST(50885.166770936521/8.0),
+ REAL_CONST(50905.193402110279/8.0),
+ REAL_CONST(50925.222003148934/8.0),
+ REAL_CONST(50945.252573665071/8.0),
+ REAL_CONST(50965.285113271471/8.0),
+ REAL_CONST(50985.319621581119/8.0),
+ REAL_CONST(51005.356098207172/8.0),
+ REAL_CONST(51025.394542762981/8.0),
+ REAL_CONST(51045.434954862096/8.0),
+ REAL_CONST(51065.477334118244/8.0),
+ REAL_CONST(51085.521680145357/8.0),
+ REAL_CONST(51105.567992557546/8.0),
+ REAL_CONST(51125.616270969113/8.0),
+ REAL_CONST(51145.66651499454/8.0),
+ REAL_CONST(51165.718724248516/8.0),
+ REAL_CONST(51185.772898345916/8.0),
+ REAL_CONST(51205.829036901778/8.0),
+ REAL_CONST(51225.887139531362/8.0),
+ REAL_CONST(51245.947205850105/8.0),
+ REAL_CONST(51266.009235473619/8.0),
+ REAL_CONST(51286.073228017718/8.0),
+ REAL_CONST(51306.139183098399/8.0),
+ REAL_CONST(51326.207100331856/8.0),
+ REAL_CONST(51346.276979334456/8.0),
+ REAL_CONST(51366.348819722756/8.0),
+ REAL_CONST(51386.42262111351/8.0),
+ REAL_CONST(51406.498383123653/8.0),
+ REAL_CONST(51426.57610537031/8.0),
+ REAL_CONST(51446.655787470787/8.0),
+ REAL_CONST(51466.737429042587/8.0),
+ REAL_CONST(51486.82102970338/8.0),
+ REAL_CONST(51506.906589071048/8.0),
+ REAL_CONST(51526.994106763632/8.0),
+ REAL_CONST(51547.083582399391/8.0),
+ REAL_CONST(51567.175015596738/8.0),
+ REAL_CONST(51587.268405974297/8.0),
+ REAL_CONST(51607.363753150858/8.0),
+ REAL_CONST(51627.461056745415/8.0),
+ REAL_CONST(51647.56031637713/8.0),
+ REAL_CONST(51667.661531665362/8.0),
+ REAL_CONST(51687.764702229651/8.0),
+ REAL_CONST(51707.869827689727/8.0),
+ REAL_CONST(51727.976907665499/8.0),
+ REAL_CONST(51748.085941777055/8.0),
+ REAL_CONST(51768.196929644677/8.0),
+ REAL_CONST(51788.309870888836/8.0),
+ REAL_CONST(51808.42476513017/8.0),
+ REAL_CONST(51828.541611989524/8.0),
+ REAL_CONST(51848.660411087905/8.0),
+ REAL_CONST(51868.781162046515/8.0),
+ REAL_CONST(51888.90386448674/8.0),
+ REAL_CONST(51909.028518030143/8.0),
+ REAL_CONST(51929.155122298485/8.0),
+ REAL_CONST(51949.283676913685/8.0),
+ REAL_CONST(51969.414181497872/8.0),
+ REAL_CONST(51989.546635673345/8.0),
+ REAL_CONST(52009.681039062583/8.0),
+ REAL_CONST(52029.817391288263/8.0),
+ REAL_CONST(52049.955691973213/8.0),
+ REAL_CONST(52070.095940740481/8.0),
+ REAL_CONST(52090.238137213273/8.0),
+ REAL_CONST(52110.382281014987/8.0),
+ REAL_CONST(52130.5283717692/8.0),
+ REAL_CONST(52150.676409099666/8.0),
+ REAL_CONST(52170.826392630333/8.0),
+ REAL_CONST(52190.97832198532/8.0),
+ REAL_CONST(52211.132196788931/8.0),
+ REAL_CONST(52231.288016665654/8.0),
+ REAL_CONST(52251.445781240145/8.0),
+ REAL_CONST(52271.60549013727/8.0),
+ REAL_CONST(52291.76714298204/8.0),
+ REAL_CONST(52311.930739399664/8.0),
+ REAL_CONST(52332.096279015546/8.0),
+ REAL_CONST(52352.263761455244/8.0),
+ REAL_CONST(52372.433186344519/8.0),
+ REAL_CONST(52392.604553309284/8.0),
+ REAL_CONST(52412.777861975665/8.0),
+ REAL_CONST(52432.953111969946/8.0),
+ REAL_CONST(52453.130302918595/8.0),
+ REAL_CONST(52473.309434448267/8.0),
+ REAL_CONST(52493.490506185793/8.0),
+ REAL_CONST(52513.67351775818/8.0),
+ REAL_CONST(52533.858468792605/8.0),
+ REAL_CONST(52554.045358916446/8.0),
+ REAL_CONST(52574.234187757254/8.0),
+ REAL_CONST(52594.42495494274/8.0),
+ REAL_CONST(52614.617660100812/8.0),
+ REAL_CONST(52634.812302859558/8.0),
+ REAL_CONST(52655.008882847229/8.0),
+ REAL_CONST(52675.20739969227/8.0),
+ REAL_CONST(52695.407853023295/8.0),
+ REAL_CONST(52715.610242469098/8.0),
+ REAL_CONST(52735.814567658657/8.0),
+ REAL_CONST(52756.02082822111/8.0),
+ REAL_CONST(52776.229023785803/8.0),
+ REAL_CONST(52796.439153982225/8.0),
+ REAL_CONST(52816.651218440056/8.0),
+ REAL_CONST(52836.865216789171/8.0),
+ REAL_CONST(52857.081148659599/8.0),
+ REAL_CONST(52877.29901368155/8.0),
+ REAL_CONST(52897.518811485425/8.0),
+ REAL_CONST(52917.740541701773/8.0),
+ REAL_CONST(52937.964203961354/8.0),
+ REAL_CONST(52958.18979789508/8.0),
+ REAL_CONST(52978.417323134046/8.0),
+ REAL_CONST(52998.646779309529/8.0),
+ REAL_CONST(53018.878166052978/8.0),
+ REAL_CONST(53039.111482996006/8.0),
+ REAL_CONST(53059.346729770419/8.0),
+ REAL_CONST(53079.583906008193/8.0),
+ REAL_CONST(53099.823011341483/8.0),
+ REAL_CONST(53120.0640454026/8.0),
+ REAL_CONST(53140.307007824063/8.0),
+ REAL_CONST(53160.551898238533/8.0),
+ REAL_CONST(53180.79871627887/8.0),
+ REAL_CONST(53201.047461578091/8.0),
+ REAL_CONST(53221.2981337694/8.0),
+ REAL_CONST(53241.550732486176/8.0),
+ REAL_CONST(53261.805257361964/8.0),
+ REAL_CONST(53282.061708030487/8.0),
+ REAL_CONST(53302.32008412564/8.0),
+ REAL_CONST(53322.580385281493/8.0),
+ REAL_CONST(53342.842611132299/8.0),
+ REAL_CONST(53363.106761312469/8.0),
+ REAL_CONST(53383.372835456597/8.0),
+ REAL_CONST(53403.640833199453/8.0),
+ REAL_CONST(53423.910754175973/8.0),
+ REAL_CONST(53444.18259802126/8.0),
+ REAL_CONST(53464.456364370613/8.0),
+ REAL_CONST(53484.732052859479/8.0),
+ REAL_CONST(53505.009663123499/8.0),
+ REAL_CONST(53525.289194798468/8.0),
+ REAL_CONST(53545.570647520362/8.0),
+ REAL_CONST(53565.854020925333/8.0),
+ REAL_CONST(53586.139314649699/8.0),
+ REAL_CONST(53606.426528329954/8.0),
+ REAL_CONST(53626.715661602764/8.0),
+ REAL_CONST(53647.006714104959/8.0),
+ REAL_CONST(53667.299685473547/8.0),
+ REAL_CONST(53687.59457534572/8.0),
+ REAL_CONST(53707.891383358816/8.0),
+ REAL_CONST(53728.190109150361/8.0),
+ REAL_CONST(53748.490752358055/8.0),
+ REAL_CONST(53768.793312619753/8.0),
+ REAL_CONST(53789.09778957349/8.0),
+ REAL_CONST(53809.404182857485/8.0),
+ REAL_CONST(53829.712492110106/8.0),
+ REAL_CONST(53850.022716969899/8.0),
+ REAL_CONST(53870.334857075584/8.0),
+ REAL_CONST(53890.648912066055/8.0),
+ REAL_CONST(53910.964881580367/8.0),
+ REAL_CONST(53931.28276525774/8.0),
+ REAL_CONST(53951.602562737586/8.0),
+ REAL_CONST(53971.924273659461/8.0),
+ REAL_CONST(53992.24789766311/8.0),
+ REAL_CONST(54012.57343438844/8.0),
+ REAL_CONST(54032.90088347553/8.0),
+ REAL_CONST(54053.23024456462/8.0),
+ REAL_CONST(54073.561517296133/8.0),
+ REAL_CONST(54093.894701310644/8.0),
+ REAL_CONST(54114.22979624891/8.0),
+ REAL_CONST(54134.566801751855/8.0),
+ REAL_CONST(54154.90571746057/8.0),
+ REAL_CONST(54175.246543016314/8.0),
+ REAL_CONST(54195.589278060506/8.0),
+ REAL_CONST(54215.933922234755/8.0),
+ REAL_CONST(54236.280475180814/8.0),
+ REAL_CONST(54256.628936540626/8.0),
+ REAL_CONST(54276.97930595628/8.0),
+ REAL_CONST(54297.331583070045/8.0),
+ REAL_CONST(54317.685767524359/8.0),
+ REAL_CONST(54338.041858961828/8.0),
+ REAL_CONST(54358.399857025215/8.0),
+ REAL_CONST(54378.759761357462/8.0),
+ REAL_CONST(54399.121571601667/8.0),
+ REAL_CONST(54419.485287401105/8.0),
+ REAL_CONST(54439.850908399218/8.0),
+ REAL_CONST(54460.218434239614/8.0),
+ REAL_CONST(54480.587864566056/8.0),
+ REAL_CONST(54500.95919902248/8.0),
+ REAL_CONST(54521.332437252997/8.0),
+ REAL_CONST(54541.707578901878/8.0),
+ REAL_CONST(54562.084623613555/8.0),
+ REAL_CONST(54582.46357103264/8.0),
+ REAL_CONST(54602.844420803893/8.0),
+ REAL_CONST(54623.227172572246/8.0),
+ REAL_CONST(54643.611825982807/8.0),
+ REAL_CONST(54663.998380680838/8.0),
+ REAL_CONST(54684.386836311773/8.0),
+ REAL_CONST(54704.777192521207/8.0),
+ REAL_CONST(54725.169448954897/8.0),
+ REAL_CONST(54745.563605258772/8.0),
+ REAL_CONST(54765.959661078923/8.0),
+ REAL_CONST(54786.357616061614/8.0),
+ REAL_CONST(54806.757469853255/8.0),
+ REAL_CONST(54827.159222100439/8.0),
+ REAL_CONST(54847.562872449904/8.0),
+ REAL_CONST(54867.968420548583/8.0),
+ REAL_CONST(54888.375866043534/8.0),
+ REAL_CONST(54908.785208582012/8.0),
+ REAL_CONST(54929.196447811417/8.0),
+ REAL_CONST(54949.609583379322/8.0),
+ REAL_CONST(54970.024614933463/8.0),
+ REAL_CONST(54990.441542121727/8.0),
+ REAL_CONST(55010.86036459219/8.0),
+ REAL_CONST(55031.28108199306/8.0),
+ REAL_CONST(55051.703693972733/8.0),
+ REAL_CONST(55072.128200179759/8.0),
+ REAL_CONST(55092.554600262847/8.0),
+ REAL_CONST(55112.982893870874/8.0),
+ REAL_CONST(55133.413080652877/8.0),
+ REAL_CONST(55153.845160258061/8.0),
+ REAL_CONST(55174.279132335789/8.0),
+ REAL_CONST(55194.714996535586/8.0),
+ REAL_CONST(55215.152752507143/8.0),
+ REAL_CONST(55235.592399900306/8.0),
+ REAL_CONST(55256.033938365079/8.0),
+ REAL_CONST(55276.477367551655/8.0),
+ REAL_CONST(55296.92268711036/8.0),
+ REAL_CONST(55317.369896691685/8.0),
+ REAL_CONST(55337.818995946305/8.0),
+ REAL_CONST(55358.269984525024/8.0),
+ REAL_CONST(55378.72286207883/8.0),
+ REAL_CONST(55399.177628258869/8.0),
+ REAL_CONST(55419.634282716441/8.0),
+ REAL_CONST(55440.092825103013/8.0),
+ REAL_CONST(55460.553255070205/8.0),
+ REAL_CONST(55481.015572269804/8.0),
+ REAL_CONST(55501.479776353764/8.0),
+ REAL_CONST(55521.945866974187/8.0),
+ REAL_CONST(55542.413843783339/8.0),
+ REAL_CONST(55562.883706433655/8.0),
+ REAL_CONST(55583.355454577715/8.0),
+ REAL_CONST(55603.82908786826/8.0),
+ REAL_CONST(55624.304605958219/8.0),
+ REAL_CONST(55644.782008500639/8.0),
+ REAL_CONST(55665.261295148754/8.0),
+ REAL_CONST(55685.742465555952/8.0),
+ REAL_CONST(55706.225519375774/8.0),
+ REAL_CONST(55726.710456261928/8.0),
+ REAL_CONST(55747.197275868275/8.0),
+ REAL_CONST(55767.685977848843/8.0),
+ REAL_CONST(55788.176561857814/8.0),
+ REAL_CONST(55808.669027549528/8.0),
+ REAL_CONST(55829.163374578478/8.0),
+ REAL_CONST(55849.659602599328/8.0),
+ REAL_CONST(55870.157711266889/8.0),
+ REAL_CONST(55890.657700236145/8.0),
+ REAL_CONST(55911.159569162221/8.0),
+ REAL_CONST(55931.663317700411/8.0),
+ REAL_CONST(55952.168945506164/8.0),
+ REAL_CONST(55972.676452235086/8.0),
+ REAL_CONST(55993.185837542944/8.0),
+ REAL_CONST(56013.697101085651/8.0),
+ REAL_CONST(56034.210242519301/8.0),
+ REAL_CONST(56054.72526150012/8.0),
+ REAL_CONST(56075.242157684508/8.0),
+ REAL_CONST(56095.760930729011/8.0),
+ REAL_CONST(56116.281580290342/8.0),
+ REAL_CONST(56136.804106025367/8.0),
+ REAL_CONST(56157.328507591104/8.0),
+ REAL_CONST(56177.85478464474/8.0),
+ REAL_CONST(56198.382936843598/8.0),
+ REAL_CONST(56218.912963845185/8.0),
+ REAL_CONST(56239.444865307138/8.0),
+ REAL_CONST(56259.978640887268/8.0),
+ REAL_CONST(56280.514290243525/8.0),
+ REAL_CONST(56301.051813034042/8.0),
+ REAL_CONST(56321.591208917082/8.0),
+ REAL_CONST(56342.13247755108/8.0),
+ REAL_CONST(56362.675618594607/8.0),
+ REAL_CONST(56383.220631706419/8.0),
+ REAL_CONST(56403.767516545398/8.0),
+ REAL_CONST(56424.316272770608/8.0),
+ REAL_CONST(56444.866900041241/8.0),
+ REAL_CONST(56465.419398016667/8.0),
+ REAL_CONST(56485.973766356394/8.0),
+ REAL_CONST(56506.530004720102/8.0),
+ REAL_CONST(56527.088112767611/8.0),
+ REAL_CONST(56547.648090158902/8.0),
+ REAL_CONST(56568.209936554107/8.0),
+ REAL_CONST(56588.773651613519/8.0),
+ REAL_CONST(56609.339234997584/8.0),
+ REAL_CONST(56629.9066863669/8.0),
+ REAL_CONST(56650.47600538221/8.0),
+ REAL_CONST(56671.04719170442/8.0),
+ REAL_CONST(56691.620244994599/8.0),
+ REAL_CONST(56712.195164913959/8.0),
+ REAL_CONST(56732.771951123868/8.0),
+ REAL_CONST(56753.350603285835/8.0),
+ REAL_CONST(56773.931121061541/8.0),
+ REAL_CONST(56794.513504112823/8.0),
+ REAL_CONST(56815.097752101647/8.0),
+ REAL_CONST(56835.683864690152/8.0),
+ REAL_CONST(56856.271841540627/8.0),
+ REAL_CONST(56876.86168231551/8.0),
+ REAL_CONST(56897.453386677393/8.0),
+ REAL_CONST(56918.046954289028/8.0),
+ REAL_CONST(56938.642384813298/8.0),
+ REAL_CONST(56959.239677913261/8.0),
+ REAL_CONST(56979.838833252121/8.0),
+ REAL_CONST(57000.439850493225/8.0),
+ REAL_CONST(57021.04272930009/8.0),
+ REAL_CONST(57041.647469336371/8.0),
+ REAL_CONST(57062.254070265873/8.0),
+ REAL_CONST(57082.862531752558/8.0),
+ REAL_CONST(57103.472853460553/8.0),
+ REAL_CONST(57124.085035054108/8.0),
+ REAL_CONST(57144.699076197649/8.0),
+ REAL_CONST(57165.314976555739/8.0),
+ REAL_CONST(57185.932735793103/8.0),
+ REAL_CONST(57206.552353574611/8.0),
+ REAL_CONST(57227.173829565276/8.0),
+ REAL_CONST(57247.797163430281/8.0),
+ REAL_CONST(57268.42235483494/8.0),
+ REAL_CONST(57289.049403444733/8.0),
+ REAL_CONST(57309.678308925286/8.0),
+ REAL_CONST(57330.30907094237/8.0),
+ REAL_CONST(57350.941689161911/8.0),
+ REAL_CONST(57371.576163249985/8.0),
+ REAL_CONST(57392.212492872815/8.0),
+ REAL_CONST(57412.850677696784/8.0),
+ REAL_CONST(57433.490717388406/8.0),
+ REAL_CONST(57454.132611614368/8.0),
+ REAL_CONST(57474.776360041491/8.0),
+ REAL_CONST(57495.421962336746/8.0),
+ REAL_CONST(57516.069418167266/8.0),
+ REAL_CONST(57536.718727200314/8.0),
+ REAL_CONST(57557.36988910332/8.0),
+ REAL_CONST(57578.022903543861/8.0),
+ REAL_CONST(57598.677770189643/8.0),
+ REAL_CONST(57619.334488708548/8.0),
+ REAL_CONST(57639.993058768589/8.0),
+ REAL_CONST(57660.653480037938/8.0),
+ REAL_CONST(57681.315752184906/8.0),
+ REAL_CONST(57701.979874877965/8.0),
+ REAL_CONST(57722.64584778573/8.0),
+ REAL_CONST(57743.31367057695/8.0),
+ REAL_CONST(57763.983342920546/8.0),
+ REAL_CONST(57784.654864485572/8.0),
+ REAL_CONST(57805.328234941233/8.0),
+ REAL_CONST(57826.003453956881/8.0),
+ REAL_CONST(57846.680521202026/8.0),
+ REAL_CONST(57867.359436346305/8.0),
+ REAL_CONST(57888.040199059527/8.0),
+ REAL_CONST(57908.722809011633/8.0),
+ REAL_CONST(57929.407265872709/8.0),
+ REAL_CONST(57950.093569313001/8.0),
+ REAL_CONST(57970.781719002895/8.0),
+ REAL_CONST(57991.471714612911/8.0),
+ REAL_CONST(58012.16355581375/8.0),
+ REAL_CONST(58032.857242276223/8.0),
+ REAL_CONST(58053.552773671312/8.0),
+ REAL_CONST(58074.25014967013/8.0),
+ REAL_CONST(58094.949369943948/8.0),
+ REAL_CONST(58115.650434164185/8.0),
+ REAL_CONST(58136.353342002389/8.0),
+ REAL_CONST(58157.058093130276/8.0),
+ REAL_CONST(58177.764687219693/8.0),
+ REAL_CONST(58198.47312394264/8.0),
+ REAL_CONST(58219.183402971255/8.0),
+ REAL_CONST(58239.895523977837/8.0),
+ REAL_CONST(58260.609486634821/8.0),
+ REAL_CONST(58281.325290614775/8.0),
+ REAL_CONST(58302.042935590434/8.0),
+ REAL_CONST(58322.762421234678/8.0),
+ REAL_CONST(58343.483747220511/8.0),
+ REAL_CONST(58364.206913221096/8.0),
+ REAL_CONST(58384.931918909751/8.0),
+ REAL_CONST(58405.658763959924/8.0),
+ REAL_CONST(58426.3874480452/8.0),
+ REAL_CONST(58447.117970839339/8.0),
+ REAL_CONST(58467.85033201622/8.0),
+ REAL_CONST(58488.584531249864/8.0),
+ REAL_CONST(58509.320568214462/8.0),
+ REAL_CONST(58530.058442584334/8.0),
+ REAL_CONST(58550.798154033931/8.0),
+ REAL_CONST(58571.539702237875/8.0),
+ REAL_CONST(58592.283086870906/8.0),
+ REAL_CONST(58613.028307607929/8.0),
+ REAL_CONST(58633.775364123983/8.0),
+ REAL_CONST(58654.52425609425/8.0),
+ REAL_CONST(58675.274983194053/8.0),
+ REAL_CONST(58696.027545098877/8.0),
+ REAL_CONST(58716.781941484325/8.0),
+ REAL_CONST(58737.538172026158/8.0),
+ REAL_CONST(58758.296236400274/8.0),
+ REAL_CONST(58779.056134282728/8.0),
+ REAL_CONST(58799.817865349694/8.0),
+ REAL_CONST(58820.581429277503/8.0),
+ REAL_CONST(58841.346825742643/8.0),
+ REAL_CONST(58862.114054421712/8.0),
+ REAL_CONST(58882.883114991484/8.0),
+ REAL_CONST(58903.654007128847/8.0),
+ REAL_CONST(58924.426730510851/8.0),
+ REAL_CONST(58945.201284814684/8.0),
+ REAL_CONST(58965.977669717664/8.0),
+ REAL_CONST(58986.755884897269/8.0),
+ REAL_CONST(59007.535930031117/8.0),
+ REAL_CONST(59028.317804796949/8.0),
+ REAL_CONST(59049.101508872664/8.0),
+ REAL_CONST(59069.887041936301/8.0),
+ REAL_CONST(59090.674403666046/8.0),
+ REAL_CONST(59111.463593740213/8.0),
+ REAL_CONST(59132.254611837263/8.0),
+ REAL_CONST(59153.047457635803/8.0),
+ REAL_CONST(59173.84213081457/8.0),
+ REAL_CONST(59194.638631052461/8.0),
+ REAL_CONST(59215.436958028506/8.0),
+ REAL_CONST(59236.237111421855/8.0),
+ REAL_CONST(59257.039090911829/8.0),
+ REAL_CONST(59277.842896177877/8.0),
+ REAL_CONST(59298.648526899589/8.0),
+ REAL_CONST(59319.455982756685/8.0),
+ REAL_CONST(59340.26526342905/8.0),
+ REAL_CONST(59361.076368596696/8.0),
+ REAL_CONST(59381.889297939757/8.0),
+ REAL_CONST(59402.704051138542/8.0),
+ REAL_CONST(59423.520627873484/8.0),
+ REAL_CONST(59444.339027825139/8.0),
+ REAL_CONST(59465.159250674224/8.0),
+ REAL_CONST(59485.9812961016/8.0),
+ REAL_CONST(59506.805163788253/8.0),
+ REAL_CONST(59527.630853415307/8.0),
+ REAL_CONST(59548.458364664046/8.0),
+ REAL_CONST(59569.287697215863/8.0),
+ REAL_CONST(59590.118850752311/8.0),
+ REAL_CONST(59610.951824955089/8.0),
+ REAL_CONST(59631.786619506012/8.0),
+ REAL_CONST(59652.623234087048/8.0),
+ REAL_CONST(59673.461668380311/8.0),
+ REAL_CONST(59694.301922068029/8.0),
+ REAL_CONST(59715.143994832593/8.0),
+ REAL_CONST(59735.987886356525/8.0),
+ REAL_CONST(59756.833596322482/8.0),
+ REAL_CONST(59777.681124413255/8.0),
+ REAL_CONST(59798.530470311794/8.0),
+ REAL_CONST(59819.381633701159/8.0),
+ REAL_CONST(59840.234614264569/8.0),
+ REAL_CONST(59861.089411685381/8.0),
+ REAL_CONST(59881.94602564707/8.0),
+ REAL_CONST(59902.804455833269/8.0),
+ REAL_CONST(59923.664701927737/8.0),
+ REAL_CONST(59944.526763614384/8.0),
+ REAL_CONST(59965.390640577243/8.0),
+ REAL_CONST(59986.256332500488/8.0),
+ REAL_CONST(60007.123839068438/8.0),
+ REAL_CONST(60027.993159965539/8.0),
+ REAL_CONST(60048.864294876381/8.0),
+ REAL_CONST(60069.737243485688/8.0),
+ REAL_CONST(60090.612005478324/8.0),
+ REAL_CONST(60111.488580539284/8.0),
+ REAL_CONST(60132.366968353708/8.0),
+ REAL_CONST(60153.247168606867/8.0),
+ REAL_CONST(60174.129180984164/8.0),
+ REAL_CONST(60195.013005171153/8.0),
+ REAL_CONST(60215.898640853513/8.0),
+ REAL_CONST(60236.786087717061/8.0),
+ REAL_CONST(60257.675345447751/8.0),
+ REAL_CONST(60278.566413731671/8.0),
+ REAL_CONST(60299.459292255044/8.0),
+ REAL_CONST(60320.353980704247/8.0),
+ REAL_CONST(60341.25047876576/8.0),
+ REAL_CONST(60362.148786126229/8.0),
+ REAL_CONST(60383.048902472423/8.0),
+ REAL_CONST(60403.950827491237/8.0),
+ REAL_CONST(60424.854560869717/8.0),
+ REAL_CONST(60445.76010229504/8.0),
+ REAL_CONST(60466.667451454516/8.0),
+ REAL_CONST(60487.57660803559/8.0),
+ REAL_CONST(60508.487571725847/8.0),
+ REAL_CONST(60529.400342212997/8.0),
+ REAL_CONST(60550.314919184893/8.0),
+ REAL_CONST(60571.231302329521/8.0),
+ REAL_CONST(60592.149491335003/8.0),
+ REAL_CONST(60613.069485889588/8.0),
+ REAL_CONST(60633.991285681674/8.0),
+ REAL_CONST(60654.914890399785/8.0),
+ REAL_CONST(60675.840299732568/8.0),
+ REAL_CONST(60696.767513368832/8.0),
+ REAL_CONST(60717.696530997484/8.0),
+ REAL_CONST(60738.627352307602/8.0),
+ REAL_CONST(60759.55997698837/8.0),
+ REAL_CONST(60780.494404729128/8.0),
+ REAL_CONST(60801.430635219323/8.0),
+ REAL_CONST(60822.368668148556/8.0),
+ REAL_CONST(60843.308503206565/8.0),
+ REAL_CONST(60864.250140083204/8.0),
+ REAL_CONST(60885.193578468468/8.0),
+ REAL_CONST(60906.138818052495/8.0),
+ REAL_CONST(60927.085858525541/8.0),
+ REAL_CONST(60948.034699578006/8.0),
+ REAL_CONST(60968.985340900421/8.0),
+ REAL_CONST(60989.937782183442/8.0),
+ REAL_CONST(61010.892023117864/8.0),
+ REAL_CONST(61031.848063394616/8.0),
+ REAL_CONST(61052.805902704764/8.0),
+ REAL_CONST(61073.765540739492/8.0),
+ REAL_CONST(61094.726977190134/8.0),
+ REAL_CONST(61115.690211748137/8.0),
+ REAL_CONST(61136.655244105103/8.0),
+ REAL_CONST(61157.622073952742/8.0),
+ REAL_CONST(61178.590700982917/8.0),
+ REAL_CONST(61199.561124887616/8.0),
+ REAL_CONST(61220.533345358948/8.0),
+ REAL_CONST(61241.507362089171/8.0),
+ REAL_CONST(61262.483174770663/8.0),
+ REAL_CONST(61283.460783095943/8.0),
+ REAL_CONST(61304.440186757645/8.0),
+ REAL_CONST(61325.421385448557/8.0),
+ REAL_CONST(61346.404378861582/8.0),
+ REAL_CONST(61367.389166689762/8.0),
+ REAL_CONST(61388.375748626262/8.0),
+ REAL_CONST(61409.364124364387/8.0),
+ REAL_CONST(61430.354293597571/8.0),
+ REAL_CONST(61451.346256019373/8.0),
+ REAL_CONST(61472.340011323497/8.0),
+ REAL_CONST(61493.335559203762/8.0),
+ REAL_CONST(61514.332899354122/8.0),
+ REAL_CONST(61535.332031468672/8.0),
+ REAL_CONST(61556.332955241618/8.0),
+ REAL_CONST(61577.335670367313/8.0),
+ REAL_CONST(61598.340176540238/8.0),
+ REAL_CONST(61619.346473454993/8.0),
+ REAL_CONST(61640.354560806329/8.0),
+ REAL_CONST(61661.3644382891/8.0),
+ REAL_CONST(61682.376105598312/8.0),
+ REAL_CONST(61703.389562429089/8.0),
+ REAL_CONST(61724.404808476691/8.0),
+ REAL_CONST(61745.42184343651/8.0),
+ REAL_CONST(61766.440667004063/8.0),
+ REAL_CONST(61787.461278874987/8.0),
+ REAL_CONST(61808.483678745069/8.0),
+ REAL_CONST(61829.507866310203/8.0),
+ REAL_CONST(61850.533841266435/8.0),
+ REAL_CONST(61871.561603309929/8.0),
+ REAL_CONST(61892.591152136971/8.0),
+ REAL_CONST(61913.622487443987/8.0),
+ REAL_CONST(61934.655608927525/8.0),
+ REAL_CONST(61955.690516284267/8.0),
+ REAL_CONST(61976.727209211022/8.0),
+ REAL_CONST(61997.765687404724/8.0),
+ REAL_CONST(62018.805950562448/8.0),
+ REAL_CONST(62039.847998381381/8.0),
+ REAL_CONST(62060.891830558845/8.0),
+ REAL_CONST(62081.93744679229/8.0),
+ REAL_CONST(62102.984846779298/8.0),
+ REAL_CONST(62124.034030217575/8.0),
+ REAL_CONST(62145.084996804966/8.0),
+ REAL_CONST(62166.137746239416/8.0),
+ REAL_CONST(62187.19227821903/8.0),
+ REAL_CONST(62208.248592442025/8.0),
+ REAL_CONST(62229.306688606739/8.0),
+ REAL_CONST(62250.366566411656/8.0),
+ REAL_CONST(62271.428225555377/8.0),
+ REAL_CONST(62292.491665736627/8.0),
+ REAL_CONST(62313.556886654267/8.0),
+ REAL_CONST(62334.623888007271/8.0),
+ REAL_CONST(62355.692669494762/8.0),
+ REAL_CONST(62376.763230815974/8.0),
+ REAL_CONST(62397.835571670272/8.0),
+ REAL_CONST(62418.909691757144/8.0),
+ REAL_CONST(62439.98559077621/8.0),
+ REAL_CONST(62461.063268427228/8.0),
+ REAL_CONST(62482.142724410049/8.0),
+ REAL_CONST(62503.223958424685/8.0),
+ REAL_CONST(62524.306970171267/8.0),
+ REAL_CONST(62545.39175935003/8.0),
+ REAL_CONST(62566.478325661366/8.0),
+ REAL_CONST(62587.566668805768/8.0),
+ REAL_CONST(62608.656788483881/8.0),
+ REAL_CONST(62629.748684396451/8.0),
+ REAL_CONST(62650.842356244357/8.0),
+ REAL_CONST(62671.937803728622/8.0),
+ REAL_CONST(62693.035026550366/8.0),
+ REAL_CONST(62714.134024410858/8.0),
+ REAL_CONST(62735.234797011479/8.0),
+ REAL_CONST(62756.337344053733/8.0),
+ REAL_CONST(62777.441665239276/8.0),
+ REAL_CONST(62798.547760269852/8.0),
+ REAL_CONST(62819.655628847358/8.0),
+ REAL_CONST(62840.765270673801/8.0),
+ REAL_CONST(62861.876685451323/8.0),
+ REAL_CONST(62882.989872882186/8.0),
+ REAL_CONST(62904.104832668774/8.0),
+ REAL_CONST(62925.221564513602/8.0),
+ REAL_CONST(62946.340068119309/8.0),
+ REAL_CONST(62967.460343188657/8.0),
+ REAL_CONST(62988.582389424526/8.0),
+ REAL_CONST(63009.70620652994/8.0),
+ REAL_CONST(63030.831794208025/8.0),
+ REAL_CONST(63051.959152162039/8.0),
+ REAL_CONST(63073.08828009537/8.0),
+ REAL_CONST(63094.219177711529/8.0),
+ REAL_CONST(63115.351844714154/8.0),
+ REAL_CONST(63136.486280806988/8.0),
+ REAL_CONST(63157.622485693922/8.0),
+ REAL_CONST(63178.760459078956/8.0),
+ REAL_CONST(63199.900200666219/8.0),
+ REAL_CONST(63221.041710159967/8.0),
+ REAL_CONST(63242.184987264569/8.0),
+ REAL_CONST(63263.330031684534/8.0),
+ REAL_CONST(63284.476843124474/8.0),
+ REAL_CONST(63305.625421289144/8.0),
+ REAL_CONST(63326.775765883409/8.0),
+ REAL_CONST(63347.927876612259/8.0),
+ REAL_CONST(63369.081753180813/8.0),
+ REAL_CONST(63390.237395294316/8.0),
+ REAL_CONST(63411.39480265812/8.0),
+ REAL_CONST(63432.553974977716/8.0),
+ REAL_CONST(63453.714911958712/8.0),
+ REAL_CONST(63474.877613306839/8.0),
+ REAL_CONST(63496.042078727944/8.0),
+ REAL_CONST(63517.208307927998/8.0),
+ REAL_CONST(63538.376300613119/8.0),
+ REAL_CONST(63559.546056489504/8.0),
+ REAL_CONST(63580.717575263516/8.0),
+ REAL_CONST(63601.890856641607/8.0),
+ REAL_CONST(63623.065900330374/8.0),
+ REAL_CONST(63644.242706036515/8.0),
+ REAL_CONST(63665.421273466869/8.0),
+ REAL_CONST(63686.601602328381/8.0),
+ REAL_CONST(63707.783692328136/8.0),
+ REAL_CONST(63728.967543173334/8.0),
+ REAL_CONST(63750.153154571279/8.0),
+ REAL_CONST(63771.340526229418/8.0),
+ REAL_CONST(63792.529657855317/8.0),
+ REAL_CONST(63813.720549156649/8.0),
+ REAL_CONST(63834.913199841227/8.0),
+ REAL_CONST(63856.107609616978/8.0),
+ REAL_CONST(63877.303778191941/8.0),
+ REAL_CONST(63898.501705274284/8.0),
+ REAL_CONST(63919.7013905723/8.0),
+ REAL_CONST(63940.902833794404/8.0),
+ REAL_CONST(63962.106034649114/8.0),
+ REAL_CONST(63983.310992845094/8.0),
+ REAL_CONST(64004.517708091109/8.0),
+ REAL_CONST(64025.726180096048/8.0),
+ REAL_CONST(64046.936408568938/8.0),
+ REAL_CONST(64068.1483932189/8.0),
+ REAL_CONST(64089.362133755196/8.0),
+ REAL_CONST(64110.577629887193/8.0),
+ REAL_CONST(64131.794881324393/8.0),
+ REAL_CONST(64153.013887776404/8.0),
+ REAL_CONST(64174.234648952966/8.0),
+ REAL_CONST(64195.457164563937/8.0),
+ REAL_CONST(64216.681434319289/8.0),
+ REAL_CONST(64237.907457929112/8.0),
+ REAL_CONST(64259.135235103626/8.0),
+ REAL_CONST(64280.36476555316/8.0),
+ REAL_CONST(64301.596048988169/8.0),
+ REAL_CONST(64322.829085119236/8.0),
+ REAL_CONST(64344.06387365704/8.0),
+ REAL_CONST(64365.300414312398/8.0),
+ REAL_CONST(64386.538706796251/8.0),
+ REAL_CONST(64407.778750819634/8.0),
+ REAL_CONST(64429.020546093721/8.0),
+ REAL_CONST(64450.26409232981/8.0),
+ REAL_CONST(64471.509389239291/8.0),
+ REAL_CONST(64492.756436533709/8.0),
+ REAL_CONST(64514.005233924705/8.0),
+ REAL_CONST(64535.255781124033/8.0),
+ REAL_CONST(64556.50807784358/8.0),
+ REAL_CONST(64577.762123795357/8.0),
+ REAL_CONST(64599.017918691468/8.0),
+ REAL_CONST(64620.275462244172/8.0),
+ REAL_CONST(64641.534754165805/8.0),
+ REAL_CONST(64662.795794168844/8.0),
+ REAL_CONST(64684.058581965895/8.0),
+ REAL_CONST(64705.323117269661/8.0),
+ REAL_CONST(64726.589399792974/8.0),
+ REAL_CONST(64747.857429248776/8.0),
+ REAL_CONST(64769.127205350138/8.0),
+ REAL_CONST(64790.398727810236/8.0),
+ REAL_CONST(64811.671996342375/8.0),
+ REAL_CONST(64832.947010659969/8.0),
+ REAL_CONST(64854.223770476558/8.0),
+ REAL_CONST(64875.502275505794/8.0),
+ REAL_CONST(64896.782525461451/8.0),
+ REAL_CONST(64918.064520057414/8.0),
+ REAL_CONST(64939.348259007682/8.0),
+ REAL_CONST(64960.633742026388/8.0),
+ REAL_CONST(64981.920968827762/8.0),
+ REAL_CONST(65003.209939126165/8.0),
+ REAL_CONST(65024.500652636067/8.0),
+ REAL_CONST(65045.793109072067/8.0),
+ REAL_CONST(65067.087308148861/8.0),
+ REAL_CONST(65088.383249581282/8.0),
+ REAL_CONST(65109.680933084259/8.0),
+ REAL_CONST(65130.980358372864/8.0),
+ REAL_CONST(65152.28152516226/8.0),
+ REAL_CONST(65173.584433167736/8.0),
+ REAL_CONST(65194.889082104703/8.0),
+ REAL_CONST(65216.195471688683/8.0),
+ REAL_CONST(65237.503601635319/8.0),
+ REAL_CONST(65258.813471660353/8.0),
+ REAL_CONST(65280.125081479666/8.0),
+ REAL_CONST(65301.438430809241/8.0),
+ REAL_CONST(65322.753519365178/8.0),
+ REAL_CONST(65344.070346863708/8.0),
+ REAL_CONST(65365.388913021146/8.0),
+ REAL_CONST(65386.709217553958/8.0),
+ REAL_CONST(65408.031260178701/8.0),
+ REAL_CONST(65429.355040612056/8.0),
+ REAL_CONST(65450.680558570821/8.0),
+ REAL_CONST(65472.00781377191/8.0),
+ REAL_CONST(65493.336805932355/8.0),
+ REAL_CONST(65514.66753476928/8.0),
+ REAL_CONST(65535.999999999956/8.0),
+ REAL_CONST(65557.334201341757/8.0),
+ REAL_CONST(65578.670138512171/8.0),
+ REAL_CONST(65600.007811228788/8.0),
+ REAL_CONST(65621.347219209332/8.0),
+ REAL_CONST(65642.688362171626/8.0),
+ REAL_CONST(65664.031239833639/8.0),
+ REAL_CONST(65685.375851913413/8.0),
+ REAL_CONST(65706.722198129137/8.0),
+ REAL_CONST(65728.070278199084/8.0),
+ REAL_CONST(65749.420091841661/8.0),
+ REAL_CONST(65770.771638775404/8.0),
+ REAL_CONST(65792.124918718939/8.0),
+ REAL_CONST(65813.479931391004/8.0),
+ REAL_CONST(65834.836676510458/8.0),
+ REAL_CONST(65856.195153796303/8.0),
+ REAL_CONST(65877.5553629676/8.0),
+ REAL_CONST(65898.917303743554/8.0),
+ REAL_CONST(65920.280975843489/8.0),
+ REAL_CONST(65941.646378986843/8.0),
+ REAL_CONST(65963.013512893158/8.0),
+ REAL_CONST(65984.382377282076/8.0),
+ REAL_CONST(66005.752971873386/8.0),
+ REAL_CONST(66027.125296386963/8.0),
+ REAL_CONST(66048.499350542799/8.0),
+ REAL_CONST(66069.875134061018/8.0),
+ REAL_CONST(66091.252646661844/8.0),
+ REAL_CONST(66112.631888065618/8.0),
+ REAL_CONST(66134.01285799277/8.0),
+ REAL_CONST(66155.395556163887/8.0),
+ REAL_CONST(66176.779982299631/8.0),
+ REAL_CONST(66198.166136120795/8.0),
+ REAL_CONST(66219.554017348273/8.0),
+ REAL_CONST(66240.943625703105/8.0),
+ REAL_CONST(66262.334960906388/8.0),
+ REAL_CONST(66283.728022679396/8.0),
+ REAL_CONST(66305.122810743444/8.0),
+ REAL_CONST(66326.519324820023/8.0),
+ REAL_CONST(66347.917564630698/8.0),
+ REAL_CONST(66369.317529897162/8.0),
+ REAL_CONST(66390.719220341227/8.0),
+ REAL_CONST(66412.122635684791/8.0),
+ REAL_CONST(66433.527775649884/8.0),
+ REAL_CONST(66454.934639958636/8.0),
+ REAL_CONST(66476.343228333324/8.0),
+ REAL_CONST(66497.753540496284/8.0),
+ REAL_CONST(66519.165576169995/8.0),
+ REAL_CONST(66540.57933507704/8.0),
+ REAL_CONST(66561.994816940118/8.0),
+ REAL_CONST(66583.412021482043/8.0),
+ REAL_CONST(66604.830948425733/8.0),
+ REAL_CONST(66626.251597494222/8.0),
+ REAL_CONST(66647.673968410629/8.0),
+ REAL_CONST(66669.098060898235/8.0),
+ REAL_CONST(66690.523874680381/8.0),
+ REAL_CONST(66711.951409480564/8.0),
+ REAL_CONST(66733.380665022371/8.0),
+ REAL_CONST(66754.811641029475/8.0),
+ REAL_CONST(66776.244337225711/8.0),
+ REAL_CONST(66797.678753334985/8.0),
+ REAL_CONST(66819.11488908132/8.0),
+ REAL_CONST(66840.552744188884/8.0),
+ REAL_CONST(66861.992318381905/8.0),
+ REAL_CONST(66883.433611384738/8.0),
+ REAL_CONST(66904.876622921889/8.0),
+ REAL_CONST(66926.321352717903/8.0),
+ REAL_CONST(66947.767800497502/8.0),
+ REAL_CONST(66969.215965985466/8.0),
+ REAL_CONST(66990.665848906734/8.0),
+ REAL_CONST(67012.117448986304/8.0),
+ REAL_CONST(67033.570765949335/8.0),
+ REAL_CONST(67055.025799521056/8.0),
+ REAL_CONST(67076.482549426815/8.0),
+ REAL_CONST(67097.941015392076/8.0),
+ REAL_CONST(67119.401197142433/8.0),
+ REAL_CONST(67140.863094403554/8.0),
+ REAL_CONST(67162.326706901222/8.0),
+ REAL_CONST(67183.792034361351/8.0),
+ REAL_CONST(67205.259076509959/8.0),
+ REAL_CONST(67226.72783307315/8.0),
+ REAL_CONST(67248.198303777172/8.0),
+ REAL_CONST(67269.670488348347/8.0),
+ REAL_CONST(67291.144386513144/8.0),
+ REAL_CONST(67312.619997998088/8.0),
+ REAL_CONST(67334.09732252988/8.0),
+ REAL_CONST(67355.576359835293/8.0),
+ REAL_CONST(67377.057109641188/8.0),
+ REAL_CONST(67398.53957167457/8.0),
+ REAL_CONST(67420.023745662547/8.0),
+ REAL_CONST(67441.50963133233/8.0),
+ REAL_CONST(67462.99722841123/8.0),
+ REAL_CONST(67484.486536626689/8.0),
+ REAL_CONST(67505.977555706224/8.0),
+ REAL_CONST(67527.470285377494/8.0),
+ REAL_CONST(67548.964725368263/8.0),
+ REAL_CONST(67570.460875406367/8.0),
+ REAL_CONST(67591.9587352198/8.0),
+ REAL_CONST(67613.458304536631/8.0),
+ REAL_CONST(67634.95958308503/8.0),
+ REAL_CONST(67656.462570593329/8.0),
+ REAL_CONST(67677.967266789899/8.0),
+ REAL_CONST(67699.473671403248/8.0),
+ REAL_CONST(67720.981784162024/8.0),
+ REAL_CONST(67742.491604794923/8.0),
+ REAL_CONST(67764.003133030797/8.0),
+ REAL_CONST(67785.516368598575/8.0),
+ REAL_CONST(67807.031311227314/8.0),
+ REAL_CONST(67828.547960646174/8.0),
+ REAL_CONST(67850.066316584402/8.0),
+ REAL_CONST(67871.58637877139/8.0),
+ REAL_CONST(67893.108146936589/8.0),
+ REAL_CONST(67914.63162080961/8.0),
+ REAL_CONST(67936.156800120138/8.0),
+ REAL_CONST(67957.683684597971/8.0),
+ REAL_CONST(67979.212273973011/8.0),
+ REAL_CONST(68000.742567975263/8.0),
+ REAL_CONST(68022.274566334876/8.0),
+ REAL_CONST(68043.808268782057/8.0),
+ REAL_CONST(68065.343675047145/8.0),
+ REAL_CONST(68086.880784860579/8.0),
+ REAL_CONST(68108.419597952918/8.0),
+ REAL_CONST(68129.960114054789/8.0),
+ REAL_CONST(68151.502332896969/8.0),
+ REAL_CONST(68173.04625421032/8.0),
+ REAL_CONST(68194.591877725834/8.0),
+ REAL_CONST(68216.139203174564/8.0),
+ REAL_CONST(68237.688230287706/8.0),
+ REAL_CONST(68259.238958796544/8.0),
+ REAL_CONST(68280.791388432481/8.0),
+ REAL_CONST(68302.345518927032/8.0),
+ REAL_CONST(68323.901350011787/8.0),
+ REAL_CONST(68345.458881418483/8.0),
+ REAL_CONST(68367.018112878912/8.0),
+ REAL_CONST(68388.579044125028/8.0),
+ REAL_CONST(68410.141674888844/8.0),
+ REAL_CONST(68431.706004902502/8.0),
+ REAL_CONST(68453.272033898262/8.0),
+ REAL_CONST(68474.839761608455/8.0),
+ REAL_CONST(68496.409187765545/8.0),
+ REAL_CONST(68517.980312102081/8.0),
+ REAL_CONST(68539.553134350732/8.0),
+ REAL_CONST(68561.127654244279/8.0),
+ REAL_CONST(68582.70387151558/8.0),
+ REAL_CONST(68604.281785897634/8.0),
+ REAL_CONST(68625.861397123503/8.0),
+ REAL_CONST(68647.44270492639/8.0),
+ REAL_CONST(68669.025709039604/8.0),
+ REAL_CONST(68690.610409196524/8.0),
+ REAL_CONST(68712.196805130661/8.0),
+ REAL_CONST(68733.784896575627/8.0),
+ REAL_CONST(68755.374683265123/8.0),
+ REAL_CONST(68776.966164932994/8.0),
+ REAL_CONST(68798.559341313128/8.0),
+ REAL_CONST(68820.154212139591/8.0),
+ REAL_CONST(68841.750777146473/8.0),
+ REAL_CONST(68863.349036068044/8.0),
+ REAL_CONST(68884.948988638629/8.0),
+ REAL_CONST(68906.550634592684/8.0),
+ REAL_CONST(68928.153973664739/8.0),
+ REAL_CONST(68949.75900558944/8.0),
+ REAL_CONST(68971.365730101577/8.0),
+ REAL_CONST(68992.974146935987/8.0),
+ REAL_CONST(69014.584255827634/8.0),
+ REAL_CONST(69036.196056511588/8.0),
+ REAL_CONST(69057.809548723017/8.0),
+ REAL_CONST(69079.424732197207/8.0),
+ REAL_CONST(69101.041606669532/8.0),
+ REAL_CONST(69122.660171875468/8.0),
+ REAL_CONST(69144.280427550606/8.0),
+ REAL_CONST(69165.902373430625/8.0),
+ REAL_CONST(69187.526009251334/8.0),
+ REAL_CONST(69209.151334748618/8.0),
+ REAL_CONST(69230.778349658474/8.0),
+ REAL_CONST(69252.40705371699/8.0),
+ REAL_CONST(69274.037446660412/8.0),
+ REAL_CONST(69295.669528225/8.0),
+ REAL_CONST(69317.303298147192/8.0),
+ REAL_CONST(69338.938756163494/8.0),
+ REAL_CONST(69360.575902010532/8.0),
+ REAL_CONST(69382.214735425005/8.0),
+ REAL_CONST(69403.855256143754/8.0),
+ REAL_CONST(69425.497463903681/8.0),
+ REAL_CONST(69447.141358441833/8.0),
+ REAL_CONST(69468.78693949533/8.0),
+ REAL_CONST(69490.434206801394/8.0),
+ REAL_CONST(69512.083160097391/8.0),
+ REAL_CONST(69533.733799120717/8.0),
+ REAL_CONST(69555.386123608929/8.0),
+ REAL_CONST(69577.04013329967/8.0),
+ REAL_CONST(69598.695827930685/8.0),
+ REAL_CONST(69620.353207239794/8.0),
+ REAL_CONST(69642.012270964973/8.0),
+ REAL_CONST(69663.67301884426/8.0),
+ REAL_CONST(69685.335450615792/8.0),
+ REAL_CONST(69706.999566017839/8.0),
+ REAL_CONST(69728.665364788743/8.0),
+ REAL_CONST(69750.332846666963/8.0),
+ REAL_CONST(69772.002011391058/8.0),
+ REAL_CONST(69793.672858699691/8.0),
+ REAL_CONST(69815.345388331611/8.0),
+ REAL_CONST(69837.019600025669/8.0),
+ REAL_CONST(69858.695493520849/8.0),
+ REAL_CONST(69880.373068556204/8.0),
+ REAL_CONST(69902.052324870907/8.0),
+ REAL_CONST(69923.733262204216/8.0),
+ REAL_CONST(69945.415880295492/8.0),
+ REAL_CONST(69967.100178884211/8.0),
+ REAL_CONST(69988.786157709939/8.0),
+ REAL_CONST(70010.473816512356/8.0),
+ REAL_CONST(70032.163155031216/8.0),
+ REAL_CONST(70053.854173006403/8.0),
+ REAL_CONST(70075.546870177874/8.0),
+ REAL_CONST(70097.241246285717/8.0),
+ REAL_CONST(70118.937301070109/8.0),
+ REAL_CONST(70140.635034271298/8.0),
+ REAL_CONST(70162.334445629691/8.0),
+ REAL_CONST(70184.035534885741/8.0),
+ REAL_CONST(70205.738301780017/8.0),
+ REAL_CONST(70227.442746053217/8.0),
+ REAL_CONST(70249.1488674461/8.0),
+ REAL_CONST(70270.856665699539/8.0),
+ REAL_CONST(70292.566140554511/8.0),
+ REAL_CONST(70314.277291752107/8.0),
+ REAL_CONST(70335.990119033493/8.0),
+ REAL_CONST(70357.704622139936/8.0),
+ REAL_CONST(70379.420800812819/8.0),
+ REAL_CONST(70401.138654793613/8.0),
+ REAL_CONST(70422.85818382389/8.0),
+ REAL_CONST(70444.579387645339/8.0),
+ REAL_CONST(70466.302265999722/8.0),
+ REAL_CONST(70488.026818628918/8.0),
+ REAL_CONST(70509.753045274876/8.0),
+ REAL_CONST(70531.480945679708/8.0),
+ REAL_CONST(70553.210519585555/8.0),
+ REAL_CONST(70574.941766734701/8.0),
+ REAL_CONST(70596.674686869505/8.0),
+ REAL_CONST(70618.409279732456/8.0),
+ REAL_CONST(70640.145545066101/8.0),
+ REAL_CONST(70661.883482613106/8.0),
+ REAL_CONST(70683.623092116264/8.0),
+ REAL_CONST(70705.364373318414/8.0),
+ REAL_CONST(70727.107325962526/8.0),
+ REAL_CONST(70748.851949791671/8.0),
+ REAL_CONST(70770.598244549008/8.0),
+ REAL_CONST(70792.346209977783/8.0),
+ REAL_CONST(70814.095845821372/8.0),
+ REAL_CONST(70835.847151823225/8.0),
+ REAL_CONST(70857.600127726895/8.0),
+ REAL_CONST(70879.354773276034/8.0),
+ REAL_CONST(70901.111088214413/8.0),
+ REAL_CONST(70922.869072285859/8.0),
+ REAL_CONST(70944.628725234332/8.0),
+ REAL_CONST(70966.390046803877/8.0),
+ REAL_CONST(70988.153036738629/8.0),
+ REAL_CONST(71009.917694782853/8.0),
+ REAL_CONST(71031.684020680885/8.0),
+ REAL_CONST(71053.45201417715/8.0),
+ REAL_CONST(71075.221675016204/8.0),
+ REAL_CONST(71096.993002942661/8.0),
+ REAL_CONST(71118.765997701266/8.0),
+ REAL_CONST(71140.540659036851/8.0),
+ REAL_CONST(71162.316986694335/8.0),
+ REAL_CONST(71184.09498041874/8.0),
+ REAL_CONST(71205.874639955218/8.0),
+ REAL_CONST(71227.655965048951/8.0),
+ REAL_CONST(71249.438955445294/8.0),
+ REAL_CONST(71271.223610889632/8.0),
+ REAL_CONST(71293.009931127483/8.0),
+ REAL_CONST(71314.797915904477/8.0),
+ REAL_CONST(71336.587564966307/8.0),
+ REAL_CONST(71358.378878058764/8.0),
+ REAL_CONST(71380.171854927772/8.0),
+ REAL_CONST(71401.966495319313/8.0),
+ REAL_CONST(71423.762798979486/8.0),
+ REAL_CONST(71445.560765654489/8.0),
+ REAL_CONST(71467.360395090596/8.0),
+ REAL_CONST(71489.161687034211/8.0),
+ REAL_CONST(71510.964641231811/8.0),
+ REAL_CONST(71532.769257429973/8.0),
+ REAL_CONST(71554.575535375348/8.0),
+ REAL_CONST(71576.383474814749/8.0),
+ REAL_CONST(71598.19307549503/8.0),
+ REAL_CONST(71620.004337163133/8.0),
+ REAL_CONST(71641.817259566145/8.0),
+ REAL_CONST(71663.631842451214/8.0),
+ REAL_CONST(71685.4480855656/8.0),
+ REAL_CONST(71707.26598865664/8.0),
+ REAL_CONST(71729.085551471784/8.0),
+ REAL_CONST(71750.906773758586/8.0),
+ REAL_CONST(71772.729655264673/8.0),
+ REAL_CONST(71794.554195737772/8.0),
+ REAL_CONST(71816.380394925713/8.0),
+ REAL_CONST(71838.208252576442/8.0),
+ REAL_CONST(71860.037768437964/8.0),
+ REAL_CONST(71881.868942258385/8.0),
+ REAL_CONST(71903.701773785942/8.0),
+ REAL_CONST(71925.536262768932/8.0),
+ REAL_CONST(71947.372408955751/8.0),
+ REAL_CONST(71969.210212094898/8.0),
+ REAL_CONST(71991.049671934976/8.0),
+ REAL_CONST(72012.890788224686/8.0),
+ REAL_CONST(72034.73356071279/8.0),
+ REAL_CONST(72056.577989148165/8.0),
+ REAL_CONST(72078.424073279821/8.0),
+ REAL_CONST(72100.271812856794/8.0),
+ REAL_CONST(72122.121207628254/8.0),
+ REAL_CONST(72143.97225734347/8.0),
+ REAL_CONST(72165.824961751801/8.0),
+ REAL_CONST(72187.679320602692/8.0),
+ REAL_CONST(72209.53533364569/8.0),
+ REAL_CONST(72231.393000630429/8.0),
+ REAL_CONST(72253.252321306645/8.0),
+ REAL_CONST(72275.113295424177/8.0),
+ REAL_CONST(72296.975922732949/8.0),
+ REAL_CONST(72318.840202982959/8.0),
+ REAL_CONST(72340.706135924338/8.0),
+ REAL_CONST(72362.573721307272/8.0),
+ REAL_CONST(72384.442958882093/8.0),
+ REAL_CONST(72406.313848399179/8.0),
+ REAL_CONST(72428.186389609036/8.0),
+ REAL_CONST(72450.060582262216/8.0),
+ REAL_CONST(72471.936426109431/8.0),
+ REAL_CONST(72493.813920901433/8.0),
+ REAL_CONST(72515.693066389096/8.0),
+ REAL_CONST(72537.573862323392/8.0),
+ REAL_CONST(72559.456308455352/8.0),
+ REAL_CONST(72581.340404536139/8.0),
+ REAL_CONST(72603.226150316987/8.0),
+ REAL_CONST(72625.113545549248/8.0),
+ REAL_CONST(72647.002589984331/8.0),
+ REAL_CONST(72668.893283373764/8.0),
+ REAL_CONST(72690.785625469172/8.0),
+ REAL_CONST(72712.679616022273/8.0),
+ REAL_CONST(72734.575254784853/8.0),
+ REAL_CONST(72756.472541508803/8.0),
+ REAL_CONST(72778.371475946144/8.0),
+ REAL_CONST(72800.272057848939/8.0),
+ REAL_CONST(72822.174286969355/8.0),
+ REAL_CONST(72844.07816305969/8.0),
+ REAL_CONST(72865.983685872285/8.0),
+ REAL_CONST(72887.890855159596/8.0),
+ REAL_CONST(72909.799670674183/8.0),
+ REAL_CONST(72931.710132168693/8.0),
+ REAL_CONST(72953.622239395845/8.0),
+ REAL_CONST(72975.535992108475/8.0),
+ REAL_CONST(72997.451390059519/8.0),
+ REAL_CONST(73019.368433001961/8.0),
+ REAL_CONST(73041.287120688925/8.0),
+ REAL_CONST(73063.207452873612/8.0),
+ REAL_CONST(73085.129429309294/8.0),
+ REAL_CONST(73107.053049749389/8.0),
+ REAL_CONST(73128.978313947344/8.0),
+ REAL_CONST(73150.905221656736/8.0),
+ REAL_CONST(73172.833772631217/8.0),
+ REAL_CONST(73194.763966624567/8.0),
+ REAL_CONST(73216.695803390612/8.0),
+ REAL_CONST(73238.62928268328/8.0),
+ REAL_CONST(73260.564404256627/8.0),
+ REAL_CONST(73282.501167864757/8.0),
+ REAL_CONST(73304.439573261901/8.0),
+ REAL_CONST(73326.379620202337/8.0),
+ REAL_CONST(73348.321308440485/8.0),
+ REAL_CONST(73370.264637730841/8.0),
+ REAL_CONST(73392.209607827957/8.0),
+ REAL_CONST(73414.156218486532/8.0),
+ REAL_CONST(73436.104469461323/8.0),
+ REAL_CONST(73458.054360507173/8.0),
+ REAL_CONST(73480.005891379056/8.0),
+ REAL_CONST(73501.959061831993/8.0),
+ REAL_CONST(73523.913871621116/8.0),
+ REAL_CONST(73545.870320501665/8.0),
+ REAL_CONST(73567.828408228932/8.0),
+ REAL_CONST(73589.78813455833/8.0),
+ REAL_CONST(73611.749499245358/8.0),
+ REAL_CONST(73633.712502045615/8.0),
+ REAL_CONST(73655.677142714747/8.0),
+ REAL_CONST(73677.643421008557/8.0),
+ REAL_CONST(73699.611336682879/8.0),
+ REAL_CONST(73721.580889493693/8.0),
+ REAL_CONST(73743.552079197019/8.0),
+ REAL_CONST(73765.524905548999/8.0),
+ REAL_CONST(73787.499368305856/8.0),
+ REAL_CONST(73809.475467223907/8.0),
+ REAL_CONST(73831.453202059551/8.0),
+ REAL_CONST(73853.432572569291/8.0),
+ REAL_CONST(73875.413578509717/8.0),
+ REAL_CONST(73897.396219637507/8.0),
+ REAL_CONST(73919.380495709411/8.0),
+ REAL_CONST(73941.36640648231/8.0),
+ REAL_CONST(73963.353951713143/8.0),
+ REAL_CONST(73985.343131158952/8.0),
+ REAL_CONST(74007.333944576865/8.0),
+ REAL_CONST(74029.326391724098/8.0),
+ REAL_CONST(74051.320472357969/8.0),
+ REAL_CONST(74073.316186235883/8.0),
+ REAL_CONST(74095.313533115303/8.0),
+ REAL_CONST(74117.312512753837/8.0),
+ REAL_CONST(74139.313124909138/8.0),
+ REAL_CONST(74161.315369338976/8.0),
+ REAL_CONST(74183.319245801191/8.0),
+ REAL_CONST(74205.324754053727/8.0),
+ REAL_CONST(74227.331893854629/8.0),
+ REAL_CONST(74249.340664961986/8.0),
+ REAL_CONST(74271.351067134034/8.0),
+ REAL_CONST(74293.363100129049/8.0),
+ REAL_CONST(74315.376763705441/8.0),
+ REAL_CONST(74337.392057621662/8.0),
+ REAL_CONST(74359.408981636298/8.0),
+ REAL_CONST(74381.427535508003/8.0),
+ REAL_CONST(74403.447718995507/8.0),
+ REAL_CONST(74425.469531857671/8.0),
+ REAL_CONST(74447.492973853383/8.0),
+ REAL_CONST(74469.518044741693/8.0),
+ REAL_CONST(74491.54474428168/8.0),
+ REAL_CONST(74513.573072232539/8.0),
+ REAL_CONST(74535.603028353551/8.0),
+ REAL_CONST(74557.634612404087/8.0),
+ REAL_CONST(74579.667824143602/8.0),
+ REAL_CONST(74601.702663331642/8.0),
+ REAL_CONST(74623.739129727837/8.0),
+ REAL_CONST(74645.777223091936/8.0),
+ REAL_CONST(74667.816943183716/8.0),
+ REAL_CONST(74689.858289763113/8.0),
+ REAL_CONST(74711.901262590094/8.0),
+ REAL_CONST(74733.945861424741/8.0),
+ REAL_CONST(74755.992086027225/8.0),
+ REAL_CONST(74778.039936157802/8.0),
+ REAL_CONST(74800.089411576817/8.0),
+ REAL_CONST(74822.140512044702/8.0),
+ REAL_CONST(74844.193237321961/8.0),
+ REAL_CONST(74866.24758716923/8.0),
+ REAL_CONST(74888.303561347187/8.0),
+ REAL_CONST(74910.36115961663/8.0),
+ REAL_CONST(74932.420381738411/8.0),
+ REAL_CONST(74954.481227473516/8.0),
+ REAL_CONST(74976.543696582972/8.0),
+ REAL_CONST(74998.607788827925/8.0),
+ REAL_CONST(75020.673503969607/8.0),
+ REAL_CONST(75042.740841769322/8.0),
+ REAL_CONST(75064.809801988464/8.0),
+ REAL_CONST(75086.88038438854/8.0),
+ REAL_CONST(75108.952588731103/8.0),
+ REAL_CONST(75131.026414777836/8.0),
+ REAL_CONST(75153.101862290467/8.0),
+ REAL_CONST(75175.178931030852/8.0),
+ REAL_CONST(75197.257620760924/8.0),
+ REAL_CONST(75219.33793124267/8.0),
+ REAL_CONST(75241.419862238225/8.0),
+ REAL_CONST(75263.503413509738/8.0),
+ REAL_CONST(75285.588584819503/8.0),
+ REAL_CONST(75307.675375929874/8.0),
+ REAL_CONST(75329.763786603318/8.0),
+ REAL_CONST(75351.853816602365/8.0),
+ REAL_CONST(75373.945465689612/8.0),
+ REAL_CONST(75396.038733627807/8.0),
+ REAL_CONST(75418.133620179724/8.0),
+ REAL_CONST(75440.230125108254/8.0),
+ REAL_CONST(75462.32824817636/8.0),
+ REAL_CONST(75484.427989147109/8.0),
+ REAL_CONST(75506.529347783653/8.0),
+ REAL_CONST(75528.63232384919/8.0),
+ REAL_CONST(75550.736917107075/8.0),
+ REAL_CONST(75572.843127320695/8.0),
+ REAL_CONST(75594.950954253538/8.0),
+ REAL_CONST(75617.060397669193/8.0),
+ REAL_CONST(75639.171457331307/8.0),
+ REAL_CONST(75661.284133003646/8.0),
+ REAL_CONST(75683.398424450032/8.0),
+ REAL_CONST(75705.514331434402/8.0),
+ REAL_CONST(75727.631853720741/8.0),
+ REAL_CONST(75749.750991073175/8.0),
+ REAL_CONST(75771.871743255862/8.0),
+ REAL_CONST(75793.994110033076/8.0),
+ REAL_CONST(75816.118091169177/8.0),
+ REAL_CONST(75838.243686428585/8.0),
+ REAL_CONST(75860.370895575848/8.0),
+ REAL_CONST(75882.499718375562/8.0),
+ REAL_CONST(75904.630154592422/8.0),
+ REAL_CONST(75926.762203991224/8.0),
+ REAL_CONST(75948.895866336825/8.0),
+ REAL_CONST(75971.031141394182/8.0),
+ REAL_CONST(75993.168028928325/8.0),
+ REAL_CONST(76015.306528704401/8.0),
+ REAL_CONST(76037.4466404876/8.0),
+ REAL_CONST(76059.588364043215/8.0),
+ REAL_CONST(76081.731699136653/8.0),
+ REAL_CONST(76103.876645533353/8.0),
+ REAL_CONST(76126.023202998884/8.0),
+ REAL_CONST(76148.171371298871/8.0),
+ REAL_CONST(76170.321150199044/8.0),
+ REAL_CONST(76192.472539465205/8.0),
+ REAL_CONST(76214.625538863256/8.0),
+ REAL_CONST(76236.780148159174/8.0),
+ REAL_CONST(76258.936367119008/8.0),
+ REAL_CONST(76281.094195508922/8.0),
+ REAL_CONST(76303.253633095141/8.0),
+ REAL_CONST(76325.414679643975/8.0),
+ REAL_CONST(76347.577334921851/8.0),
+ REAL_CONST(76369.741598695226/8.0),
+ REAL_CONST(76391.907470730686/8.0),
+ REAL_CONST(76414.074950794879/8.0),
+ REAL_CONST(76436.244038654564/8.0),
+ REAL_CONST(76458.414734076548/8.0),
+ REAL_CONST(76480.587036827754/8.0),
+ REAL_CONST(76502.760946675175/8.0),
+ REAL_CONST(76524.936463385893/8.0),
+ REAL_CONST(76547.11358672705/8.0),
+ REAL_CONST(76569.292316465915/8.0),
+ REAL_CONST(76591.472652369819/8.0),
+ REAL_CONST(76613.654594206164/8.0),
+ REAL_CONST(76635.838141742468/8.0),
+ REAL_CONST(76658.023294746308/8.0),
+ REAL_CONST(76680.210052985349/8.0),
+ REAL_CONST(76702.398416227341/8.0),
+ REAL_CONST(76724.588384240138/8.0),
+ REAL_CONST(76746.779956791637/8.0),
+ REAL_CONST(76768.973133649866/8.0),
+ REAL_CONST(76791.167914582897/8.0),
+ REAL_CONST(76813.364299358902/8.0),
+ REAL_CONST(76835.562287746157/8.0),
+ REAL_CONST(76857.761879512967/8.0),
+ REAL_CONST(76879.963074427797/8.0),
+ REAL_CONST(76902.165872259109/8.0),
+ REAL_CONST(76924.37027277553/8.0),
+ REAL_CONST(76946.576275745727/8.0),
+ REAL_CONST(76968.783880938441/8.0),
+ REAL_CONST(76990.993088122515/8.0),
+ REAL_CONST(77013.203897066895/8.0),
+ REAL_CONST(77035.416307540567/8.0),
+ REAL_CONST(77057.630319312622/8.0),
+ REAL_CONST(77079.845932152239/8.0),
+ REAL_CONST(77102.063145828695/8.0),
+ REAL_CONST(77124.281960111301/8.0),
+ REAL_CONST(77146.50237476948/8.0),
+ REAL_CONST(77168.724389572759/8.0),
+ REAL_CONST(77190.948004290723/8.0),
+ REAL_CONST(77213.173218693031/8.0),
+ REAL_CONST(77235.400032549442/8.0),
+ REAL_CONST(77257.628445629802/8.0),
+ REAL_CONST(77279.858457704031/8.0),
+ REAL_CONST(77302.090068542122/8.0),
+ REAL_CONST(77324.323277914169/8.0),
+ REAL_CONST(77346.558085590339/8.0),
+ REAL_CONST(77368.794491340886/8.0),
+ REAL_CONST(77391.032494936138/8.0),
+ REAL_CONST(77413.272096146524/8.0),
+ REAL_CONST(77435.51329474253/8.0),
+ REAL_CONST(77457.756090494731/8.0),
+ REAL_CONST(77480.000483173804/8.0),
+ REAL_CONST(77502.246472550498/8.0),
+ REAL_CONST(77524.494058395634/8.0),
+ REAL_CONST(77546.743240480107/8.0),
+ REAL_CONST(77568.994018574944/8.0),
+ REAL_CONST(77591.246392451198/8.0),
+ REAL_CONST(77613.500361880026/8.0),
+ REAL_CONST(77635.755926632657/8.0),
+ REAL_CONST(77658.013086480438/8.0),
+ REAL_CONST(77680.271841194757/8.0),
+ REAL_CONST(77702.532190547092/8.0),
+ REAL_CONST(77724.794134309021/8.0),
+ REAL_CONST(77747.057672252195/8.0),
+ REAL_CONST(77769.322804148323/8.0),
+ REAL_CONST(77791.589529769248/8.0),
+ REAL_CONST(77813.857848886837/8.0),
+ REAL_CONST(77836.127761273063/8.0),
+ REAL_CONST(77858.399266699998/8.0),
+ REAL_CONST(77880.67236493979/8.0),
+ REAL_CONST(77902.947055764627/8.0),
+ REAL_CONST(77925.223338946831/8.0),
+ REAL_CONST(77947.50121425878/8.0),
+ REAL_CONST(77969.780681472927/8.0),
+ REAL_CONST(77992.061740361838/8.0),
+ REAL_CONST(78014.344390698127/8.0),
+ REAL_CONST(78036.628632254491/8.0),
+ REAL_CONST(78058.914464803747/8.0),
+ REAL_CONST(78081.201888118725/8.0),
+ REAL_CONST(78103.490901972415/8.0),
+ REAL_CONST(78125.781506137821/8.0),
+ REAL_CONST(78148.073700388064/8.0),
+ REAL_CONST(78170.367484496339/8.0),
+ REAL_CONST(78192.662858235926/8.0),
+ REAL_CONST(78214.959821380166/8.0),
+ REAL_CONST(78237.258373702498/8.0),
+ REAL_CONST(78259.558514976452/8.0),
+ REAL_CONST(78281.860244975614/8.0),
+ REAL_CONST(78304.163563473659/8.0),
+ REAL_CONST(78326.468470244363/8.0),
+ REAL_CONST(78348.77496506153/8.0),
+ REAL_CONST(78371.083047699125/8.0),
+ REAL_CONST(78393.392717931114/8.0),
+ REAL_CONST(78415.703975531578/8.0),
+ REAL_CONST(78438.016820274701/8.0),
+ REAL_CONST(78460.331251934695/8.0),
+ REAL_CONST(78482.647270285903/8.0),
+ REAL_CONST(78504.964875102727/8.0),
+ REAL_CONST(78527.284066159627/8.0),
+ REAL_CONST(78549.604843231195/8.0),
+ REAL_CONST(78571.927206092048/8.0),
+ REAL_CONST(78594.251154516911/8.0),
+ REAL_CONST(78616.576688280606/8.0),
+ REAL_CONST(78638.903807157985/8.0),
+ REAL_CONST(78661.232510924034/8.0),
+ REAL_CONST(78683.562799353778/8.0),
+ REAL_CONST(78705.894672222363/8.0),
+ REAL_CONST(78728.228129304945/8.0),
+ REAL_CONST(78750.563170376859/8.0),
+ REAL_CONST(78772.899795213423/8.0),
+ REAL_CONST(78795.238003590101/8.0),
+ REAL_CONST(78817.577795282399/8.0),
+ REAL_CONST(78839.919170065928/8.0),
+ REAL_CONST(78862.262127716356/8.0),
+ REAL_CONST(78884.606668009452/8.0),
+ REAL_CONST(78906.952790721043/8.0),
+ REAL_CONST(78929.300495627045/8.0),
+ REAL_CONST(78951.64978250346/8.0),
+ REAL_CONST(78974.000651126378/8.0),
+ REAL_CONST(78996.353101271932/8.0),
+ REAL_CONST(79018.707132716358/8.0),
+ REAL_CONST(79041.062745235977/8.0),
+ REAL_CONST(79063.41993860717/8.0),
+ REAL_CONST(79085.778712606436/8.0),
+ REAL_CONST(79108.139067010285/8.0),
+ REAL_CONST(79130.501001595389/8.0),
+ REAL_CONST(79152.864516138419/8.0),
+ REAL_CONST(79175.22961041618/8.0),
+ REAL_CONST(79197.596284205531/8.0),
+ REAL_CONST(79219.96453728342/8.0),
+ REAL_CONST(79242.33436942687/8.0),
+ REAL_CONST(79264.705780412987/8.0),
+ REAL_CONST(79287.078770018954/8.0),
+ REAL_CONST(79309.453338022009/8.0),
+ REAL_CONST(79331.829484199508/8.0),
+ REAL_CONST(79354.207208328866/8.0),
+ REAL_CONST(79376.586510187582/8.0),
+ REAL_CONST(79398.967389553218/8.0),
+ REAL_CONST(79421.349846203433/8.0),
+ REAL_CONST(79443.733879915948/8.0),
+ REAL_CONST(79466.119490468584/8.0),
+ REAL_CONST(79488.50667763922/8.0),
+ REAL_CONST(79510.895441205823/8.0),
+ REAL_CONST(79533.285780946433/8.0),
+ REAL_CONST(79555.677696639163/8.0),
+ REAL_CONST(79578.071188062226/8.0),
+ REAL_CONST(79600.466254993895/8.0),
+ REAL_CONST(79622.862897212515/8.0),
+ REAL_CONST(79645.261114496549/8.0),
+ REAL_CONST(79667.660906624471/8.0),
+ REAL_CONST(79690.062273374875/8.0),
+ REAL_CONST(79712.465214526455/8.0),
+ REAL_CONST(79734.869729857935/8.0),
+ REAL_CONST(79757.275819148126/8.0),
+ REAL_CONST(79779.683482175955/8.0),
+ REAL_CONST(79802.092718720378/8.0),
+ REAL_CONST(79824.503528560454/8.0),
+ REAL_CONST(79846.915911475327/8.0),
+ REAL_CONST(79869.329867244203/8.0),
+ REAL_CONST(79891.745395646343/8.0),
+ REAL_CONST(79914.162496461155/8.0),
+ REAL_CONST(79936.581169468045/8.0),
+ REAL_CONST(79959.001414446553/8.0),
+ REAL_CONST(79981.423231176261/8.0),
+ REAL_CONST(80003.846619436852/8.0),
+ REAL_CONST(80026.271579008084/8.0),
+ REAL_CONST(80048.698109669771/8.0),
+ REAL_CONST(80071.12621120183/8.0),
+ REAL_CONST(80093.555883384237/8.0),
+ REAL_CONST(80115.987125997053/8.0),
+ REAL_CONST(80138.419938820414/8.0),
+ REAL_CONST(80160.854321634528/8.0),
+ REAL_CONST(80183.290274219689/8.0),
+ REAL_CONST(80205.727796356281/8.0),
+ REAL_CONST(80228.166887824715/8.0),
+ REAL_CONST(80250.607548405547/8.0),
+ REAL_CONST(80273.049777879336/8.0),
+ REAL_CONST(80295.493576026798/8.0),
+ REAL_CONST(80317.938942628651/8.0),
+ REAL_CONST(80340.385877465727/8.0),
+ REAL_CONST(80362.834380318949/8.0),
+ REAL_CONST(80385.28445096928/8.0),
+ REAL_CONST(80407.736089197788/8.0),
+ REAL_CONST(80430.189294785596/8.0),
+ REAL_CONST(80452.644067513917/8.0),
+ REAL_CONST(80475.100407164035/8.0),
+ REAL_CONST(80497.558313517322/8.0),
+ REAL_CONST(80520.017786355209/8.0),
+ REAL_CONST(80542.478825459213/8.0),
+ REAL_CONST(80564.941430610925/8.0),
+ REAL_CONST(80587.405601592007/8.0),
+ REAL_CONST(80609.871338184195/8.0),
+ REAL_CONST(80632.338640169342/8.0),
+ REAL_CONST(80654.8075073293/8.0),
+ REAL_CONST(80677.277939446067/8.0),
+ REAL_CONST(80699.749936301683/8.0),
+ REAL_CONST(80722.223497678278/8.0),
+ REAL_CONST(80744.698623358039/8.0),
+ REAL_CONST(80767.17531312324/8.0),
+ REAL_CONST(80789.653566756242/8.0),
+ REAL_CONST(80812.133384039465/8.0),
+ REAL_CONST(80834.614764755403/8.0),
+ REAL_CONST(80857.097708686648/8.0),
+ REAL_CONST(80879.582215615854/8.0),
+ REAL_CONST(80902.068285325731/8.0),
+ REAL_CONST(80924.555917599093/8.0),
+ REAL_CONST(80947.045112218824/8.0),
+ REAL_CONST(80969.535868967869/8.0),
+ REAL_CONST(80992.028187629272/8.0),
+ REAL_CONST(81014.522067986123/8.0),
+ REAL_CONST(81037.017509821613/8.0),
+ REAL_CONST(81059.514512919006/8.0),
+ REAL_CONST(81082.013077061609/8.0),
+ REAL_CONST(81104.513202032831/8.0),
+ REAL_CONST(81127.014887616184/8.0),
+ REAL_CONST(81149.518133595193/8.0),
+ REAL_CONST(81172.022939753486/8.0),
+ REAL_CONST(81194.529305874807/8.0),
+ REAL_CONST(81217.037231742899/8.0),
+ REAL_CONST(81239.546717141639/8.0),
+ REAL_CONST(81262.057761854958/8.0),
+ REAL_CONST(81284.570365666848/8.0),
+ REAL_CONST(81307.084528361403/8.0),
+ REAL_CONST(81329.600249722775/8.0),
+ REAL_CONST(81352.117529535186/8.0),
+ REAL_CONST(81374.636367582949/8.0),
+ REAL_CONST(81397.156763650448/8.0),
+ REAL_CONST(81419.678717522125/8.0),
+ REAL_CONST(81442.202228982511/8.0),
+ REAL_CONST(81464.727297816222/8.0),
+ REAL_CONST(81487.253923807933/8.0),
+ REAL_CONST(81509.782106742379/8.0),
+ REAL_CONST(81532.311846404409/8.0),
+ REAL_CONST(81554.843142578902/8.0),
+ REAL_CONST(81577.375995050839/8.0),
+ REAL_CONST(81599.910403605274/8.0),
+ REAL_CONST(81622.446368027333/8.0),
+ REAL_CONST(81644.983888102215/8.0),
+ REAL_CONST(81667.522963615178/8.0),
+ REAL_CONST(81690.063594351581/8.0),
+ REAL_CONST(81712.605780096841/8.0),
+ REAL_CONST(81735.149520636449/8.0),
+ REAL_CONST(81757.694815755967/8.0),
+ REAL_CONST(81780.241665241047/8.0),
+ REAL_CONST(81802.79006887741/8.0),
+ REAL_CONST(81825.340026450824/8.0),
+ REAL_CONST(81847.891537747171/8.0),
+ REAL_CONST(81870.444602552379/8.0),
+ REAL_CONST(81892.999220652477/8.0),
+ REAL_CONST(81915.555391833506/8.0),
+ REAL_CONST(81938.113115881672/8.0),
+ REAL_CONST(81960.672392583176/8.0),
+ REAL_CONST(81983.233221724338/8.0),
+ REAL_CONST(82005.795603091537/8.0),
+ REAL_CONST(82028.359536471224/8.0),
+ REAL_CONST(82050.925021649906/8.0),
+ REAL_CONST(82073.492058414209/8.0),
+ REAL_CONST(82096.060646550788/8.0),
+ REAL_CONST(82118.630785846399/8.0),
+ REAL_CONST(82141.202476087841/8.0),
+ REAL_CONST(82163.775717062032/8.0),
+ REAL_CONST(82186.35050855593/8.0),
+ REAL_CONST(82208.926850356569/8.0),
+ REAL_CONST(82231.504742251054/8.0),
+ REAL_CONST(82254.084184026578/8.0),
+ REAL_CONST(82276.665175470393/8.0),
+ REAL_CONST(82299.24771636985/8.0),
+ REAL_CONST(82321.831806512317/8.0),
+ REAL_CONST(82344.417445685307/8.0),
+ REAL_CONST(82367.004633676348/8.0),
+ REAL_CONST(82389.593370273054/8.0),
+ REAL_CONST(82412.183655263143/8.0),
+ REAL_CONST(82434.775488434374/8.0),
+ REAL_CONST(82457.368869574595/8.0),
+ REAL_CONST(82479.963798471697/8.0),
+ REAL_CONST(82502.560274913689/8.0),
+ REAL_CONST(82525.158298688606/8.0),
+ REAL_CONST(82547.757869584602/8.0),
+ REAL_CONST(82570.35898738986/8.0),
+ REAL_CONST(82592.961651892678/8.0),
+ REAL_CONST(82615.565862881398/8.0),
+ REAL_CONST(82638.171620144421/8.0),
+ REAL_CONST(82660.778923470265/8.0),
+ REAL_CONST(82683.387772647475/8.0),
+ REAL_CONST(82705.998167464713/8.0),
+ REAL_CONST(82728.610107710658/8.0),
+ REAL_CONST(82751.223593174116/8.0),
+ REAL_CONST(82773.83862364394/8.0),
+ REAL_CONST(82796.45519890904/8.0),
+ REAL_CONST(82819.073318758441/8.0),
+ REAL_CONST(82841.692982981185/8.0),
+ REAL_CONST(82864.314191366429/8.0),
+ REAL_CONST(82886.936943703375/8.0),
+ REAL_CONST(82909.561239781324/8.0),
+ REAL_CONST(82932.187079389638/8.0),
+ REAL_CONST(82954.814462317736/8.0),
+ REAL_CONST(82977.443388355125/8.0),
+ REAL_CONST(83000.073857291369/8.0),
+ REAL_CONST(83022.70586891612/8.0),
+ REAL_CONST(83045.339423019104/8.0),
+ REAL_CONST(83067.974519390089/8.0),
+ REAL_CONST(83090.611157818959/8.0),
+ REAL_CONST(83113.249338095629/8.0),
+ REAL_CONST(83135.8890600101/8.0),
+ REAL_CONST(83158.530323352461/8.0),
+ REAL_CONST(83181.173127912858/8.0),
+ REAL_CONST(83203.817473481497/8.0),
+ REAL_CONST(83226.463359848669/8.0),
+ REAL_CONST(83249.11078680474/8.0),
+ REAL_CONST(83271.759754140134/8.0),
+ REAL_CONST(83294.410261645375/8.0),
+ REAL_CONST(83317.062309111003/8.0),
+ REAL_CONST(83339.715896327703/8.0),
+ REAL_CONST(83362.371023086147/8.0),
+ REAL_CONST(83385.027689177165/8.0),
+ REAL_CONST(83407.685894391587/8.0),
+ REAL_CONST(83430.345638520361/8.0),
+ REAL_CONST(83453.006921354478/8.0),
+ REAL_CONST(83475.669742685001/8.0),
+ REAL_CONST(83498.334102303095/8.0),
+ REAL_CONST(83520.999999999942/8.0),
+ REAL_CONST(83543.667435566866/8.0),
+ REAL_CONST(83566.336408795192/8.0),
+ REAL_CONST(83589.006919476349/8.0),
+ REAL_CONST(83611.678967401851/8.0),
+ REAL_CONST(83634.352552363242/8.0),
+ REAL_CONST(83657.027674152167/8.0),
+ REAL_CONST(83679.704332560359/8.0),
+ REAL_CONST(83702.382527379552/8.0),
+ REAL_CONST(83725.062258401638/8.0),
+ REAL_CONST(83747.743525418511/8.0),
+ REAL_CONST(83770.42632822218/8.0),
+ REAL_CONST(83793.110666604684/8.0),
+ REAL_CONST(83815.796540358162/8.0),
+ REAL_CONST(83838.483949274829/8.0),
+ REAL_CONST(83861.172893146941/8.0),
+ REAL_CONST(83883.863371766842/8.0),
+ REAL_CONST(83906.555384926964/8.0),
+ REAL_CONST(83929.248932419752/8.0),
+ REAL_CONST(83951.944014037799/8.0),
+ REAL_CONST(83974.640629573696/8.0),
+ REAL_CONST(83997.338778820151/8.0),
+ REAL_CONST(84020.038461569929/8.0),
+ REAL_CONST(84042.739677615857/8.0),
+ REAL_CONST(84065.442426750829/8.0),
+ REAL_CONST(84088.146708767847/8.0),
+ REAL_CONST(84110.852523459922/8.0),
+ REAL_CONST(84133.559870620171/8.0),
+ REAL_CONST(84156.268750041796/8.0),
+ REAL_CONST(84178.979161518029/8.0),
+ REAL_CONST(84201.691104842204/8.0),
+ REAL_CONST(84224.404579807713/8.0),
+ REAL_CONST(84247.119586208006/8.0),
+ REAL_CONST(84269.83612383662/8.0),
+ REAL_CONST(84292.55419248715/8.0),
+ REAL_CONST(84315.273791953281/8.0),
+ REAL_CONST(84337.994922028738/8.0),
+ REAL_CONST(84360.717582507335/8.0),
+ REAL_CONST(84383.441773182945/8.0),
+ REAL_CONST(84406.167493849513/8.0),
+ REAL_CONST(84428.894744301069/8.0),
+ REAL_CONST(84451.623524331691/8.0),
+ REAL_CONST(84474.353833735542/8.0),
+ REAL_CONST(84497.085672306828/8.0),
+ REAL_CONST(84519.819039839858/8.0),
+ REAL_CONST(84542.553936128999/8.0),
+ REAL_CONST(84565.290360968676/8.0),
+ REAL_CONST(84588.028314153402/8.0),
+ REAL_CONST(84610.767795477717/8.0),
+ REAL_CONST(84633.508804736295/8.0),
+ REAL_CONST(84656.251341723822/8.0),
+ REAL_CONST(84678.995406235073/8.0),
+ REAL_CONST(84701.740998064924/8.0),
+ REAL_CONST(84724.488117008252/8.0),
+ REAL_CONST(84747.236762860062/8.0),
+ REAL_CONST(84769.986935415407/8.0),
+ REAL_CONST(84792.73863446941/8.0),
+ REAL_CONST(84815.491859817252/8.0),
+ REAL_CONST(84838.246611254188/8.0),
+ REAL_CONST(84861.002888575575/8.0),
+ REAL_CONST(84883.760691576768/8.0),
+ REAL_CONST(84906.520020053256/8.0),
+ REAL_CONST(84929.28087380057/8.0),
+ REAL_CONST(84952.043252614312/8.0),
+ REAL_CONST(84974.807156290146/8.0),
+ REAL_CONST(84997.572584623806/8.0),
+ REAL_CONST(85020.339537411113/8.0),
+ REAL_CONST(85043.108014447949/8.0),
+ REAL_CONST(85065.878015530237/8.0),
+ REAL_CONST(85088.649540453989/8.0),
+ REAL_CONST(85111.422589015303/8.0),
+ REAL_CONST(85134.197161010321/8.0),
+ REAL_CONST(85156.973256235244/8.0),
+ REAL_CONST(85179.750874486374/8.0),
+ REAL_CONST(85202.530015560071/8.0),
+ REAL_CONST(85225.310679252725/8.0),
+ REAL_CONST(85248.092865360857/8.0),
+ REAL_CONST(85270.876573681016/8.0),
+ REAL_CONST(85293.661804009811/8.0),
+ REAL_CONST(85316.448556143951/8.0),
+ REAL_CONST(85339.236829880188/8.0),
+ REAL_CONST(85362.026625015351/8.0),
+ REAL_CONST(85384.817941346351/8.0),
+ REAL_CONST(85407.610778670132/8.0),
+ REAL_CONST(85430.405136783724/8.0),
+ REAL_CONST(85453.201015484257/8.0),
+ REAL_CONST(85475.998414568865/8.0),
+ REAL_CONST(85498.797333834795/8.0),
+ REAL_CONST(85521.597773079353/8.0),
+ REAL_CONST(85544.399732099904/8.0),
+ REAL_CONST(85567.203210693886/8.0),
+ REAL_CONST(85590.008208658808/8.0),
+ REAL_CONST(85612.814725792239/8.0),
+ REAL_CONST(85635.62276189182/8.0),
+ REAL_CONST(85658.432316755265/8.0),
+ REAL_CONST(85681.243390180331/8.0),
+ REAL_CONST(85704.055981964877/8.0),
+ REAL_CONST(85726.870091906807/8.0),
+ REAL_CONST(85749.685719804082/8.0),
+ REAL_CONST(85772.502865454764/8.0),
+ REAL_CONST(85795.321528656961/8.0),
+ REAL_CONST(85818.141709208852/8.0),
+ REAL_CONST(85840.963406908675/8.0),
+ REAL_CONST(85863.78662155474/8.0),
+ REAL_CONST(85886.611352945445/8.0),
+ REAL_CONST(85909.437600879217/8.0),
+ REAL_CONST(85932.26536515457/8.0),
+ REAL_CONST(85955.094645570091/8.0),
+ REAL_CONST(85977.92544192441/8.0),
+ REAL_CONST(86000.757754016275/8.0),
+ REAL_CONST(86023.591581644432/8.0),
+ REAL_CONST(86046.426924607746/8.0),
+ REAL_CONST(86069.263782705122/8.0),
+ REAL_CONST(86092.102155735556/8.0),
+ REAL_CONST(86114.942043498071/8.0),
+ REAL_CONST(86137.783445791807/8.0),
+ REAL_CONST(86160.626362415918/8.0),
+ REAL_CONST(86183.470793169676/8.0),
+ REAL_CONST(86206.316737852379/8.0),
+ REAL_CONST(86229.164196263402/8.0),
+ REAL_CONST(86252.013168202204/8.0),
+ REAL_CONST(86274.863653468303/8.0),
+ REAL_CONST(86297.715651861261/8.0),
+ REAL_CONST(86320.569163180728/8.0),
+ REAL_CONST(86343.424187226425/8.0),
+ REAL_CONST(86366.280723798132/8.0),
+ REAL_CONST(86389.138772695675/8.0),
+ REAL_CONST(86411.998333718977/8.0),
+ REAL_CONST(86434.859406668009/8.0),
+ REAL_CONST(86457.721991342827/8.0),
+ REAL_CONST(86480.586087543532/8.0),
+ REAL_CONST(86503.451695070296/8.0),
+ REAL_CONST(86526.318813723352/8.0),
+ REAL_CONST(86549.187443303032/8.0),
+ REAL_CONST(86572.057583609683/8.0),
+ REAL_CONST(86594.929234443756/8.0),
+ REAL_CONST(86617.802395605773/8.0),
+ REAL_CONST(86640.677066896271/8.0),
+ REAL_CONST(86663.553248115903/8.0),
+ REAL_CONST(86686.43093906538/8.0),
+ REAL_CONST(86709.310139545443/8.0),
+ REAL_CONST(86732.190849356964/8.0),
+ REAL_CONST(86755.073068300815/8.0),
+ REAL_CONST(86777.956796177954/8.0),
+ REAL_CONST(86800.842032789442/8.0),
+ REAL_CONST(86823.728777936354/8.0),
+ REAL_CONST(86846.617031419853/8.0),
+ REAL_CONST(86869.506793041175/8.0),
+ REAL_CONST(86892.398062601613/8.0),
+ REAL_CONST(86915.290839902518/8.0),
+ REAL_CONST(86938.185124745316/8.0),
+ REAL_CONST(86961.080916931489/8.0),
+ REAL_CONST(86983.978216262592/8.0),
+ REAL_CONST(87006.87702254027/8.0),
+ REAL_CONST(87029.777335566177/8.0),
+ REAL_CONST(87052.67915514209/8.0),
+ REAL_CONST(87075.582481069796/8.0),
+ REAL_CONST(87098.487313151185/8.0),
+ REAL_CONST(87121.39365118822/8.0),
+ REAL_CONST(87144.301494982894/8.0),
+ REAL_CONST(87167.210844337285/8.0),
+ REAL_CONST(87190.121699053532/8.0),
+ REAL_CONST(87213.034058933845/8.0),
+ REAL_CONST(87235.947923780506/8.0),
+ REAL_CONST(87258.863293395829/8.0),
+ REAL_CONST(87281.780167582241/8.0),
+ REAL_CONST(87304.698546142172/8.0),
+ REAL_CONST(87327.618428878181/8.0),
+ REAL_CONST(87350.539815592856/8.0),
+ REAL_CONST(87373.462706088845/8.0),
+ REAL_CONST(87396.387100168897/8.0),
+ REAL_CONST(87419.312997635774/8.0),
+ REAL_CONST(87442.240398292357/8.0),
+ REAL_CONST(87465.16930194154/8.0),
+ REAL_CONST(87488.099708386319/8.0),
+ REAL_CONST(87511.031617429733/8.0),
+ REAL_CONST(87533.965028874911/8.0),
+ REAL_CONST(87556.899942525008/8.0),
+ REAL_CONST(87579.836358183282/8.0),
+ REAL_CONST(87602.774275653021/8.0),
+ REAL_CONST(87625.713694737613/8.0),
+ REAL_CONST(87648.654615240492/8.0),
+ REAL_CONST(87671.597036965148/8.0),
+ REAL_CONST(87694.540959715145/8.0),
+ REAL_CONST(87717.486383294105/8.0),
+ REAL_CONST(87740.433307505737/8.0),
+ REAL_CONST(87763.381732153779/8.0),
+ REAL_CONST(87786.331657042057/8.0),
+ REAL_CONST(87809.283081974456/8.0),
+ REAL_CONST(87832.236006754916/8.0),
+ REAL_CONST(87855.190431187453/8.0),
+ REAL_CONST(87878.146355076155/8.0),
+ REAL_CONST(87901.103778225151/8.0),
+ REAL_CONST(87924.062700438633/8.0),
+ REAL_CONST(87947.023121520891/8.0),
+ REAL_CONST(87969.985041276246/8.0),
+ REAL_CONST(87992.948459509105/8.0),
+ REAL_CONST(88015.913376023906/8.0),
+ REAL_CONST(88038.879790625171/8.0),
+ REAL_CONST(88061.847703117513/8.0),
+ REAL_CONST(88084.817113305573/8.0),
+ REAL_CONST(88107.788020994049/8.0),
+ REAL_CONST(88130.760425987726/8.0),
+ REAL_CONST(88153.734328091465/8.0),
+ REAL_CONST(88176.709727110137/8.0),
+ REAL_CONST(88199.686622848749/8.0),
+ REAL_CONST(88222.665015112303/8.0),
+ REAL_CONST(88245.644903705906/8.0),
+ REAL_CONST(88268.626288434709/8.0),
+ REAL_CONST(88291.609169103947/8.0),
+ REAL_CONST(88314.593545518903/8.0),
+ REAL_CONST(88337.579417484914/8.0),
+ REAL_CONST(88360.566784807408/8.0),
+ REAL_CONST(88383.555647291854/8.0),
+ REAL_CONST(88406.546004743795/8.0),
+ REAL_CONST(88429.537856968818/8.0),
+ REAL_CONST(88452.531203772611/8.0),
+ REAL_CONST(88475.52604496089/8.0),
+ REAL_CONST(88498.522380339447/8.0),
+ REAL_CONST(88521.52020971413/8.0),
+ REAL_CONST(88544.519532890874/8.0),
+ REAL_CONST(88567.520349675644/8.0),
+ REAL_CONST(88590.522659874507/8.0),
+ REAL_CONST(88613.526463293543/8.0),
+ REAL_CONST(88636.531759738922/8.0),
+ REAL_CONST(88659.538549016899/8.0),
+ REAL_CONST(88682.546830933745/8.0),
+ REAL_CONST(88705.556605295846/8.0),
+ REAL_CONST(88728.567871909589/8.0),
+ REAL_CONST(88751.580630581491/8.0),
+ REAL_CONST(88774.594881118086/8.0),
+ REAL_CONST(88797.610623325963/8.0),
+ REAL_CONST(88820.62785701183/8.0),
+ REAL_CONST(88843.646581982393/8.0),
+ REAL_CONST(88866.666798044462/8.0),
+ REAL_CONST(88889.688505004888/8.0),
+ REAL_CONST(88912.711702670611/8.0),
+ REAL_CONST(88935.7363908486/8.0),
+ REAL_CONST(88958.762569345898/8.0),
+ REAL_CONST(88981.790237969632/8.0),
+ REAL_CONST(89004.81939652696/8.0),
+ REAL_CONST(89027.850044825114/8.0),
+ REAL_CONST(89050.882182671412/8.0),
+ REAL_CONST(89073.9158098732/8.0),
+ REAL_CONST(89096.950926237885/8.0),
+ REAL_CONST(89119.987531572973/8.0),
+ REAL_CONST(89143.025625686001/8.0),
+ REAL_CONST(89166.065208384563/8.0),
+ REAL_CONST(89189.106279476357/8.0),
+ REAL_CONST(89212.148838769106/8.0),
+ REAL_CONST(89235.192886070581/8.0),
+ REAL_CONST(89258.238421188667/8.0),
+ REAL_CONST(89281.285443931265/8.0),
+ REAL_CONST(89304.333954106376/8.0),
+ REAL_CONST(89327.383951522017/8.0),
+ REAL_CONST(89350.435435986306/8.0),
+ REAL_CONST(89373.488407307406/8.0),
+ REAL_CONST(89396.542865293537/8.0),
+ REAL_CONST(89419.598809753006/8.0),
+ REAL_CONST(89442.656240494165/8.0),
+ REAL_CONST(89465.715157325409/8.0),
+ REAL_CONST(89488.775560055219/8.0),
+ REAL_CONST(89511.837448492137/8.0),
+ REAL_CONST(89534.900822444746/8.0),
+ REAL_CONST(89557.965681721733/8.0),
+ REAL_CONST(89581.032026131812/8.0),
+ REAL_CONST(89604.099855483742/8.0),
+ REAL_CONST(89627.169169586399/8.0),
+ REAL_CONST(89650.239968248672/8.0),
+ REAL_CONST(89673.312251279538/8.0),
+ REAL_CONST(89696.386018488018/8.0),
+ REAL_CONST(89719.461269683205/8.0),
+ REAL_CONST(89742.53800467425/8.0),
+ REAL_CONST(89765.616223270365/8.0),
+ REAL_CONST(89788.69592528083/8.0),
+ REAL_CONST(89811.777110514988/8.0),
+ REAL_CONST(89834.859778782207/8.0),
+ REAL_CONST(89857.943929891975/8.0),
+ REAL_CONST(89881.029563653807/8.0),
+ REAL_CONST(89904.116679877261/8.0),
+ REAL_CONST(89927.205278372014/8.0),
+ REAL_CONST(89950.29535894774/8.0),
+ REAL_CONST(89973.386921414218/8.0),
+ REAL_CONST(89996.479965581268/8.0),
+ REAL_CONST(90019.574491258769/8.0),
+ REAL_CONST(90042.670498256688/8.0),
+ REAL_CONST(90065.767986385021/8.0),
+ REAL_CONST(90088.866955453836/8.0),
+ REAL_CONST(90111.967405273259/8.0),
+ REAL_CONST(90135.069335653476/8.0),
+ REAL_CONST(90158.172746404758/8.0),
+ REAL_CONST(90181.277637337407/8.0),
+ REAL_CONST(90204.384008261797/8.0),
+ REAL_CONST(90227.49185898836/8.0),
+ REAL_CONST(90250.601189327586/8.0),
+ REAL_CONST(90273.711999090039/8.0),
+ REAL_CONST(90296.824288086325/8.0),
+ REAL_CONST(90319.938056127125/8.0),
+ REAL_CONST(90343.053303023189/8.0),
+ REAL_CONST(90366.170028585286/8.0),
+ REAL_CONST(90389.288232624298/8.0),
+ REAL_CONST(90412.407914951138/8.0),
+ REAL_CONST(90435.529075376777/8.0),
+ REAL_CONST(90458.651713712257/8.0),
+ REAL_CONST(90481.775829768681/8.0),
+ REAL_CONST(90504.901423357209/8.0),
+ REAL_CONST(90528.028494289058/8.0),
+ REAL_CONST(90551.157042375504/8.0),
+ REAL_CONST(90574.287067427911/8.0),
+ REAL_CONST(90597.418569257643/8.0),
+ REAL_CONST(90620.551547676194/8.0),
+ REAL_CONST(90643.686002495073/8.0),
+ REAL_CONST(90666.821933525847/8.0),
+ REAL_CONST(90689.959340580186/8.0),
+ REAL_CONST(90713.098223469773/8.0),
+ REAL_CONST(90736.238582006365/8.0),
+ REAL_CONST(90759.380416001804/8.0),
+ REAL_CONST(90782.523725267951/8.0),
+ REAL_CONST(90805.668509616764/8.0),
+ REAL_CONST(90828.814768860233/8.0),
+ REAL_CONST(90851.962502810435/8.0),
+ REAL_CONST(90875.11171127946/8.0),
+ REAL_CONST(90898.262394079517/8.0),
+ REAL_CONST(90921.414551022855/8.0),
+ REAL_CONST(90944.568181921743/8.0),
+ REAL_CONST(90967.72328658856/8.0),
+ REAL_CONST(90990.879864835719/8.0),
+ REAL_CONST(91014.037916475718/8.0),
+ REAL_CONST(91037.19744132107/8.0),
+ REAL_CONST(91060.358439184391/8.0),
+ REAL_CONST(91083.520909878338/8.0),
+ REAL_CONST(91106.684853215629/8.0),
+ REAL_CONST(91129.850269009039/8.0),
+ REAL_CONST(91153.017157071401/8.0),
+ REAL_CONST(91176.185517215621/8.0),
+ REAL_CONST(91199.355349254649/8.0),
+ REAL_CONST(91222.526653001492/8.0),
+ REAL_CONST(91245.699428269247/8.0),
+ REAL_CONST(91268.873674871036/8.0),
+ REAL_CONST(91292.049392620058/8.0),
+ REAL_CONST(91315.226581329553/8.0),
+ REAL_CONST(91338.405240812834/8.0),
+ REAL_CONST(91361.585370883287/8.0),
+ REAL_CONST(91384.766971354344/8.0),
+ REAL_CONST(91407.950042039476/8.0),
+ REAL_CONST(91431.134582752245/8.0),
+ REAL_CONST(91454.320593306256/8.0),
+ REAL_CONST(91477.508073515171/8.0),
+ REAL_CONST(91500.697023192712/8.0),
+ REAL_CONST(91523.887442152685/8.0),
+ REAL_CONST(91547.07933020893/8.0),
+ REAL_CONST(91570.272687175326/8.0),
+ REAL_CONST(91593.467512865856/8.0),
+ REAL_CONST(91616.663807094534/8.0),
+ REAL_CONST(91639.861569675442/8.0),
+ REAL_CONST(91663.060800422725/8.0),
+ REAL_CONST(91686.261499150554/8.0),
+ REAL_CONST(91709.463665673218/8.0),
+ REAL_CONST(91732.66729980502/8.0),
+ REAL_CONST(91755.872401360321/8.0),
+ REAL_CONST(91779.078970153569/8.0),
+ REAL_CONST(91802.287005999257/8.0),
+ REAL_CONST(91825.49650871192/8.0),
+ REAL_CONST(91848.707478106167/8.0),
+ REAL_CONST(91871.91991399668/8.0),
+ REAL_CONST(91895.133816198169/8.0),
+ REAL_CONST(91918.349184525418/8.0),
+ REAL_CONST(91941.566018793281/8.0),
+ REAL_CONST(91964.784318816659/8.0),
+ REAL_CONST(91988.004084410495/8.0),
+ REAL_CONST(92011.22531538982/8.0),
+ REAL_CONST(92034.448011569708/8.0),
+ REAL_CONST(92057.672172765277/8.0),
+ REAL_CONST(92080.897798791746/8.0),
+ REAL_CONST(92104.124889464365/8.0),
+ REAL_CONST(92127.353444598411/8.0),
+ REAL_CONST(92150.58346400928/8.0),
+ REAL_CONST(92173.814947512379/8.0),
+ REAL_CONST(92197.04789492322/8.0),
+ REAL_CONST(92220.282306057314/8.0),
+ REAL_CONST(92243.518180730272/8.0),
+ REAL_CONST(92266.755518757753/8.0),
+ REAL_CONST(92289.994319955469/8.0),
+ REAL_CONST(92313.234584139194/8.0),
+ REAL_CONST(92336.476311124774/8.0),
+ REAL_CONST(92359.719500728082/8.0),
+ REAL_CONST(92382.964152765067/8.0),
+ REAL_CONST(92406.210267051734/8.0),
+ REAL_CONST(92429.457843404161/8.0),
+ REAL_CONST(92452.706881638471/8.0),
+ REAL_CONST(92475.957381570814/8.0),
+ REAL_CONST(92499.209343017443/8.0),
+ REAL_CONST(92522.462765794655/8.0),
+ REAL_CONST(92545.717649718805/8.0),
+ REAL_CONST(92568.973994606305/8.0),
+ REAL_CONST(92592.231800273614/8.0),
+ REAL_CONST(92615.491066537259/8.0),
+ REAL_CONST(92638.751793213814/8.0),
+ REAL_CONST(92662.01398011994/8.0),
+ REAL_CONST(92685.277627072326/8.0),
+ REAL_CONST(92708.54273388772/8.0),
+ REAL_CONST(92731.809300382942/8.0),
+ REAL_CONST(92755.077326374871/8.0),
+ REAL_CONST(92778.346811680414/8.0),
+ REAL_CONST(92801.617756116568/8.0),
+ REAL_CONST(92824.890159500384/8.0),
+ REAL_CONST(92848.164021648947/8.0),
+ REAL_CONST(92871.439342379424/8.0),
+ REAL_CONST(92894.716121509016/8.0),
+ REAL_CONST(92917.994358855023/8.0),
+ REAL_CONST(92941.274054234746/8.0),
+ REAL_CONST(92964.555207465572/8.0),
+ REAL_CONST(92987.837818364962/8.0),
+ REAL_CONST(93011.121886750407/8.0),
+ REAL_CONST(93034.407412439468/8.0),
+ REAL_CONST(93057.694395249753/8.0),
+ REAL_CONST(93080.982834998955/8.0),
+ REAL_CONST(93104.272731504767/8.0),
+ REAL_CONST(93127.564084584999/8.0),
+ REAL_CONST(93150.856894057491/8.0),
+ REAL_CONST(93174.15115974014/8.0),
+ REAL_CONST(93197.446881450916/8.0),
+ REAL_CONST(93220.744059007804/8.0),
+ REAL_CONST(93244.04269222889/8.0),
+ REAL_CONST(93267.342780932304/8.0),
+ REAL_CONST(93290.644324936235/8.0),
+ REAL_CONST(93313.947324058914/8.0),
+ REAL_CONST(93337.251778118633/8.0),
+ REAL_CONST(93360.557686933767/8.0),
+ REAL_CONST(93383.865050322696/8.0),
+ REAL_CONST(93407.173868103928/8.0),
+ REAL_CONST(93430.484140095941/8.0),
+ REAL_CONST(93453.795866117362/8.0),
+ REAL_CONST(93477.109045986799/8.0),
+ REAL_CONST(93500.423679522952/8.0),
+ REAL_CONST(93523.739766544561/8.0),
+ REAL_CONST(93547.057306870454/8.0),
+ REAL_CONST(93570.376300319491/8.0),
+ REAL_CONST(93593.696746710571/8.0),
+ REAL_CONST(93617.018645862699/8.0),
+ REAL_CONST(93640.341997594893/8.0),
+ REAL_CONST(93663.666801726242/8.0),
+ REAL_CONST(93686.993058075881/8.0),
+ REAL_CONST(93710.320766463032/8.0),
+ REAL_CONST(93733.64992670693/8.0),
+ REAL_CONST(93756.980538626914/8.0),
+ REAL_CONST(93780.312602042337/8.0),
+ REAL_CONST(93803.646116772637/8.0),
+ REAL_CONST(93826.981082637285/8.0),
+ REAL_CONST(93850.317499455836/8.0),
+ REAL_CONST(93873.655367047861/8.0),
+ REAL_CONST(93896.994685233032/8.0),
+ REAL_CONST(93920.335453831038/8.0),
+ REAL_CONST(93943.677672661666/8.0),
+ REAL_CONST(93967.021341544707/8.0),
+ REAL_CONST(93990.366460300051/8.0),
+ REAL_CONST(94013.713028747632/8.0),
+ REAL_CONST(94037.061046707429/8.0),
+ REAL_CONST(94060.410513999494/8.0),
+ REAL_CONST(94083.761430443905/8.0),
+ REAL_CONST(94107.113795860845/8.0),
+ REAL_CONST(94130.467610070496/8.0),
+ REAL_CONST(94153.822872893157/8.0),
+ REAL_CONST(94177.179584149111/8.0),
+ REAL_CONST(94200.537743658759/8.0),
+ REAL_CONST(94223.897351242529/8.0),
+ REAL_CONST(94247.25840672091/8.0),
+ REAL_CONST(94270.620909914433/8.0),
+ REAL_CONST(94293.98486064373/8.0),
+ REAL_CONST(94317.350258729421/8.0),
+ REAL_CONST(94340.71710399224/8.0),
+ REAL_CONST(94364.085396252936/8.0),
+ REAL_CONST(94387.455135332348/8.0),
+ REAL_CONST(94410.82632105134/8.0),
+ REAL_CONST(94434.198953230851/8.0),
+ REAL_CONST(94457.573031691878/8.0),
+ REAL_CONST(94480.948556255447/8.0),
+ REAL_CONST(94504.325526742658/8.0),
+ REAL_CONST(94527.70394297468/8.0),
+ REAL_CONST(94551.083804772716/8.0),
+ REAL_CONST(94574.465111958023/8.0),
+ REAL_CONST(94597.847864351934/8.0),
+ REAL_CONST(94621.232061775823/8.0),
+ REAL_CONST(94644.617704051096/8.0),
+ REAL_CONST(94668.004790999272/8.0),
+ REAL_CONST(94691.393322441872/8.0),
+ REAL_CONST(94714.783298200506/8.0),
+ REAL_CONST(94738.174718096794/8.0),
+ REAL_CONST(94761.567581952477/8.0),
+ REAL_CONST(94784.961889589307/8.0),
+ REAL_CONST(94808.357640829097/8.0),
+ REAL_CONST(94831.754835493703/8.0),
+ REAL_CONST(94855.153473405066/8.0),
+ REAL_CONST(94878.553554385173/8.0),
+ REAL_CONST(94901.955078256055/8.0),
+ REAL_CONST(94925.358044839784/8.0),
+ REAL_CONST(94948.762453958523/8.0),
+ REAL_CONST(94972.168305434476/8.0),
+ REAL_CONST(94995.575599089891/8.0),
+ REAL_CONST(95018.984334747074/8.0),
+ REAL_CONST(95042.394512228391/8.0),
+ REAL_CONST(95065.806131356265/8.0),
+ REAL_CONST(95089.219191953176/8.0),
+ REAL_CONST(95112.633693841635/8.0),
+ REAL_CONST(95136.04963684424/8.0),
+ REAL_CONST(95159.467020783617/8.0),
+ REAL_CONST(95182.885845482466/8.0),
+ REAL_CONST(95206.306110763529/8.0),
+ REAL_CONST(95229.727816449609/8.0),
+ REAL_CONST(95253.150962363579/8.0),
+ REAL_CONST(95276.575548328314/8.0),
+ REAL_CONST(95300.001574166803/8.0),
+ REAL_CONST(95323.429039702052/8.0),
+ REAL_CONST(95346.857944757154/8.0),
+ REAL_CONST(95370.288289155214/8.0),
+ REAL_CONST(95393.720072719429/8.0),
+ REAL_CONST(95417.153295273019/8.0),
+ REAL_CONST(95440.587956639298/8.0),
+ REAL_CONST(95464.024056641589/8.0),
+ REAL_CONST(95487.461595103305/8.0),
+ REAL_CONST(95510.900571847902/8.0),
+ REAL_CONST(95534.340986698866/8.0),
+ REAL_CONST(95557.782839479783/8.0),
+ REAL_CONST(95581.226130014256/8.0),
+ REAL_CONST(95604.670858125959/8.0),
+ REAL_CONST(95628.117023638595/8.0),
+ REAL_CONST(95651.564626375985/8.0),
+ REAL_CONST(95675.013666161918/8.0),
+ REAL_CONST(95698.464142820303/8.0),
+ REAL_CONST(95721.916056175076/8.0),
+ REAL_CONST(95745.369406050231/8.0),
+ REAL_CONST(95768.824192269807/8.0),
+ REAL_CONST(95792.280414657915/8.0),
+ REAL_CONST(95815.738073038709/8.0),
+ REAL_CONST(95839.197167236387/8.0),
+ REAL_CONST(95862.657697075221/8.0),
+ REAL_CONST(95886.11966237954/8.0),
+ REAL_CONST(95909.583062973688/8.0),
+ REAL_CONST(95933.047898682111/8.0),
+ REAL_CONST(95956.514169329268/8.0),
+ REAL_CONST(95979.981874739708/8.0),
+ REAL_CONST(96003.451014738006/8.0),
+ REAL_CONST(96026.921589148798/8.0),
+ REAL_CONST(96050.393597796792/8.0),
+ REAL_CONST(96073.867040506724/8.0),
+ REAL_CONST(96097.341917103375/8.0),
+ REAL_CONST(96120.818227411626/8.0),
+ REAL_CONST(96144.295971256375/8.0),
+ REAL_CONST(96167.775148462577/8.0),
+ REAL_CONST(96191.255758855244/8.0),
+ REAL_CONST(96214.737802259449/8.0),
+ REAL_CONST(96238.221278500292/8.0),
+ REAL_CONST(96261.70618740299/8.0),
+ REAL_CONST(96285.192528792715/8.0),
+ REAL_CONST(96308.680302494788/8.0),
+ REAL_CONST(96332.169508334526/8.0),
+ REAL_CONST(96355.660146137321/8.0),
+ REAL_CONST(96379.152215728609/8.0),
+ REAL_CONST(96402.645716933868/8.0),
+ REAL_CONST(96426.14064957868/8.0),
+ REAL_CONST(96449.637013488609/8.0),
+ REAL_CONST(96473.134808489311/8.0),
+ REAL_CONST(96496.63403440651/8.0),
+ REAL_CONST(96520.134691065963/8.0),
+ REAL_CONST(96543.636778293469/8.0),
+ REAL_CONST(96567.140295914898/8.0),
+ REAL_CONST(96590.645243756153/8.0),
+ REAL_CONST(96614.151621643221/8.0),
+ REAL_CONST(96637.659429402134/8.0),
+ REAL_CONST(96661.168666858954/8.0),
+ REAL_CONST(96684.679333839798/8.0),
+ REAL_CONST(96708.191430170875/8.0),
+ REAL_CONST(96731.70495567839/8.0),
+ REAL_CONST(96755.219910188665/8.0),
+ REAL_CONST(96778.736293528011/8.0),
+ REAL_CONST(96802.254105522836/8.0),
+ REAL_CONST(96825.77334599958/8.0),
+ REAL_CONST(96849.29401478474/8.0),
+ REAL_CONST(96872.816111704873/8.0),
+ REAL_CONST(96896.339636586577/8.0),
+ REAL_CONST(96919.864589256511/8.0),
+ REAL_CONST(96943.390969541389/8.0),
+ REAL_CONST(96966.918777267958/8.0),
+ REAL_CONST(96990.448012263048/8.0),
+ REAL_CONST(97013.978674353522/8.0),
+ REAL_CONST(97037.510763366285/8.0),
+ REAL_CONST(97061.044279128328/8.0),
+ REAL_CONST(97084.579221466673/8.0),
+ REAL_CONST(97108.115590208385/8.0),
+ REAL_CONST(97131.653385180587/8.0),
+ REAL_CONST(97155.19260621049/8.0),
+ REAL_CONST(97178.733253125291/8.0),
+ REAL_CONST(97202.2753257523/8.0),
+ REAL_CONST(97225.81882391886/8.0),
+ REAL_CONST(97249.363747452342/8.0),
+ REAL_CONST(97272.910096180189/8.0),
+ REAL_CONST(97296.457869929916/8.0),
+ REAL_CONST(97320.007068529041/8.0),
+ REAL_CONST(97343.557691805196/8.0),
+ REAL_CONST(97367.109739586012/8.0),
+ REAL_CONST(97390.663211699197/8.0),
+ REAL_CONST(97414.218107972498/8.0),
+ REAL_CONST(97437.774428233737/8.0),
+ REAL_CONST(97461.332172310766/8.0),
+ REAL_CONST(97484.891340031507/8.0),
+ REAL_CONST(97508.451931223899/8.0),
+ REAL_CONST(97532.013945715982/8.0),
+ REAL_CONST(97555.577383335811/8.0),
+ REAL_CONST(97579.142243911512/8.0),
+ REAL_CONST(97602.708527271257/8.0),
+ REAL_CONST(97626.276233243261/8.0),
+ REAL_CONST(97649.845361655811/8.0),
+ REAL_CONST(97673.415912337223/8.0),
+ REAL_CONST(97696.987885115886/8.0),
+ REAL_CONST(97720.561279820206/8.0),
+ REAL_CONST(97744.1360962787/8.0),
+ REAL_CONST(97767.712334319876/8.0),
+ REAL_CONST(97791.289993772341/8.0),
+ REAL_CONST(97814.869074464703/8.0),
+ REAL_CONST(97838.449576225685/8.0),
+ REAL_CONST(97862.031498883996/8.0),
+ REAL_CONST(97885.614842268449/8.0),
+ REAL_CONST(97909.199606207883/8.0),
+ REAL_CONST(97932.785790531183/8.0),
+ REAL_CONST(97956.37339506732/8.0),
+ REAL_CONST(97979.962419645264/8.0),
+ REAL_CONST(98003.552864094076/8.0),
+ REAL_CONST(98027.144728242856/8.0),
+ REAL_CONST(98050.738011920766/8.0),
+ REAL_CONST(98074.332714956996/8.0),
+ REAL_CONST(98097.928837180807/8.0),
+ REAL_CONST(98121.526378421506/8.0),
+ REAL_CONST(98145.125338508456/8.0),
+ REAL_CONST(98168.725717271067/8.0),
+ REAL_CONST(98192.327514538789/8.0),
+ REAL_CONST(98215.930730141132/8.0),
+ REAL_CONST(98239.535363907664/8.0),
+ REAL_CONST(98263.141415668011/8.0),
+ REAL_CONST(98286.748885251814/8.0),
+ REAL_CONST(98310.357772488816/8.0),
+ REAL_CONST(98333.968077208759/8.0),
+ REAL_CONST(98357.579799241488/8.0),
+ REAL_CONST(98381.192938416847/8.0),
+ REAL_CONST(98404.807494564782/8.0),
+ REAL_CONST(98428.42346751524/8.0),
+ REAL_CONST(98452.040857098269/8.0),
+ REAL_CONST(98475.659663143917/8.0),
+ REAL_CONST(98499.27988548232/8.0),
+ REAL_CONST(98522.901523943656/8.0),
+ REAL_CONST(98546.524578358163/8.0),
+ REAL_CONST(98570.149048556093/8.0),
+ REAL_CONST(98593.774934367786/8.0),
+ REAL_CONST(98617.402235623624/8.0),
+ REAL_CONST(98641.030952154048/8.0),
+ REAL_CONST(98664.661083789513/8.0),
+ REAL_CONST(98688.292630360564/8.0),
+ REAL_CONST(98711.925591697771/8.0),
+ REAL_CONST(98735.559967631794/8.0),
+ REAL_CONST(98759.195757993293/8.0),
+ REAL_CONST(98782.832962613014/8.0),
+ REAL_CONST(98806.471581321734/8.0),
+ REAL_CONST(98830.111613950285/8.0),
+ REAL_CONST(98853.753060329575/8.0),
+ REAL_CONST(98877.39592029051/8.0),
+ REAL_CONST(98901.040193664099/8.0),
+ REAL_CONST(98924.68588028138/8.0),
+ REAL_CONST(98948.33297997342/8.0),
+ REAL_CONST(98971.981492571387/8.0),
+ REAL_CONST(98995.63141790645/8.0),
+ REAL_CONST(99019.282755809851/8.0),
+ REAL_CONST(99042.935506112874/8.0),
+ REAL_CONST(99066.589668646877/8.0),
+ REAL_CONST(99090.245243243233/8.0),
+ REAL_CONST(99113.902229733401/8.0),
+ REAL_CONST(99137.560627948857/8.0),
+ REAL_CONST(99161.220437721131/8.0),
+ REAL_CONST(99184.881658881859/8.0),
+ REAL_CONST(99208.544291262631/8.0),
+ REAL_CONST(99232.208334695169/8.0),
+ REAL_CONST(99255.87378901121/8.0),
+ REAL_CONST(99279.540654042547/8.0),
+ REAL_CONST(99303.208929621018/8.0),
+ REAL_CONST(99326.878615578535/8.0),
+ REAL_CONST(99350.549711746993/8.0),
+ REAL_CONST(99374.222217958435/8.0),
+ REAL_CONST(99397.896134044888/8.0),
+ REAL_CONST(99421.571459838422/8.0),
+ REAL_CONST(99445.248195171211/8.0),
+ REAL_CONST(99468.926339875441/8.0),
+ REAL_CONST(99492.605893783344/8.0),
+ REAL_CONST(99516.286856727209/8.0),
+ REAL_CONST(99539.969228539398/8.0),
+ REAL_CONST(99563.653009052287/8.0),
+ REAL_CONST(99587.338198098325/8.0),
+ REAL_CONST(99611.024795510006/8.0),
+ REAL_CONST(99634.712801119866/8.0),
+ REAL_CONST(99658.402214760499/8.0),
+ REAL_CONST(99682.093036264545/8.0),
+ REAL_CONST(99705.785265464699/8.0),
+ REAL_CONST(99729.478902193689/8.0),
+ REAL_CONST(99753.173946284325/8.0),
+ REAL_CONST(99776.870397569437/8.0),
+ REAL_CONST(99800.56825588191/8.0),
+ REAL_CONST(99824.267521054688/8.0),
+ REAL_CONST(99847.968192920773/8.0),
+ REAL_CONST(99871.670271313182/8.0),
+ REAL_CONST(99895.373756065004/8.0),
+ REAL_CONST(99919.078647009388/8.0),
+ REAL_CONST(99942.78494397951/8.0),
+ REAL_CONST(99966.492646808634/8.0),
+ REAL_CONST(99990.20175533001/8.0),
+ REAL_CONST(100013.91226937699/8.0),
+ REAL_CONST(100037.62418878295/8.0),
+ REAL_CONST(100061.33751338134/8.0),
+ REAL_CONST(100085.05224300563/8.0),
+ REAL_CONST(100108.76837748935/8.0),
+ REAL_CONST(100132.4859166661/8.0),
+ REAL_CONST(100156.2048603695/8.0),
+ REAL_CONST(100179.92520843323/8.0),
+ REAL_CONST(100203.64696069101/8.0),
+ REAL_CONST(100227.37011697664/8.0),
+ REAL_CONST(100251.09467712394/8.0),
+ REAL_CONST(100274.82064096678/8.0),
+ REAL_CONST(100298.54800833909/8.0),
+ REAL_CONST(100322.27677907483/8.0),
+ REAL_CONST(100346.00695300807/8.0),
+ REAL_CONST(100369.73852997283/8.0),
+ REAL_CONST(100393.47150980328/8.0),
+ REAL_CONST(100417.20589233354/8.0),
+ REAL_CONST(100440.94167739789/8.0),
+ REAL_CONST(100464.67886483055/8.0),
+ REAL_CONST(100488.41745446586/8.0),
+ REAL_CONST(100512.1574461382/8.0),
+ REAL_CONST(100535.89883968196/8.0),
+ REAL_CONST(100559.64163493161/8.0),
+ REAL_CONST(100583.38583172169/8.0),
+ REAL_CONST(100607.13142988674/8.0),
+ REAL_CONST(100630.87842926137/8.0),
+ REAL_CONST(100654.62682968024/8.0),
+ REAL_CONST(100678.37663097809/8.0),
+ REAL_CONST(100702.12783298964/8.0),
+ REAL_CONST(100725.88043554971/8.0),
+ REAL_CONST(100749.63443849317/8.0),
+ REAL_CONST(100773.38984165489/8.0),
+ REAL_CONST(100797.14664486986/8.0),
+ REAL_CONST(100820.90484797307/8.0),
+ REAL_CONST(100844.66445079957/8.0),
+ REAL_CONST(100868.42545318443/8.0),
+ REAL_CONST(100892.18785496285/8.0),
+ REAL_CONST(100915.95165596998/8.0),
+ REAL_CONST(100939.71685604109/8.0),
+ REAL_CONST(100963.48345501146/8.0),
+ REAL_CONST(100987.25145271645/8.0),
+ REAL_CONST(101011.02084899142/8.0),
+ REAL_CONST(101034.79164367182/8.0),
+ REAL_CONST(101058.56383659317/8.0),
+ REAL_CONST(101082.33742759094/8.0),
+ REAL_CONST(101106.11241650078/8.0),
+ REAL_CONST(101129.88880315828/8.0),
+ REAL_CONST(101153.66658739912/8.0),
+ REAL_CONST(101177.44576905905/8.0),
+ REAL_CONST(101201.22634797383/8.0),
+ REAL_CONST(101225.00832397929/8.0),
+ REAL_CONST(101248.7916969113/8.0),
+ REAL_CONST(101272.57646660579/8.0),
+ REAL_CONST(101296.36263289873/8.0),
+ REAL_CONST(101320.15019562612/8.0),
+ REAL_CONST(101343.93915462404/8.0),
+ REAL_CONST(101367.7295097286/8.0),
+ REAL_CONST(101391.52126077596/8.0),
+ REAL_CONST(101415.31440760233/8.0),
+ REAL_CONST(101439.10895004397/8.0),
+ REAL_CONST(101462.9048879372/8.0),
+ REAL_CONST(101486.70222111834/8.0),
+ REAL_CONST(101510.50094942382/8.0),
+ REAL_CONST(101534.30107269008/8.0),
+ REAL_CONST(101558.10259075361/8.0),
+ REAL_CONST(101581.90550345098/8.0),
+ REAL_CONST(101605.70981061876/8.0),
+ REAL_CONST(101629.5155120936/8.0),
+ REAL_CONST(101653.32260771218/8.0),
+ REAL_CONST(101677.13109731126/8.0),
+ REAL_CONST(101700.9409807276/8.0),
+ REAL_CONST(101724.75225779804/8.0),
+ REAL_CONST(101748.56492835947/8.0),
+ REAL_CONST(101772.37899224881/8.0),
+ REAL_CONST(101796.19444930303/8.0),
+ REAL_CONST(101820.01129935916/8.0),
+ REAL_CONST(101843.82954225427/8.0),
+ REAL_CONST(101867.64917782549/8.0),
+ REAL_CONST(101891.47020590997/8.0),
+ REAL_CONST(101915.29262634492/8.0),
+ REAL_CONST(101939.11643896763/8.0),
+ REAL_CONST(101962.94164361537/8.0),
+ REAL_CONST(101986.76824012553/8.0),
+ REAL_CONST(102010.59622833549/8.0),
+ REAL_CONST(102034.42560808272/8.0),
+ REAL_CONST(102058.25637920471/8.0),
+ REAL_CONST(102082.08854153901/8.0),
+ REAL_CONST(102105.9220949232/8.0),
+ REAL_CONST(102129.75703919494/8.0),
+ REAL_CONST(102153.59337419191/8.0),
+ REAL_CONST(102177.43109975185/8.0),
+ REAL_CONST(102201.27021571253/8.0),
+ REAL_CONST(102225.1107219118/8.0),
+ REAL_CONST(102248.95261818753/8.0),
+ REAL_CONST(102272.79590437764/8.0),
+ REAL_CONST(102296.64058032009/8.0),
+ REAL_CONST(102320.48664585294/8.0),
+ REAL_CONST(102344.33410081422/8.0),
+ REAL_CONST(102368.18294504205/8.0),
+ REAL_CONST(102392.03317837461/8.0),
+ REAL_CONST(102415.88480065008/8.0),
+ REAL_CONST(102439.73781170673/8.0),
+ REAL_CONST(102463.59221138287/8.0),
+ REAL_CONST(102487.44799951684/8.0),
+ REAL_CONST(102511.30517594704/8.0),
+ REAL_CONST(102535.1637405119/8.0),
+ REAL_CONST(102559.02369304992/8.0),
+ REAL_CONST(102582.88503339965/8.0),
+ REAL_CONST(102606.74776139967/8.0),
+ REAL_CONST(102630.61187688859/8.0),
+ REAL_CONST(102654.4773797051/8.0),
+ REAL_CONST(102678.34426968795/8.0),
+ REAL_CONST(102702.21254667587/8.0),
+ REAL_CONST(102726.08221050771/8.0),
+ REAL_CONST(102749.95326102231/8.0),
+ REAL_CONST(102773.8256980586/8.0),
+ REAL_CONST(102797.69952145554/8.0),
+ REAL_CONST(102821.57473105213/8.0),
+ REAL_CONST(102845.45132668741/8.0),
+ REAL_CONST(102869.32930820051/8.0),
+ REAL_CONST(102893.20867543056/8.0),
+ REAL_CONST(102917.08942821674/8.0),
+ REAL_CONST(102940.97156639832/8.0),
+ REAL_CONST(102964.85508981455/8.0),
+ REAL_CONST(102988.73999830478/8.0),
+ REAL_CONST(103012.6262917084/8.0),
+ REAL_CONST(103036.51396986481/8.0),
+ REAL_CONST(103060.40303261351/8.0),
+ REAL_CONST(103084.293479794/8.0),
+ REAL_CONST(103108.18531124585/8.0),
+ REAL_CONST(103132.07852680866/8.0),
+ REAL_CONST(103155.97312632212/8.0),
+ REAL_CONST(103179.8691096259/8.0),
+ REAL_CONST(103203.76647655977/8.0),
+ REAL_CONST(103227.66522696352/8.0),
+ REAL_CONST(103251.56536067701/8.0),
+ REAL_CONST(103275.46687754011/8.0),
+ REAL_CONST(103299.36977739276/8.0),
+ REAL_CONST(103323.27406007495/8.0),
+ REAL_CONST(103347.1797254267/8.0),
+ REAL_CONST(103371.0867732881/8.0),
+ REAL_CONST(103394.99520349925/8.0),
+ REAL_CONST(103418.90501590034/8.0),
+ REAL_CONST(103442.81621033157/8.0),
+ REAL_CONST(103466.72878663319/8.0),
+ REAL_CONST(103490.64274464553/8.0),
+ REAL_CONST(103514.55808420894/8.0),
+ REAL_CONST(103538.4748051638/8.0),
+ REAL_CONST(103562.39290735057/8.0),
+ REAL_CONST(103586.31239060973/8.0),
+ REAL_CONST(103610.23325478184/8.0),
+ REAL_CONST(103634.15549970744/8.0),
+ REAL_CONST(103658.07912522719/8.0),
+ REAL_CONST(103682.00413118176/8.0),
+ REAL_CONST(103705.93051741188/8.0),
+ REAL_CONST(103729.85828375829/8.0),
+ REAL_CONST(103753.78743006183/8.0),
+ REAL_CONST(103777.71795616332/8.0),
+ REAL_CONST(103801.64986190372/8.0),
+ REAL_CONST(103825.58314712394/8.0),
+ REAL_CONST(103849.51781166498/8.0),
+ REAL_CONST(103873.4538553679/8.0),
+ REAL_CONST(103897.39127807376/8.0),
+ REAL_CONST(103921.33007962372/8.0),
+ REAL_CONST(103945.27025985894/8.0),
+ REAL_CONST(103969.21181862066/8.0),
+ REAL_CONST(103993.15475575015/8.0),
+ REAL_CONST(104017.0990710887/8.0),
+ REAL_CONST(104041.0447644777/8.0),
+ REAL_CONST(104064.99183575854/8.0),
+ REAL_CONST(104088.94028477269/8.0),
+ REAL_CONST(104112.89011136163/8.0),
+ REAL_CONST(104136.84131536692/8.0),
+ REAL_CONST(104160.79389663014/8.0),
+ REAL_CONST(104184.74785499295/8.0),
+ REAL_CONST(104208.70319029699/8.0),
+ REAL_CONST(104232.65990238401/8.0),
+ REAL_CONST(104256.61799109577/8.0),
+ REAL_CONST(104280.57745627411/8.0),
+ REAL_CONST(104304.53829776087/8.0),
+ REAL_CONST(104328.50051539797/8.0),
+ REAL_CONST(104352.46410902737/8.0),
+ REAL_CONST(104376.42907849104/8.0),
+ REAL_CONST(104400.39542363105/8.0),
+ REAL_CONST(104424.36314428948/8.0),
+ REAL_CONST(104448.33224030846/8.0),
+ REAL_CONST(104472.3027115302/8.0),
+ REAL_CONST(104496.27455779689/8.0),
+ REAL_CONST(104520.24777895081/8.0),
+ REAL_CONST(104544.22237483428/8.0),
+ REAL_CONST(104568.19834528965/8.0),
+ REAL_CONST(104592.17569015936/8.0),
+ REAL_CONST(104616.15440928582/8.0),
+ REAL_CONST(104640.13450251156/8.0),
+ REAL_CONST(104664.1159696791/8.0),
+ REAL_CONST(104688.09881063103/8.0),
+ REAL_CONST(104712.08302520998/8.0),
+ REAL_CONST(104736.06861325864/8.0),
+ REAL_CONST(104760.05557461972/8.0),
+ REAL_CONST(104784.043909136/8.0),
+ REAL_CONST(104808.03361665027/8.0),
+ REAL_CONST(104832.0246970054/8.0),
+ REAL_CONST(104856.01715004431/8.0),
+ REAL_CONST(104880.01097560991/8.0),
+ REAL_CONST(104904.00617354522/8.0),
+ REAL_CONST(104928.00274369326/8.0),
+ REAL_CONST(104952.00068589712/8.0),
+ REAL_CONST(104975.99999999993/8.0),
+ REAL_CONST(105000.00068584486/8.0),
+ REAL_CONST(105024.00274327511/8.0),
+ REAL_CONST(105048.00617213396/8.0),
+ REAL_CONST(105072.0109722647/8.0),
+ REAL_CONST(105096.0171435107/8.0),
+ REAL_CONST(105120.02468571534/8.0),
+ REAL_CONST(105144.03359872208/8.0),
+ REAL_CONST(105168.04388237436/8.0),
+ REAL_CONST(105192.05553651576/8.0),
+ REAL_CONST(105216.06856098982/8.0),
+ REAL_CONST(105240.08295564017/8.0),
+ REAL_CONST(105264.09872031047/8.0),
+ REAL_CONST(105288.11585484444/8.0),
+ REAL_CONST(105312.13435908582/8.0),
+ REAL_CONST(105336.1542328784/8.0),
+ REAL_CONST(105360.17547606604/8.0),
+ REAL_CONST(105384.19808849262/8.0),
+ REAL_CONST(105408.22207000206/8.0),
+ REAL_CONST(105432.24742043833/8.0),
+ REAL_CONST(105456.27413964548/8.0),
+ REAL_CONST(105480.30222746753/8.0),
+ REAL_CONST(105504.33168374863/8.0),
+ REAL_CONST(105528.36250833291/8.0),
+ REAL_CONST(105552.39470106458/8.0),
+ REAL_CONST(105576.42826178786/8.0),
+ REAL_CONST(105600.46319034706/8.0),
+ REAL_CONST(105624.49948658649/8.0),
+ REAL_CONST(105648.53715035053/8.0),
+ REAL_CONST(105672.5761814836/8.0),
+ REAL_CONST(105696.61657983017/8.0),
+ REAL_CONST(105720.65834523473/8.0),
+ REAL_CONST(105744.70147754184/8.0),
+ REAL_CONST(105768.7459765961/8.0),
+ REAL_CONST(105792.79184224214/8.0),
+ REAL_CONST(105816.83907432464/8.0),
+ REAL_CONST(105840.88767268835/8.0),
+ REAL_CONST(105864.93763717801/8.0),
+ REAL_CONST(105888.98896763846/8.0),
+ REAL_CONST(105913.04166391456/8.0),
+ REAL_CONST(105937.09572585119/8.0),
+ REAL_CONST(105961.15115329332/8.0),
+ REAL_CONST(105985.20794608595/8.0),
+ REAL_CONST(106009.26610407409/8.0),
+ REAL_CONST(106033.32562710284/8.0),
+ REAL_CONST(106057.38651501729/8.0),
+ REAL_CONST(106081.44876766266/8.0),
+ REAL_CONST(106105.51238488412/8.0),
+ REAL_CONST(106129.57736652695/8.0),
+ REAL_CONST(106153.64371243643/8.0),
+ REAL_CONST(106177.71142245791/8.0),
+ REAL_CONST(106201.78049643678/8.0),
+ REAL_CONST(106225.85093421848/8.0),
+ REAL_CONST(106249.92273564848/8.0),
+ REAL_CONST(106273.99590057228/8.0),
+ REAL_CONST(106298.07042883546/8.0),
+ REAL_CONST(106322.14632028362/8.0),
+ REAL_CONST(106346.22357476239/8.0),
+ REAL_CONST(106370.30219211751/8.0),
+ REAL_CONST(106394.38217219469/8.0),
+ REAL_CONST(106418.46351483969/8.0),
+ REAL_CONST(106442.54621989837/8.0),
+ REAL_CONST(106466.63028721658/8.0),
+ REAL_CONST(106490.71571664025/8.0),
+ REAL_CONST(106514.80250801529/8.0),
+ REAL_CONST(106538.89066118775/8.0),
+ REAL_CONST(106562.98017600364/8.0),
+ REAL_CONST(106587.07105230905/8.0),
+ REAL_CONST(106611.16328995011/8.0),
+ REAL_CONST(106635.25688877302/8.0),
+ REAL_CONST(106659.35184862395/8.0),
+ REAL_CONST(106683.44816934918/8.0),
+ REAL_CONST(106707.54585079502/8.0),
+ REAL_CONST(106731.64489280782/8.0),
+ REAL_CONST(106755.74529523395/8.0),
+ REAL_CONST(106779.84705791986/8.0),
+ REAL_CONST(106803.95018071201/8.0),
+ REAL_CONST(106828.05466345693/8.0),
+ REAL_CONST(106852.16050600118/8.0),
+ REAL_CONST(106876.26770819137/8.0),
+ REAL_CONST(106900.37626987413/8.0),
+ REAL_CONST(106924.48619089619/8.0),
+ REAL_CONST(106948.59747110425/8.0),
+ REAL_CONST(106972.71011034511/8.0),
+ REAL_CONST(106996.82410846559/8.0),
+ REAL_CONST(107020.93946531253/8.0),
+ REAL_CONST(107045.05618073288/8.0),
+ REAL_CONST(107069.17425457356/8.0),
+ REAL_CONST(107093.29368668159/8.0),
+ REAL_CONST(107117.41447690397/8.0),
+ REAL_CONST(107141.53662508781/8.0),
+ REAL_CONST(107165.66013108024/8.0),
+ REAL_CONST(107189.7849947284/8.0),
+ REAL_CONST(107213.91121587952/8.0),
+ REAL_CONST(107238.03879438085/8.0),
+ REAL_CONST(107262.16773007967/8.0),
+ REAL_CONST(107286.29802282334/8.0),
+ REAL_CONST(107310.42967245923/8.0),
+ REAL_CONST(107334.56267883476/8.0),
+ REAL_CONST(107358.69704179741/8.0),
+ REAL_CONST(107382.83276119467/8.0),
+ REAL_CONST(107406.96983687414/8.0),
+ REAL_CONST(107431.10826868335/8.0),
+ REAL_CONST(107455.24805646999/8.0),
+ REAL_CONST(107479.38920008171/8.0),
+ REAL_CONST(107503.53169936626/8.0),
+ REAL_CONST(107527.67555417139/8.0),
+ REAL_CONST(107551.82076434491/8.0),
+ REAL_CONST(107575.96732973469/8.0),
+ REAL_CONST(107600.11525018861/8.0),
+ REAL_CONST(107624.26452555459/8.0),
+ REAL_CONST(107648.41515568066/8.0),
+ REAL_CONST(107672.56714041479/8.0),
+ REAL_CONST(107696.72047960508/8.0),
+ REAL_CONST(107720.87517309963/8.0),
+ REAL_CONST(107745.03122074658/8.0),
+ REAL_CONST(107769.18862239413/8.0),
+ REAL_CONST(107793.34737789053/8.0),
+ REAL_CONST(107817.50748708403/8.0),
+ REAL_CONST(107841.66894982298/8.0),
+ REAL_CONST(107865.83176595572/8.0),
+ REAL_CONST(107889.99593533068/8.0),
+ REAL_CONST(107914.16145779629/8.0),
+ REAL_CONST(107938.32833320105/8.0),
+ REAL_CONST(107962.49656139348/8.0),
+ REAL_CONST(107986.66614222217/8.0),
+ REAL_CONST(108010.83707553572/8.0),
+ REAL_CONST(108035.00936118282/8.0),
+ REAL_CONST(108059.18299901215/8.0),
+ REAL_CONST(108083.35798887245/8.0),
+ REAL_CONST(108107.53433061253/8.0),
+ REAL_CONST(108131.71202408121/8.0),
+ REAL_CONST(108155.89106912735/8.0),
+ REAL_CONST(108180.07146559987/8.0),
+ REAL_CONST(108204.25321334775/8.0),
+ REAL_CONST(108228.43631221994/8.0),
+ REAL_CONST(108252.62076206553/8.0),
+ REAL_CONST(108276.80656273357/8.0),
+ REAL_CONST(108300.99371407321/8.0),
+ REAL_CONST(108325.18221593359/8.0),
+ REAL_CONST(108349.37206816394/8.0),
+ REAL_CONST(108373.56327061349/8.0),
+ REAL_CONST(108397.75582313156/8.0),
+ REAL_CONST(108421.94972556747/8.0),
+ REAL_CONST(108446.1449777706/8.0),
+ REAL_CONST(108470.34157959036/8.0),
+ REAL_CONST(108494.53953087622/8.0),
+ REAL_CONST(108518.73883147769/8.0),
+ REAL_CONST(108542.93948124432/8.0),
+ REAL_CONST(108567.14148002568/8.0),
+ REAL_CONST(108591.34482767139/8.0),
+ REAL_CONST(108615.54952403114/8.0),
+ REAL_CONST(108639.75556895464/8.0),
+ REAL_CONST(108663.96296229165/8.0),
+ REAL_CONST(108688.17170389196/8.0),
+ REAL_CONST(108712.38179360541/8.0),
+ REAL_CONST(108736.59323128188/8.0),
+ REAL_CONST(108760.80601677128/8.0),
+ REAL_CONST(108785.02014992358/8.0),
+ REAL_CONST(108809.23563058881/8.0),
+ REAL_CONST(108833.45245861699/8.0),
+ REAL_CONST(108857.67063385822/8.0),
+ REAL_CONST(108881.89015616261/8.0),
+ REAL_CONST(108906.11102538036/8.0),
+ REAL_CONST(108930.33324136167/8.0),
+ REAL_CONST(108954.55680395682/8.0),
+ REAL_CONST(108978.78171301607/8.0),
+ REAL_CONST(109003.00796838976/8.0),
+ REAL_CONST(109027.23556992831/8.0),
+ REAL_CONST(109051.46451748211/8.0),
+ REAL_CONST(109075.69481090162/8.0),
+ REAL_CONST(109099.92645003737/8.0),
+ REAL_CONST(109124.15943473989/8.0),
+ REAL_CONST(109148.39376485976/8.0),
+ REAL_CONST(109172.62944024763/8.0),
+ REAL_CONST(109196.86646075416/8.0),
+ REAL_CONST(109221.10482623006/8.0),
+ REAL_CONST(109245.34453652608/8.0),
+ REAL_CONST(109269.58559149304/8.0),
+ REAL_CONST(109293.82799098175/8.0),
+ REAL_CONST(109318.07173484311/8.0),
+ REAL_CONST(109342.31682292801/8.0),
+ REAL_CONST(109366.56325508743/8.0),
+ REAL_CONST(109390.81103117237/8.0),
+ REAL_CONST(109415.06015103387/8.0),
+ REAL_CONST(109439.31061452301/8.0),
+ REAL_CONST(109463.56242149093/8.0),
+ REAL_CONST(109487.8155717888/8.0),
+ REAL_CONST(109512.07006526781/8.0),
+ REAL_CONST(109536.3259017792/8.0),
+ REAL_CONST(109560.58308117429/8.0),
+ REAL_CONST(109584.8416033044/8.0),
+ REAL_CONST(109609.1014680209/8.0),
+ REAL_CONST(109633.36267517522/8.0),
+ REAL_CONST(109657.62522461878/8.0),
+ REAL_CONST(109681.88911620311/8.0),
+ REAL_CONST(109706.15434977971/8.0),
+ REAL_CONST(109730.4209252002/8.0),
+ REAL_CONST(109754.68884231619/8.0),
+ REAL_CONST(109778.95810097932/8.0),
+ REAL_CONST(109803.22870104131/8.0),
+ REAL_CONST(109827.50064235389/8.0),
+ REAL_CONST(109851.77392476884/8.0),
+ REAL_CONST(109876.04854813802/8.0),
+ REAL_CONST(109900.32451231324/8.0),
+ REAL_CONST(109924.60181714644/8.0),
+ REAL_CONST(109948.88046248957/8.0),
+ REAL_CONST(109973.1604481946/8.0),
+ REAL_CONST(109997.44177411357/8.0),
+ REAL_CONST(110021.72444009855/8.0),
+ REAL_CONST(110046.00844600165/8.0),
+ REAL_CONST(110070.29379167501/8.0),
+ REAL_CONST(110094.58047697082/8.0),
+ REAL_CONST(110118.86850174134/8.0),
+ REAL_CONST(110143.15786583882/8.0),
+ REAL_CONST(110167.44856911557/8.0),
+ REAL_CONST(110191.74061142397/8.0),
+ REAL_CONST(110216.03399261639/8.0),
+ REAL_CONST(110240.32871254528/8.0),
+ REAL_CONST(110264.62477106311/8.0),
+ REAL_CONST(110288.9221680224/8.0),
+ REAL_CONST(110313.22090327571/8.0),
+ REAL_CONST(110337.52097667565/8.0),
+ REAL_CONST(110361.82238807483/8.0),
+ REAL_CONST(110386.12513732594/8.0),
+ REAL_CONST(110410.42922428172/8.0),
+ REAL_CONST(110434.73464879491/8.0),
+ REAL_CONST(110459.04141071832/8.0),
+ REAL_CONST(110483.34950990479/8.0),
+ REAL_CONST(110507.6589462072/8.0),
+ REAL_CONST(110531.96971947847/8.0),
+ REAL_CONST(110556.28182957157/8.0),
+ REAL_CONST(110580.5952763395/8.0),
+ REAL_CONST(110604.91005963532/8.0),
+ REAL_CONST(110629.22617931209/8.0),
+ REAL_CONST(110653.54363522294/8.0),
+ REAL_CONST(110677.86242722106/8.0),
+ REAL_CONST(110702.18255515963/8.0),
+ REAL_CONST(110726.50401889188/8.0),
+ REAL_CONST(110750.82681827113/8.0),
+ REAL_CONST(110775.1509531507/8.0),
+ REAL_CONST(110799.47642338395/8.0),
+ REAL_CONST(110823.80322882428/8.0),
+ REAL_CONST(110848.13136932514/8.0),
+ REAL_CONST(110872.46084474004/8.0),
+ REAL_CONST(110896.79165492248/8.0),
+ REAL_CONST(110921.12379972603/8.0),
+ REAL_CONST(110945.4572790043/8.0),
+ REAL_CONST(110969.79209261097/8.0),
+ REAL_CONST(110994.12824039967/8.0),
+ REAL_CONST(111018.46572222417/8.0),
+ REAL_CONST(111042.80453793822/8.0),
+ REAL_CONST(111067.14468739564/8.0),
+ REAL_CONST(111091.48617045028/8.0),
+ REAL_CONST(111115.82898695602/8.0),
+ REAL_CONST(111140.1731367668/8.0),
+ REAL_CONST(111164.51861973655/8.0),
+ REAL_CONST(111188.86543571933/8.0),
+ REAL_CONST(111213.21358456917/8.0),
+ REAL_CONST(111237.56306614014/8.0),
+ REAL_CONST(111261.91388028639/8.0),
+ REAL_CONST(111286.26602686207/8.0),
+ REAL_CONST(111310.61950572141/8.0),
+ REAL_CONST(111334.97431671864/8.0),
+ REAL_CONST(111359.33045970804/8.0),
+ REAL_CONST(111383.68793454397/8.0),
+ REAL_CONST(111408.04674108078/8.0),
+ REAL_CONST(111432.40687917286/8.0),
+ REAL_CONST(111456.76834867468/8.0),
+ REAL_CONST(111481.13114944073/8.0),
+ REAL_CONST(111505.49528132551/8.0),
+ REAL_CONST(111529.86074418361/8.0),
+ REAL_CONST(111554.22753786964/8.0),
+ REAL_CONST(111578.59566223821/8.0),
+ REAL_CONST(111602.96511714405/8.0),
+ REAL_CONST(111627.33590244185/8.0),
+ REAL_CONST(111651.7080179864/8.0),
+ REAL_CONST(111676.08146363248/8.0),
+ REAL_CONST(111700.45623923496/8.0),
+ REAL_CONST(111724.8323446487/8.0),
+ REAL_CONST(111749.20977972864/8.0),
+ REAL_CONST(111773.58854432974/8.0),
+ REAL_CONST(111797.96863830699/8.0),
+ REAL_CONST(111822.35006151545/8.0),
+ REAL_CONST(111846.73281381019/8.0),
+ REAL_CONST(111871.11689504632/8.0),
+ REAL_CONST(111895.50230507903/8.0),
+ REAL_CONST(111919.8890437635/8.0),
+ REAL_CONST(111944.27711095495/8.0),
+ REAL_CONST(111968.6665065087/8.0),
+ REAL_CONST(111993.05723028004/8.0),
+ REAL_CONST(112017.44928212435/8.0),
+ REAL_CONST(112041.842661897/8.0),
+ REAL_CONST(112066.23736945343/8.0),
+ REAL_CONST(112090.63340464912/8.0),
+ REAL_CONST(112115.03076733962/8.0),
+ REAL_CONST(112139.42945738042/8.0),
+ REAL_CONST(112163.82947462716/8.0),
+ REAL_CONST(112188.23081893545/8.0),
+ REAL_CONST(112212.63349016097/8.0),
+ REAL_CONST(112237.03748815943/8.0),
+ REAL_CONST(112261.44281278658/8.0),
+ REAL_CONST(112285.84946389822/8.0),
+ REAL_CONST(112310.25744135017/8.0),
+ REAL_CONST(112334.66674499828/8.0),
+ REAL_CONST(112359.07737469849/8.0),
+ REAL_CONST(112383.48933030672/8.0),
+ REAL_CONST(112407.90261167898/8.0),
+ REAL_CONST(112432.31721867126/8.0),
+ REAL_CONST(112456.73315113965/8.0),
+ REAL_CONST(112481.15040894024/8.0),
+ REAL_CONST(112505.56899192919/8.0),
+ REAL_CONST(112529.98889996267/8.0),
+ REAL_CONST(112554.41013289688/8.0),
+ REAL_CONST(112578.8326905881/8.0),
+ REAL_CONST(112603.25657289263/8.0),
+ REAL_CONST(112627.68177966679/8.0),
+ REAL_CONST(112652.10831076698/8.0),
+ REAL_CONST(112676.53616604958/8.0),
+ REAL_CONST(112700.96534537108/8.0),
+ REAL_CONST(112725.39584858794/8.0),
+ REAL_CONST(112749.82767555672/8.0),
+ REAL_CONST(112774.26082613398/8.0),
+ REAL_CONST(112798.6953001763/8.0),
+ REAL_CONST(112823.13109754038/8.0),
+ REAL_CONST(112847.56821808286/8.0),
+ REAL_CONST(112872.00666166049/8.0),
+ REAL_CONST(112896.44642813003/8.0),
+ REAL_CONST(112920.88751734827/8.0),
+ REAL_CONST(112945.32992917208/8.0),
+ REAL_CONST(112969.77366345831/8.0),
+ REAL_CONST(112994.21872006389/8.0),
+ REAL_CONST(113018.66509884578/8.0),
+ REAL_CONST(113043.11279966099/8.0),
+ REAL_CONST(113067.56182236652/8.0),
+ REAL_CONST(113092.01216681948/8.0),
+ REAL_CONST(113116.46383287695/8.0),
+ REAL_CONST(113140.9168203961/8.0),
+ REAL_CONST(113165.37112923413/8.0),
+ REAL_CONST(113189.82675924824/8.0),
+ REAL_CONST(113214.28371029573/8.0),
+ REAL_CONST(113238.74198223387/8.0),
+ REAL_CONST(113263.20157492002/8.0),
+ REAL_CONST(113287.66248821157/8.0),
+ REAL_CONST(113312.12472196593/8.0),
+ REAL_CONST(113336.58827604055/8.0),
+ REAL_CONST(113361.05315029295/8.0),
+ REAL_CONST(113385.51934458067/8.0),
+ REAL_CONST(113409.98685876124/8.0),
+ REAL_CONST(113434.45569269233/8.0),
+ REAL_CONST(113458.92584623155/8.0),
+ REAL_CONST(113483.39731923661/8.0),
+ REAL_CONST(113507.87011156522/8.0),
+ REAL_CONST(113532.34422307517/8.0),
+ REAL_CONST(113556.81965362425/8.0),
+ REAL_CONST(113581.2964030703/8.0),
+ REAL_CONST(113605.77447127122/8.0),
+ REAL_CONST(113630.25385808491/8.0),
+ REAL_CONST(113654.73456336933/8.0),
+ REAL_CONST(113679.2165869825/8.0),
+ REAL_CONST(113703.69992878241/8.0),
+ REAL_CONST(113728.18458862718/8.0),
+ REAL_CONST(113752.67056637487/8.0),
+ REAL_CONST(113777.15786188368/8.0),
+ REAL_CONST(113801.64647501177/8.0),
+ REAL_CONST(113826.13640561736/8.0),
+ REAL_CONST(113850.62765355874/8.0),
+ REAL_CONST(113875.12021869418/8.0),
+ REAL_CONST(113899.61410088204/8.0),
+ REAL_CONST(113924.1092999807/8.0),
+ REAL_CONST(113948.60581584855/8.0),
+ REAL_CONST(113973.10364834407/8.0),
+ REAL_CONST(113997.60279732574/8.0),
+ REAL_CONST(114022.1032626521/8.0),
+ REAL_CONST(114046.60504418171/8.0),
+ REAL_CONST(114071.10814177318/8.0),
+ REAL_CONST(114095.61255528514/8.0),
+ REAL_CONST(114120.11828457628/8.0),
+ REAL_CONST(114144.62532950533/8.0),
+ REAL_CONST(114169.13368993104/8.0),
+ REAL_CONST(114193.6433657122/8.0),
+ REAL_CONST(114218.15435670764/8.0),
+ REAL_CONST(114242.66666277625/8.0),
+ REAL_CONST(114267.18028377694/8.0),
+ REAL_CONST(114291.69521956862/8.0),
+ REAL_CONST(114316.21147001031/8.0),
+ REAL_CONST(114340.72903496103/8.0),
+ REAL_CONST(114365.24791427983/8.0),
+ REAL_CONST(114389.7681078258/8.0),
+ REAL_CONST(114414.2896154581/8.0),
+ REAL_CONST(114438.81243703589/8.0),
+ REAL_CONST(114463.33657241837/8.0),
+ REAL_CONST(114487.8620214648/8.0),
+ REAL_CONST(114512.38878403447/8.0),
+ REAL_CONST(114536.91685998671/8.0),
+ REAL_CONST(114561.44624918087/8.0),
+ REAL_CONST(114585.97695147636/8.0),
+ REAL_CONST(114610.5089667326/8.0),
+ REAL_CONST(114635.04229480909/8.0),
+ REAL_CONST(114659.57693556532/8.0),
+ REAL_CONST(114684.11288886084/8.0),
+ REAL_CONST(114708.65015455526/8.0),
+ REAL_CONST(114733.18873250818/8.0),
+ REAL_CONST(114757.72862257928/8.0),
+ REAL_CONST(114782.26982462825/8.0),
+ REAL_CONST(114806.81233851484/8.0),
+ REAL_CONST(114831.35616409882/8.0),
+ REAL_CONST(114855.90130123998/8.0),
+ REAL_CONST(114880.44774979822/8.0),
+ REAL_CONST(114904.99550963337/8.0),
+ REAL_CONST(114929.5445806054/8.0),
+ REAL_CONST(114954.09496257425/8.0),
+ REAL_CONST(114978.64665539992/8.0),
+ REAL_CONST(115003.19965894247/8.0),
+ REAL_CONST(115027.75397306195/8.0),
+ REAL_CONST(115052.30959761847/8.0),
+ REAL_CONST(115076.86653247218/8.0),
+ REAL_CONST(115101.42477748329/8.0),
+ REAL_CONST(115125.984332512/8.0),
+ REAL_CONST(115150.54519741859/8.0),
+ REAL_CONST(115175.10737206334/8.0),
+ REAL_CONST(115199.67085630659/8.0),
+ REAL_CONST(115224.23565000873/8.0),
+ REAL_CONST(115248.80175303014/8.0),
+ REAL_CONST(115273.3691652313/8.0),
+ REAL_CONST(115297.93788647266/8.0),
+ REAL_CONST(115322.50791661476/8.0),
+ REAL_CONST(115347.07925551817/8.0),
+ REAL_CONST(115371.65190304347/8.0),
+ REAL_CONST(115396.22585905129/8.0),
+ REAL_CONST(115420.80112340231/8.0),
+ REAL_CONST(115445.37769595724/8.0),
+ REAL_CONST(115469.95557657682/8.0),
+ REAL_CONST(115494.53476512182/8.0),
+ REAL_CONST(115519.11526145306/8.0),
+ REAL_CONST(115543.69706543141/8.0),
+ REAL_CONST(115568.28017691776/8.0),
+ REAL_CONST(115592.86459577303/8.0),
+ REAL_CONST(115617.4503218582/8.0),
+ REAL_CONST(115642.03735503425/8.0),
+ REAL_CONST(115666.62569516223/8.0),
+ REAL_CONST(115691.21534210323/8.0),
+ REAL_CONST(115715.80629571836/8.0),
+ REAL_CONST(115740.39855586876/8.0),
+ REAL_CONST(115764.99212241563/8.0),
+ REAL_CONST(115789.58699522018/8.0),
+ REAL_CONST(115814.18317414368/8.0),
+ REAL_CONST(115838.78065904744/8.0),
+ REAL_CONST(115863.37944979276/8.0),
+ REAL_CONST(115887.97954624105/8.0),
+ REAL_CONST(115912.5809482537/8.0),
+ REAL_CONST(115937.18365569216/8.0),
+ REAL_CONST(115961.78766841792/8.0),
+ REAL_CONST(115986.39298629249/8.0),
+ REAL_CONST(116010.99960917742/8.0),
+ REAL_CONST(116035.60753693432/8.0),
+ REAL_CONST(116060.21676942479/8.0),
+ REAL_CONST(116084.82730651053/8.0),
+ REAL_CONST(116109.43914805322/8.0),
+ REAL_CONST(116134.0522939146/8.0),
+ REAL_CONST(116158.66674395646/8.0),
+ REAL_CONST(116183.2824980406/8.0),
+ REAL_CONST(116207.89955602887/8.0),
+ REAL_CONST(116232.51791778316/8.0),
+ REAL_CONST(116257.13758316539/8.0),
+ REAL_CONST(116281.75855203751/8.0),
+ REAL_CONST(116306.38082426153/8.0),
+ REAL_CONST(116331.00439969949/8.0),
+ REAL_CONST(116355.62927821343/8.0),
+ REAL_CONST(116380.25545966547/8.0),
+ REAL_CONST(116404.88294391775/8.0),
+ REAL_CONST(116429.51173083246/8.0),
+ REAL_CONST(116454.14182027178/8.0),
+ REAL_CONST(116478.77321209799/8.0),
+ REAL_CONST(116503.40590617337/8.0),
+ REAL_CONST(116528.03990236025/8.0),
+ REAL_CONST(116552.67520052097/8.0),
+ REAL_CONST(116577.31180051794/8.0),
+ REAL_CONST(116601.94970221359/8.0),
+ REAL_CONST(116626.5889054704/8.0),
+ REAL_CONST(116651.22941015086/8.0),
+ REAL_CONST(116675.87121611751/8.0),
+ REAL_CONST(116700.51432323294/8.0),
+ REAL_CONST(116725.15873135976/8.0),
+ REAL_CONST(116749.8044403606/8.0),
+ REAL_CONST(116774.45145009817/8.0),
+ REAL_CONST(116799.0997604352/8.0),
+ REAL_CONST(116823.74937123443/8.0),
+ REAL_CONST(116848.40028235866/8.0),
+ REAL_CONST(116873.05249367072/8.0),
+ REAL_CONST(116897.70600503348/8.0),
+ REAL_CONST(116922.36081630984/8.0),
+ REAL_CONST(116947.01692736275/8.0),
+ REAL_CONST(116971.67433805518/8.0),
+ REAL_CONST(116996.33304825013/8.0),
+ REAL_CONST(117020.99305781067/8.0),
+ REAL_CONST(117045.65436659988/8.0),
+ REAL_CONST(117070.31697448085/8.0),
+ REAL_CONST(117094.98088131678/8.0),
+ REAL_CONST(117119.64608697082/8.0),
+ REAL_CONST(117144.31259130624/8.0),
+ REAL_CONST(117168.98039418629/8.0),
+ REAL_CONST(117193.64949547425/8.0),
+ REAL_CONST(117218.31989503348/8.0),
+ REAL_CONST(117242.99159272734/8.0),
+ REAL_CONST(117267.66458841923/8.0),
+ REAL_CONST(117292.33888197262/8.0),
+ REAL_CONST(117317.01447325097/8.0),
+ REAL_CONST(117341.6913621178/8.0),
+ REAL_CONST(117366.36954843666/8.0),
+ REAL_CONST(117391.04903207115/8.0),
+ REAL_CONST(117415.72981288488/8.0),
+ REAL_CONST(117440.41189074152/8.0),
+ REAL_CONST(117465.09526550474/8.0),
+ REAL_CONST(117489.77993703831/8.0),
+ REAL_CONST(117514.46590520597/8.0),
+ REAL_CONST(117539.15316987153/8.0),
+ REAL_CONST(117563.84173089883/8.0),
+ REAL_CONST(117588.53158815173/8.0),
+ REAL_CONST(117613.22274149416/8.0),
+ REAL_CONST(117637.91519079007/8.0),
+ REAL_CONST(117662.60893590341/8.0),
+ REAL_CONST(117687.30397669821/8.0),
+ REAL_CONST(117712.00031303853/8.0),
+ REAL_CONST(117736.69794478847/8.0),
+ REAL_CONST(117761.39687181212/8.0),
+ REAL_CONST(117786.09709397367/8.0),
+ REAL_CONST(117810.7986111373/8.0),
+ REAL_CONST(117835.50142316725/8.0),
+ REAL_CONST(117860.20552992777/8.0),
+ REAL_CONST(117884.91093128319/8.0),
+ REAL_CONST(117909.6176270978/8.0),
+ REAL_CONST(117934.32561723603/8.0),
+ REAL_CONST(117959.03490156225/8.0),
+ REAL_CONST(117983.74547994092/8.0),
+ REAL_CONST(118008.45735223651/8.0),
+ REAL_CONST(118033.17051831353/8.0),
+ REAL_CONST(118057.88497803656/8.0),
+ REAL_CONST(118082.60073127014/8.0),
+ REAL_CONST(118107.31777787894/8.0),
+ REAL_CONST(118132.03611772758/8.0),
+ REAL_CONST(118156.75575068076/8.0),
+ REAL_CONST(118181.47667660323/8.0),
+ REAL_CONST(118206.19889535972/8.0),
+ REAL_CONST(118230.92240681504/8.0),
+ REAL_CONST(118255.64721083404/8.0),
+ REAL_CONST(118280.37330728157/8.0),
+ REAL_CONST(118305.10069602253/8.0),
+ REAL_CONST(118329.82937692189/8.0),
+ REAL_CONST(118354.55934984458/8.0),
+ REAL_CONST(118379.29061465565/8.0),
+ REAL_CONST(118404.02317122012/8.0),
+ REAL_CONST(118428.75701940308/8.0),
+ REAL_CONST(118453.49215906965/8.0),
+ REAL_CONST(118478.22859008498/8.0),
+ REAL_CONST(118502.96631231424/8.0),
+ REAL_CONST(118527.70532562268/8.0),
+ REAL_CONST(118552.44562987552/8.0),
+ REAL_CONST(118577.18722493808/8.0),
+ REAL_CONST(118601.93011067568/8.0),
+ REAL_CONST(118626.67428695368/8.0),
+ REAL_CONST(118651.41975363747/8.0),
+ REAL_CONST(118676.16651059251/8.0),
+ REAL_CONST(118700.91455768423/8.0),
+ REAL_CONST(118725.66389477813/8.0),
+ REAL_CONST(118750.41452173979/8.0),
+ REAL_CONST(118775.16643843475/8.0),
+ REAL_CONST(118799.91964472862/8.0),
+ REAL_CONST(118824.67414048707/8.0),
+ REAL_CONST(118849.42992557574/8.0),
+ REAL_CONST(118874.18699986035/8.0),
+ REAL_CONST(118898.94536320666/8.0),
+ REAL_CONST(118923.70501548045/8.0),
+ REAL_CONST(118948.46595654752/8.0),
+ REAL_CONST(118973.22818627374/8.0),
+ REAL_CONST(118997.99170452499/8.0),
+ REAL_CONST(119022.7565111672/8.0),
+ REAL_CONST(119047.52260606633/8.0),
+ REAL_CONST(119072.28998908834/8.0),
+ REAL_CONST(119097.0586600993/8.0),
+ REAL_CONST(119121.82861896523/8.0),
+ REAL_CONST(119146.59986555226/8.0),
+ REAL_CONST(119171.3723997265/8.0),
+ REAL_CONST(119196.14622135412/8.0),
+ REAL_CONST(119220.92133030134/8.0),
+ REAL_CONST(119245.69772643436/8.0),
+ REAL_CONST(119270.47540961947/8.0),
+ REAL_CONST(119295.25437972297/8.0),
+ REAL_CONST(119320.03463661121/8.0),
+ REAL_CONST(119344.81618015055/8.0),
+ REAL_CONST(119369.5990102074/8.0),
+ REAL_CONST(119394.38312664822/8.0),
+ REAL_CONST(119419.16852933947/8.0),
+ REAL_CONST(119443.95521814766/8.0),
+ REAL_CONST(119468.74319293935/8.0),
+ REAL_CONST(119493.53245358112/8.0),
+ REAL_CONST(119518.32299993958/8.0),
+ REAL_CONST(119543.11483188139/8.0),
+ REAL_CONST(119567.90794927324/8.0),
+ REAL_CONST(119592.70235198183/8.0),
+ REAL_CONST(119617.49803987393/8.0),
+ REAL_CONST(119642.29501281632/8.0),
+ REAL_CONST(119667.09327067583/8.0),
+ REAL_CONST(119691.89281331931/8.0),
+ REAL_CONST(119716.69364061367/8.0),
+ REAL_CONST(119741.49575242582/8.0),
+ REAL_CONST(119766.29914862274/8.0),
+ REAL_CONST(119791.10382907141/8.0),
+ REAL_CONST(119815.90979363887/8.0),
+ REAL_CONST(119840.71704219218/8.0),
+ REAL_CONST(119865.52557459843/8.0),
+ REAL_CONST(119890.33539072477/8.0),
+ REAL_CONST(119915.14649043836/8.0),
+ REAL_CONST(119939.95887360642/8.0),
+ REAL_CONST(119964.77254009615/8.0),
+ REAL_CONST(119989.58748977486/8.0),
+ REAL_CONST(120014.40372250983/8.0),
+ REAL_CONST(120039.22123816841/8.0),
+ REAL_CONST(120064.04003661797/8.0),
+ REAL_CONST(120088.86011772591/8.0),
+ REAL_CONST(120113.6814813597/8.0),
+ REAL_CONST(120138.5041273868/8.0),
+ REAL_CONST(120163.3280556747/8.0),
+ REAL_CONST(120188.15326609099/8.0),
+ REAL_CONST(120212.97975850321/8.0),
+ REAL_CONST(120237.807532779/8.0),
+ REAL_CONST(120262.63658878599/8.0),
+ REAL_CONST(120287.46692639188/8.0),
+ REAL_CONST(120312.29854546436/8.0),
+ REAL_CONST(120337.13144587121/8.0),
+ REAL_CONST(120361.9656274802/8.0),
+ REAL_CONST(120386.80109015915/8.0),
+ REAL_CONST(120411.63783377589/8.0),
+ REAL_CONST(120436.47585819835/8.0),
+ REAL_CONST(120461.31516329442/8.0),
+ REAL_CONST(120486.15574893207/8.0),
+ REAL_CONST(120510.99761497928/8.0),
+ REAL_CONST(120535.84076130406/8.0),
+ REAL_CONST(120560.68518777451/8.0),
+ REAL_CONST(120585.53089425867/8.0),
+ REAL_CONST(120610.3778806247/8.0),
+ REAL_CONST(120635.22614674074/8.0),
+ REAL_CONST(120660.07569247499/8.0),
+ REAL_CONST(120684.92651769568/8.0),
+ REAL_CONST(120709.77862227106/8.0),
+ REAL_CONST(120734.63200606944/8.0),
+ REAL_CONST(120759.48666895913/8.0),
+ REAL_CONST(120784.3426108085/8.0),
+ REAL_CONST(120809.19983148595/8.0),
+ REAL_CONST(120834.05833085992/8.0),
+ REAL_CONST(120858.91810879884/8.0),
+ REAL_CONST(120883.77916517125/8.0),
+ REAL_CONST(120908.64149984565/8.0),
+ REAL_CONST(120933.5051126906/8.0),
+ REAL_CONST(120958.37000357473/8.0),
+ REAL_CONST(120983.23617236665/8.0),
+ REAL_CONST(121008.10361893504/8.0),
+ REAL_CONST(121032.97234314861/8.0),
+ REAL_CONST(121057.84234487606/8.0),
+ REAL_CONST(121082.71362398617/8.0),
+ REAL_CONST(121107.58618034775/8.0),
+ REAL_CONST(121132.46001382964/8.0),
+ REAL_CONST(121157.33512430069/8.0),
+ REAL_CONST(121182.21151162982/8.0),
+ REAL_CONST(121207.08917568595/8.0),
+ REAL_CONST(121231.96811633807/8.0),
+ REAL_CONST(121256.84833345517/8.0),
+ REAL_CONST(121281.72982690629/8.0),
+ REAL_CONST(121306.61259656049/8.0),
+ REAL_CONST(121331.49664228689/8.0),
+ REAL_CONST(121356.38196395461/8.0),
+ REAL_CONST(121381.26856143285/8.0),
+ REAL_CONST(121406.15643459078/8.0),
+ REAL_CONST(121431.04558329767/8.0),
+ REAL_CONST(121455.93600742276/8.0),
+ REAL_CONST(121480.82770683538/8.0),
+ REAL_CONST(121505.72068140487/8.0),
+ REAL_CONST(121530.61493100057/8.0),
+ REAL_CONST(121555.51045549192/8.0),
+ REAL_CONST(121580.40725474835/8.0),
+ REAL_CONST(121605.30532863933/8.0),
+ REAL_CONST(121630.20467703436/8.0),
+ REAL_CONST(121655.10529980299/8.0),
+ REAL_CONST(121680.00719681478/8.0),
+ REAL_CONST(121704.91036793934/8.0),
+ REAL_CONST(121729.81481304632/8.0),
+ REAL_CONST(121754.72053200539/8.0),
+ REAL_CONST(121779.62752468624/8.0),
+ REAL_CONST(121804.53579095862/8.0),
+ REAL_CONST(121829.44533069231/8.0),
+ REAL_CONST(121854.3561437571/8.0),
+ REAL_CONST(121879.26823002285/8.0),
+ REAL_CONST(121904.1815893594/8.0),
+ REAL_CONST(121929.09622163669/8.0),
+ REAL_CONST(121954.01212672464/8.0),
+ REAL_CONST(121978.92930449323/8.0),
+ REAL_CONST(122003.84775481246/8.0),
+ REAL_CONST(122028.76747755238/8.0),
+ REAL_CONST(122053.68847258303/8.0),
+ REAL_CONST(122078.61073977455/8.0),
+ REAL_CONST(122103.53427899707/8.0),
+ REAL_CONST(122128.45909012076/8.0),
+ REAL_CONST(122153.38517301581/8.0),
+ REAL_CONST(122178.31252755247/8.0),
+ REAL_CONST(122203.24115360099/8.0),
+ REAL_CONST(122228.17105103172/8.0),
+ REAL_CONST(122253.10221971494/8.0),
+ REAL_CONST(122278.03465952107/8.0),
+ REAL_CONST(122302.96837032049/8.0),
+ REAL_CONST(122327.90335198362/8.0),
+ REAL_CONST(122352.83960438096/8.0),
+ REAL_CONST(122377.777127383/8.0),
+ REAL_CONST(122402.71592086025/8.0),
+ REAL_CONST(122427.65598468333/8.0),
+ REAL_CONST(122452.59731872278/8.0),
+ REAL_CONST(122477.53992284928/8.0),
+ REAL_CONST(122502.48379693348/8.0),
+ REAL_CONST(122527.42894084606/8.0),
+ REAL_CONST(122552.37535445779/8.0),
+ REAL_CONST(122577.32303763942/8.0),
+ REAL_CONST(122602.27199026172/8.0),
+ REAL_CONST(122627.22221219557/8.0),
+ REAL_CONST(122652.17370331181/8.0),
+ REAL_CONST(122677.12646348133/8.0),
+ REAL_CONST(122702.08049257506/8.0),
+ REAL_CONST(122727.03579046397/8.0),
+ REAL_CONST(122751.99235701906/8.0),
+ REAL_CONST(122776.95019211136/8.0),
+ REAL_CONST(122801.9092956119/8.0),
+ REAL_CONST(122826.8696673918/8.0),
+ REAL_CONST(122851.83130732219/8.0),
+ REAL_CONST(122876.79421527422/8.0),
+ REAL_CONST(122901.75839111909/8.0),
+ REAL_CONST(122926.72383472799/8.0),
+ REAL_CONST(122951.69054597223/8.0),
+ REAL_CONST(122976.65852472307/8.0),
+ REAL_CONST(123001.62777085182/8.0),
+ REAL_CONST(123026.59828422987/8.0),
+ REAL_CONST(123051.57006472857/8.0),
+ REAL_CONST(123076.54311221937/8.0),
+ REAL_CONST(123101.5174265737/8.0),
+ REAL_CONST(123126.49300766307/8.0),
+ REAL_CONST(123151.46985535898/8.0),
+ REAL_CONST(123176.44796953299/8.0),
+ REAL_CONST(123201.42735005668/8.0),
+ REAL_CONST(123226.40799680166/8.0),
+ REAL_CONST(123251.38990963959/8.0),
+ REAL_CONST(123276.37308844214/8.0),
+ REAL_CONST(123301.35753308103/8.0),
+ REAL_CONST(123326.343243428/8.0),
+ REAL_CONST(123351.33021935483/8.0),
+ REAL_CONST(123376.31846073334/8.0),
+ REAL_CONST(123401.30796743535/8.0),
+ REAL_CONST(123426.29873933276/8.0),
+ REAL_CONST(123451.29077629748/8.0),
+ REAL_CONST(123476.28407820144/8.0),
+ REAL_CONST(123501.2786449166/8.0),
+ REAL_CONST(123526.27447631498/8.0),
+ REAL_CONST(123551.27157226863/8.0),
+ REAL_CONST(123576.26993264959/8.0),
+ REAL_CONST(123601.26955732999/8.0),
+ REAL_CONST(123626.27044618195/8.0),
+ REAL_CONST(123651.27259907764/8.0),
+ REAL_CONST(123676.27601588926/8.0),
+ REAL_CONST(123701.28069648903/8.0),
+ REAL_CONST(123726.28664074924/8.0),
+ REAL_CONST(123751.29384854218/8.0),
+ REAL_CONST(123776.30231974016/8.0),
+ REAL_CONST(123801.31205421555/8.0),
+ REAL_CONST(123826.32305184075/8.0),
+ REAL_CONST(123851.33531248817/8.0),
+ REAL_CONST(123876.34883603029/8.0),
+ REAL_CONST(123901.36362233957/8.0),
+ REAL_CONST(123926.37967128855/8.0),
+ REAL_CONST(123951.39698274979/8.0),
+ REAL_CONST(123976.41555659588/8.0),
+ REAL_CONST(124001.43539269941/8.0),
+ REAL_CONST(124026.45649093305/8.0),
+ REAL_CONST(124051.47885116948/8.0),
+ REAL_CONST(124076.50247328142/8.0),
+ REAL_CONST(124101.5273571416/8.0),
+ REAL_CONST(124126.55350262282/8.0),
+ REAL_CONST(124151.58090959788/8.0),
+ REAL_CONST(124176.60957793961/8.0),
+ REAL_CONST(124201.63950752091/8.0),
+ REAL_CONST(124226.67069821467/8.0),
+ REAL_CONST(124251.70314989384/8.0),
+ REAL_CONST(124276.73686243138/8.0),
+ REAL_CONST(124301.7718357003/8.0),
+ REAL_CONST(124326.80806957364/8.0),
+ REAL_CONST(124351.84556392446/8.0),
+ REAL_CONST(124376.88431862585/8.0),
+ REAL_CONST(124401.92433355095/8.0),
+ REAL_CONST(124426.96560857294/8.0),
+ REAL_CONST(124452.00814356498/8.0),
+ REAL_CONST(124477.05193840031/8.0),
+ REAL_CONST(124502.0969929522/8.0),
+ REAL_CONST(124527.14330709392/8.0),
+ REAL_CONST(124552.19088069882/8.0),
+ REAL_CONST(124577.23971364023/8.0),
+ REAL_CONST(124602.28980579154/8.0),
+ REAL_CONST(124627.34115702618/8.0),
+ REAL_CONST(124652.3937672176/8.0),
+ REAL_CONST(124677.44763623926/8.0),
+ REAL_CONST(124702.50276396469/8.0),
+ REAL_CONST(124727.55915026742/8.0),
+ REAL_CONST(124752.61679502104/8.0),
+ REAL_CONST(124777.67569809916/8.0),
+ REAL_CONST(124802.73585937542/8.0),
+ REAL_CONST(124827.79727872348/8.0),
+ REAL_CONST(124852.85995601704/8.0),
+ REAL_CONST(124877.92389112986/8.0),
+ REAL_CONST(124902.98908393568/8.0),
+ REAL_CONST(124928.05553430831/8.0),
+ REAL_CONST(124953.1232421216/8.0),
+ REAL_CONST(124978.19220724938/8.0),
+ REAL_CONST(125003.26242956554/8.0),
+ REAL_CONST(125028.33390894404/8.0),
+ REAL_CONST(125053.40664525882/8.0),
+ REAL_CONST(125078.48063838384/8.0),
+ REAL_CONST(125103.55588819318/8.0),
+ REAL_CONST(125128.63239456083/8.0),
+ REAL_CONST(125153.71015736091/8.0),
+ REAL_CONST(125178.78917646752/8.0),
+ REAL_CONST(125203.86945175481/8.0),
+ REAL_CONST(125228.95098309696/8.0),
+ REAL_CONST(125254.03377036817/8.0),
+ REAL_CONST(125279.1178134427/8.0),
+ REAL_CONST(125304.20311219479/8.0),
+ REAL_CONST(125329.28966649878/8.0),
+ REAL_CONST(125354.37747622898/8.0),
+ REAL_CONST(125379.46654125977/8.0),
+ REAL_CONST(125404.55686146552/8.0),
+ REAL_CONST(125429.6484367207/8.0),
+ REAL_CONST(125454.74126689974/8.0),
+ REAL_CONST(125479.83535187715/8.0),
+ REAL_CONST(125504.93069152744/8.0),
+ REAL_CONST(125530.02728572517/8.0),
+ REAL_CONST(125555.12513434493/8.0),
+ REAL_CONST(125580.22423726133/8.0),
+ REAL_CONST(125605.32459434902/8.0),
+ REAL_CONST(125630.4262054827/8.0),
+ REAL_CONST(125655.52907053704/8.0),
+ REAL_CONST(125680.63318938682/8.0),
+ REAL_CONST(125705.73856190679/8.0),
+ REAL_CONST(125730.84518797178/8.0),
+ REAL_CONST(125755.9530674566/8.0),
+ REAL_CONST(125781.06220023613/8.0),
+ REAL_CONST(125806.17258618528/8.0),
+ REAL_CONST(125831.28422517896/8.0),
+ REAL_CONST(125856.39711709213/8.0),
+ REAL_CONST(125881.51126179981/8.0),
+ REAL_CONST(125906.62665917698/8.0),
+ REAL_CONST(125931.74330909875/8.0),
+ REAL_CONST(125956.86121144016/8.0),
+ REAL_CONST(125981.98036607634/8.0),
+ REAL_CONST(126007.10077288245/8.0),
+ REAL_CONST(126032.22243173365/8.0),
+ REAL_CONST(126057.34534250517/8.0),
+ REAL_CONST(126082.46950507225/8.0),
+ REAL_CONST(126107.59491931014/8.0),
+ REAL_CONST(126132.72158509417/8.0),
+ REAL_CONST(126157.84950229966/8.0),
+ REAL_CONST(126182.97867080198/8.0),
+ REAL_CONST(126208.10909047653/8.0),
+ REAL_CONST(126233.24076119871/8.0),
+ REAL_CONST(126258.37368284403/8.0),
+ REAL_CONST(126283.50785528794/8.0),
+ REAL_CONST(126308.64327840599/8.0),
+ REAL_CONST(126333.77995207369/8.0),
+ REAL_CONST(126358.91787616667/8.0),
+ REAL_CONST(126384.0570505605/8.0),
+ REAL_CONST(126409.19747513086/8.0),
+ REAL_CONST(126434.3391497534/8.0),
+ REAL_CONST(126459.48207430386/8.0),
+ REAL_CONST(126484.62624865794/8.0),
+ REAL_CONST(126509.77167269142/8.0),
+ REAL_CONST(126534.9183462801/8.0),
+ REAL_CONST(126560.06626929982/8.0),
+ REAL_CONST(126585.21544162642/8.0),
+ REAL_CONST(126610.36586313581/8.0),
+ REAL_CONST(126635.51753370393/8.0),
+ REAL_CONST(126660.67045320668/8.0),
+ REAL_CONST(126685.82462152008/8.0),
+ REAL_CONST(126710.98003852014/8.0),
+ REAL_CONST(126736.13670408291/8.0),
+ REAL_CONST(126761.29461808444/8.0),
+ REAL_CONST(126786.45378040087/8.0),
+ REAL_CONST(126811.61419090834/8.0),
+ REAL_CONST(126836.77584948298/8.0),
+ REAL_CONST(126861.93875600102/8.0),
+ REAL_CONST(126887.10291033868/8.0),
+ REAL_CONST(126912.26831237224/8.0),
+ REAL_CONST(126937.43496197795/8.0),
+ REAL_CONST(126962.60285903217/8.0),
+ REAL_CONST(126987.77200341123/8.0),
+ REAL_CONST(127012.94239499152/8.0),
+ REAL_CONST(127038.11403364947/8.0),
+ REAL_CONST(127063.2869192615/8.0),
+ REAL_CONST(127088.46105170409/8.0),
+ REAL_CONST(127113.63643085376/8.0),
+ REAL_CONST(127138.81305658702/8.0),
+ REAL_CONST(127163.99092878048/8.0),
+ REAL_CONST(127189.17004731069/8.0),
+ REAL_CONST(127214.35041205429/8.0),
+ REAL_CONST(127239.53202288797/8.0),
+ REAL_CONST(127264.71487968838/8.0),
+ REAL_CONST(127289.89898233226/8.0),
+ REAL_CONST(127315.08433069635/8.0),
+ REAL_CONST(127340.27092465744/8.0),
+ REAL_CONST(127365.45876409234/8.0),
+ REAL_CONST(127390.64784887788/8.0),
+ REAL_CONST(127415.83817889093/8.0),
+ REAL_CONST(127441.02975400841/8.0),
+ REAL_CONST(127466.22257410725/8.0),
+ REAL_CONST(127491.41663906439/8.0),
+ REAL_CONST(127516.61194875685/8.0),
+ REAL_CONST(127541.80850306165/8.0),
+ REAL_CONST(127567.00630185583/8.0),
+ REAL_CONST(127592.20534501647/8.0),
+ REAL_CONST(127617.4056324207/8.0),
+ REAL_CONST(127642.60716394568/8.0),
+ REAL_CONST(127667.80993946856/8.0),
+ REAL_CONST(127693.01395886653/8.0),
+ REAL_CONST(127718.21922201688/8.0),
+ REAL_CONST(127743.42572879682/8.0),
+ REAL_CONST(127768.63347908368/8.0),
+ REAL_CONST(127793.84247275478/8.0),
+ REAL_CONST(127819.05270968749/8.0),
+ REAL_CONST(127844.26418975917/8.0),
+ REAL_CONST(127869.47691284724/8.0),
+ REAL_CONST(127894.69087882918/8.0),
+ REAL_CONST(127919.90608758242/8.0),
+ REAL_CONST(127945.12253898452/8.0),
+ REAL_CONST(127970.34023291297/8.0),
+ REAL_CONST(127995.55916924537/8.0),
+ REAL_CONST(128020.77934785932/8.0),
+ REAL_CONST(128046.00076863244/8.0),
+ REAL_CONST(128071.22343144237/8.0),
+ REAL_CONST(128096.44733616684/8.0),
+ REAL_CONST(128121.67248268353/8.0),
+ REAL_CONST(128146.89887087021/8.0),
+ REAL_CONST(128172.12650060465/8.0),
+ REAL_CONST(128197.35537176467/8.0),
+ REAL_CONST(128222.5854842281/8.0),
+ REAL_CONST(128247.81683787282/8.0),
+ REAL_CONST(128273.04943257671/8.0),
+ REAL_CONST(128298.28326821771/8.0),
+ REAL_CONST(128323.51834467379/8.0),
+ REAL_CONST(128348.75466182294/8.0),
+ REAL_CONST(128373.99221954317/8.0),
+ REAL_CONST(128399.23101771252/8.0),
+ REAL_CONST(128424.47105620909/8.0),
+ REAL_CONST(128449.71233491098/8.0),
+ REAL_CONST(128474.95485369631/8.0),
+ REAL_CONST(128500.19861244329/8.0),
+ REAL_CONST(128525.44361103009/8.0),
+ REAL_CONST(128550.68984933494/8.0),
+ REAL_CONST(128575.93732723613/8.0),
+ REAL_CONST(128601.18604461191/8.0),
+ REAL_CONST(128626.43600134061/8.0),
+ REAL_CONST(128651.68719730059/8.0),
+ REAL_CONST(128676.93963237021/8.0),
+ REAL_CONST(128702.1933064279/8.0),
+ REAL_CONST(128727.44821935208/8.0),
+ REAL_CONST(128752.70437102125/8.0),
+ REAL_CONST(128777.96176131385/8.0),
+ REAL_CONST(128803.22039010846/8.0),
+ REAL_CONST(128828.48025728362/8.0),
+ REAL_CONST(128853.74136271792/8.0),
+ REAL_CONST(128879.00370628996/8.0),
+ REAL_CONST(128904.26728787841/8.0),
+ REAL_CONST(128929.53210736193/8.0),
+ REAL_CONST(128954.79816461923/8.0),
+ REAL_CONST(128980.06545952905/8.0),
+ REAL_CONST(129005.33399197015/8.0),
+ REAL_CONST(129030.60376182134/8.0),
+ REAL_CONST(129055.87476896142/8.0),
+ REAL_CONST(129081.14701326926/8.0),
+ REAL_CONST(129106.42049462376/8.0),
+ REAL_CONST(129131.6952129038/8.0),
+ REAL_CONST(129156.97116798835/8.0),
+ REAL_CONST(129182.24835975636/8.0),
+ REAL_CONST(129207.52678808685/8.0),
+ REAL_CONST(129232.80645285884/8.0),
+ REAL_CONST(129258.08735395141/8.0),
+ REAL_CONST(129283.36949124365/8.0),
+ REAL_CONST(129308.65286461466/8.0),
+ REAL_CONST(129333.9374739436/8.0),
+ REAL_CONST(129359.22331910966/8.0),
+ REAL_CONST(129384.51039999202/8.0),
+ REAL_CONST(129409.79871646997/8.0),
+ REAL_CONST(129435.08826842274/8.0),
+ REAL_CONST(129460.37905572963/8.0),
+ REAL_CONST(129485.67107826998/8.0),
+ REAL_CONST(129510.96433592314/8.0),
+ REAL_CONST(129536.25882856851/8.0),
+ REAL_CONST(129561.55455608548/8.0),
+ REAL_CONST(129586.85151835352/8.0),
+ REAL_CONST(129612.14971525209/8.0),
+ REAL_CONST(129637.4491466607/8.0),
+ REAL_CONST(129662.74981245887/8.0),
+ REAL_CONST(129688.0517125262/8.0),
+ REAL_CONST(129713.35484674224/8.0),
+ REAL_CONST(129738.65921498663/8.0),
+ REAL_CONST(129763.96481713903/8.0),
+ REAL_CONST(129789.27165307909/8.0),
+ REAL_CONST(129814.57972268655/8.0),
+ REAL_CONST(129839.88902584116/8.0),
+ REAL_CONST(129865.19956242264/8.0),
+ REAL_CONST(129890.51133231082/8.0),
+ REAL_CONST(129915.82433538554/8.0),
+ REAL_CONST(129941.13857152662/8.0),
+ REAL_CONST(129966.45404061397/8.0),
+ REAL_CONST(129991.7707425275/8.0),
+ REAL_CONST(130017.08867714716/8.0),
+ REAL_CONST(130042.4078443529/8.0),
+ REAL_CONST(130067.72824402474/8.0),
+ REAL_CONST(130093.04987604271/8.0),
+ REAL_CONST(130118.37274028687/8.0),
+ REAL_CONST(130143.69683663732/8.0),
+ REAL_CONST(130169.02216497416/8.0),
+ REAL_CONST(130194.34872517755/8.0),
+ REAL_CONST(130219.67651712766/8.0),
+ REAL_CONST(130245.0055407047/8.0),
+ REAL_CONST(130270.33579578891/8.0),
+ REAL_CONST(130295.66728226055/8.0),
+ REAL_CONST(130320.99999999991/8.0),
+ REAL_CONST(130346.33394888733/8.0),
+ REAL_CONST(130371.66912880314/8.0),
+ REAL_CONST(130397.00553962773/8.0),
+ REAL_CONST(130422.34318124152/8.0),
+ REAL_CONST(130447.68205352494/8.0),
+ REAL_CONST(130473.02215635845/8.0),
+ REAL_CONST(130498.36348962256/8.0),
+ REAL_CONST(130523.70605319779/8.0),
+ REAL_CONST(130549.0498469647/8.0),
+ REAL_CONST(130574.39487080388/8.0),
+ REAL_CONST(130599.74112459592/8.0),
+ REAL_CONST(130625.08860822149/8.0),
+ REAL_CONST(130650.43732156123/8.0),
+ REAL_CONST(130675.78726449587/8.0),
+ REAL_CONST(130701.13843690613/8.0),
+ REAL_CONST(130726.49083867275/8.0),
+ REAL_CONST(130751.84446967654/8.0),
+ REAL_CONST(130777.19932979831/8.0),
+ REAL_CONST(130802.5554189189/8.0),
+ REAL_CONST(130827.91273691918/8.0),
+ REAL_CONST(130853.27128368006/8.0),
+ REAL_CONST(130878.63105908247/8.0),
+ REAL_CONST(130903.99206300738/8.0),
+ REAL_CONST(130929.35429533575/8.0),
+ REAL_CONST(130954.71775594862/8.0),
+ REAL_CONST(130980.08244472703/8.0),
+ REAL_CONST(131005.44836155206/8.0),
+ REAL_CONST(131030.81550630482/8.0),
+ REAL_CONST(131056.18387886642/8.0),
+ REAL_CONST(131081.55347911804/8.0),
+ REAL_CONST(131106.92430694087/8.0),
+ REAL_CONST(131132.29636221612/8.0),
+ REAL_CONST(131157.66964482504/8.0),
+ REAL_CONST(131183.0441546489/8.0),
+ REAL_CONST(131208.41989156904/8.0),
+ REAL_CONST(131233.79685546676/8.0),
+ REAL_CONST(131259.17504622342/8.0),
+ REAL_CONST(131284.55446372041/8.0),
+ REAL_CONST(131309.93510783918/8.0),
+ REAL_CONST(131335.31697846117/8.0),
+ REAL_CONST(131360.70007546784/8.0),
+ REAL_CONST(131386.0843987407/8.0),
+ REAL_CONST(131411.46994816128/8.0),
+ REAL_CONST(131436.85672361116/8.0),
+ REAL_CONST(131462.24472497194/8.0),
+ REAL_CONST(131487.63395212521/8.0),
+ REAL_CONST(131513.02440495262/8.0),
+ REAL_CONST(131538.41608333588/8.0),
+ REAL_CONST(131563.80898715663/8.0),
+ REAL_CONST(131589.2031162967/8.0),
+ REAL_CONST(131614.59847063778/8.0),
+ REAL_CONST(131639.9950500617/8.0),
+ REAL_CONST(131665.39285445024/8.0),
+ REAL_CONST(131690.79188368531/8.0),
+ REAL_CONST(131716.19213764873/8.0),
+ REAL_CONST(131741.59361622241/8.0),
+ REAL_CONST(131766.99631928833/8.0),
+ REAL_CONST(131792.40024672839/8.0),
+ REAL_CONST(131817.80539842462/8.0),
+ REAL_CONST(131843.21177425905/8.0),
+ REAL_CONST(131868.61937411371/8.0),
+ REAL_CONST(131894.02819787065/8.0),
+ REAL_CONST(131919.43824541202/8.0),
+ REAL_CONST(131944.84951661993/8.0),
+ REAL_CONST(131970.26201137656/8.0),
+ REAL_CONST(131995.67572956407/8.0),
+ REAL_CONST(132021.09067106468/8.0),
+ REAL_CONST(132046.50683576067/8.0),
+ REAL_CONST(132071.9242235343/8.0),
+ REAL_CONST(132097.34283426782/8.0),
+ REAL_CONST(132122.76266784366/8.0),
+ REAL_CONST(132148.1837241441/8.0),
+ REAL_CONST(132173.60600305157/8.0),
+ REAL_CONST(132199.02950444847/8.0),
+ REAL_CONST(132224.45422821722/8.0),
+ REAL_CONST(132249.88017424036/8.0),
+ REAL_CONST(132275.30734240031/8.0),
+ REAL_CONST(132300.73573257966/8.0),
+ REAL_CONST(132326.16534466096/8.0),
+ REAL_CONST(132351.59617852676/8.0),
+ REAL_CONST(132377.02823405969/8.0),
+ REAL_CONST(132402.46151114244/8.0),
+ REAL_CONST(132427.89600965759/8.0),
+ REAL_CONST(132453.33172948789/8.0),
+ REAL_CONST(132478.76867051609/8.0),
+ REAL_CONST(132504.20683262491/8.0),
+ REAL_CONST(132529.64621569714/8.0),
+ REAL_CONST(132555.08681961559/8.0),
+ REAL_CONST(132580.5286442631/8.0),
+ REAL_CONST(132605.97168952253/8.0),
+ REAL_CONST(132631.41595527678/8.0),
+ REAL_CONST(132656.86144140881/8.0),
+ REAL_CONST(132682.30814780149/8.0),
+ REAL_CONST(132707.75607433787/8.0),
+ REAL_CONST(132733.20522090094/8.0),
+ REAL_CONST(132758.65558737374/8.0),
+ REAL_CONST(132784.10717363929/8.0),
+ REAL_CONST(132809.55997958075/8.0),
+ REAL_CONST(132835.01400508118/8.0),
+ REAL_CONST(132860.46925002377/8.0),
+ REAL_CONST(132885.92571429166/8.0),
+ REAL_CONST(132911.38339776811/8.0),
+ REAL_CONST(132936.84230033628/8.0),
+ REAL_CONST(132962.30242187946/8.0),
+ REAL_CONST(132987.76376228096/8.0),
+ REAL_CONST(133013.22632142407/8.0),
+ REAL_CONST(133038.69009919214/8.0),
+ REAL_CONST(133064.15509546854/8.0),
+ REAL_CONST(133089.62131013666/8.0),
+ REAL_CONST(133115.08874307995/8.0),
+ REAL_CONST(133140.55739418184/8.0),
+ REAL_CONST(133166.02726332581/8.0),
+ REAL_CONST(133191.49835039541/8.0),
+ REAL_CONST(133216.97065527414/8.0),
+ REAL_CONST(133242.44417784561/8.0),
+ REAL_CONST(133267.91891799335/8.0),
+ REAL_CONST(133293.39487560102/8.0),
+ REAL_CONST(133318.87205055228/8.0),
+ REAL_CONST(133344.35044273079/8.0),
+ REAL_CONST(133369.83005202023/8.0),
+ REAL_CONST(133395.31087830439/8.0),
+ REAL_CONST(133420.79292146701/8.0),
+ REAL_CONST(133446.27618139185/8.0),
+ REAL_CONST(133471.76065796276/8.0),
+ REAL_CONST(133497.24635106357/8.0),
+ REAL_CONST(133522.73326057816/8.0),
+ REAL_CONST(133548.22138639039/8.0),
+ REAL_CONST(133573.71072838426/8.0),
+ REAL_CONST(133599.20128644365/8.0),
+ REAL_CONST(133624.69306045261/8.0),
+ REAL_CONST(133650.1860502951/8.0),
+ REAL_CONST(133675.68025585517/8.0),
+ REAL_CONST(133701.1756770169/8.0),
+ REAL_CONST(133726.67231366437/8.0),
+ REAL_CONST(133752.17016568172/8.0),
+ REAL_CONST(133777.66923295305/8.0),
+ REAL_CONST(133803.16951536259/8.0),
+ REAL_CONST(133828.67101279454/8.0),
+ REAL_CONST(133854.17372513309/8.0),
+ REAL_CONST(133879.67765226253/8.0),
+ REAL_CONST(133905.18279406714/8.0),
+ REAL_CONST(133930.68915043125/8.0),
+ REAL_CONST(133956.19672123916/8.0),
+ REAL_CONST(133981.70550637526/8.0),
+ REAL_CONST(134007.21550572399/8.0),
+ REAL_CONST(134032.7267191697/8.0),
+ REAL_CONST(134058.23914659687/8.0),
+ REAL_CONST(134083.75278789/8.0),
+ REAL_CONST(134109.26764293358/8.0),
+ REAL_CONST(134134.78371161217/8.0),
+ REAL_CONST(134160.30099381026/8.0),
+ REAL_CONST(134185.8194894125/8.0),
+ REAL_CONST(134211.33919830353/8.0),
+ REAL_CONST(134236.8601203679/8.0),
+ REAL_CONST(134262.38225549037/8.0),
+ REAL_CONST(134287.90560355558/8.0),
+ REAL_CONST(134313.43016444831/8.0),
+ REAL_CONST(134338.95593805326/8.0),
+ REAL_CONST(134364.48292425525/8.0),
+ REAL_CONST(134390.01112293909/8.0),
+ REAL_CONST(134415.54053398955/8.0),
+ REAL_CONST(134441.07115729159/8.0),
+ REAL_CONST(134466.60299273001/8.0),
+ REAL_CONST(134492.1360401898/8.0),
+ REAL_CONST(134517.67029955584/8.0),
+ REAL_CONST(134543.20577071316/8.0),
+ REAL_CONST(134568.74245354676/8.0),
+ REAL_CONST(134594.28034794159/8.0),
+ REAL_CONST(134619.81945378278/8.0),
+ REAL_CONST(134645.35977095537/8.0),
+ REAL_CONST(134670.90129934452/8.0),
+ REAL_CONST(134696.4440388353/8.0),
+ REAL_CONST(134721.98798931291/8.0),
+ REAL_CONST(134747.53315066252/8.0),
+ REAL_CONST(134773.07952276937/8.0),
+ REAL_CONST(134798.62710551871/8.0),
+ REAL_CONST(134824.17589879577/8.0),
+ REAL_CONST(134849.72590248589/8.0),
+ REAL_CONST(134875.27711647438/8.0),
+ REAL_CONST(134900.82954064661/8.0),
+ REAL_CONST(134926.38317488792/8.0),
+ REAL_CONST(134951.93801908373/8.0),
+ REAL_CONST(134977.49407311951/8.0),
+ REAL_CONST(135003.05133688069/8.0),
+ REAL_CONST(135028.60981025276/8.0),
+ REAL_CONST(135054.16949312127/8.0),
+ REAL_CONST(135079.73038537172/8.0),
+ REAL_CONST(135105.29248688967/8.0),
+ REAL_CONST(135130.85579756077/8.0),
+ REAL_CONST(135156.42031727062/8.0),
+ REAL_CONST(135181.98604590484/8.0),
+ REAL_CONST(135207.55298334916/8.0),
+ REAL_CONST(135233.12112948924/8.0),
+ REAL_CONST(135258.69048421088/8.0),
+ REAL_CONST(135284.26104739975/8.0),
+ REAL_CONST(135309.83281894168/8.0),
+ REAL_CONST(135335.4057987225/8.0),
+ REAL_CONST(135360.97998662802/8.0),
+ REAL_CONST(135386.55538254412/8.0),
+ REAL_CONST(135412.13198635669/8.0),
+ REAL_CONST(135437.70979795168/8.0),
+ REAL_CONST(135463.28881721498/8.0),
+ REAL_CONST(135488.86904403262/8.0),
+ REAL_CONST(135514.45047829056/8.0),
+ REAL_CONST(135540.03311987486/8.0),
+ REAL_CONST(135565.61696867159/8.0),
+ REAL_CONST(135591.20202456677/8.0),
+ REAL_CONST(135616.78828744654/8.0),
+ REAL_CONST(135642.37575719706/8.0),
+ REAL_CONST(135667.96443370447/8.0),
+ REAL_CONST(135693.55431685498/8.0),
+ REAL_CONST(135719.14540653475/8.0),
+ REAL_CONST(135744.73770263011/8.0),
+ REAL_CONST(135770.33120502727/8.0),
+ REAL_CONST(135795.92591361253/8.0),
+ REAL_CONST(135821.52182827223/8.0),
+ REAL_CONST(135847.11894889272/8.0),
+ REAL_CONST(135872.7172753604/8.0),
+ REAL_CONST(135898.31680756161/8.0),
+ REAL_CONST(135923.91754538284/8.0),
+ REAL_CONST(135949.51948871053/8.0),
+ REAL_CONST(135975.12263743114/8.0),
+ REAL_CONST(136000.72699143123/8.0),
+ REAL_CONST(136026.33255059729/8.0),
+ REAL_CONST(136051.93931481591/8.0),
+ REAL_CONST(136077.54728397369/8.0),
+ REAL_CONST(136103.15645795723/8.0),
+ REAL_CONST(136128.76683665317/8.0),
+ REAL_CONST(136154.37841994822/8.0),
+ REAL_CONST(136179.99120772901/8.0),
+ REAL_CONST(136205.60519988232/8.0),
+ REAL_CONST(136231.2203962949/8.0),
+ REAL_CONST(136256.83679685349/8.0),
+ REAL_CONST(136282.45440144493/8.0),
+ REAL_CONST(136308.07320995603/8.0),
+ REAL_CONST(136333.69322227367/8.0),
+ REAL_CONST(136359.31443828469/8.0),
+ REAL_CONST(136384.93685787608/8.0),
+ REAL_CONST(136410.56048093468/8.0),
+ REAL_CONST(136436.18530734754/8.0),
+ REAL_CONST(136461.81133700156/8.0),
+ REAL_CONST(136487.43856978384/8.0),
+ REAL_CONST(136513.06700558143/8.0),
+ REAL_CONST(136538.6966442813/8.0),
+ REAL_CONST(136564.32748577066/8.0),
+ REAL_CONST(136589.95952993655/8.0),
+ REAL_CONST(136615.59277666616/8.0),
+ REAL_CONST(136641.22722584667/8.0),
+ REAL_CONST(136666.86287736523/8.0),
+ REAL_CONST(136692.49973110916/8.0),
+ REAL_CONST(136718.13778696564/8.0),
+ REAL_CONST(136743.77704482197/8.0),
+ REAL_CONST(136769.41750456547/8.0),
+ REAL_CONST(136795.05916608346/8.0),
+ REAL_CONST(136820.70202926331/8.0),
+ REAL_CONST(136846.34609399244/8.0),
+ REAL_CONST(136871.99136015819/8.0),
+ REAL_CONST(136897.63782764805/8.0),
+ REAL_CONST(136923.28549634948/8.0),
+ REAL_CONST(136948.93436614997/8.0),
+ REAL_CONST(136974.58443693706/8.0),
+ REAL_CONST(137000.23570859825/8.0),
+ REAL_CONST(137025.88818102115/8.0),
+ REAL_CONST(137051.54185409332/8.0),
+ REAL_CONST(137077.19672770242/8.0),
+ REAL_CONST(137102.85280173609/8.0),
+ REAL_CONST(137128.51007608202/8.0),
+ REAL_CONST(137154.16855062786/8.0),
+ REAL_CONST(137179.82822526142/8.0),
+ REAL_CONST(137205.48909987041/8.0),
+ REAL_CONST(137231.15117434258/8.0),
+ REAL_CONST(137256.8144485658/8.0),
+ REAL_CONST(137282.47892242789/8.0),
+ REAL_CONST(137308.14459581667/8.0),
+ REAL_CONST(137333.81146862009/8.0),
+ REAL_CONST(137359.47954072602/8.0),
+ REAL_CONST(137385.14881202241/8.0),
+ REAL_CONST(137410.81928239719/8.0),
+ REAL_CONST(137436.49095173844/8.0),
+ REAL_CONST(137462.16381993407/8.0),
+ REAL_CONST(137487.83788687221/8.0),
+ REAL_CONST(137513.51315244089/8.0),
+ REAL_CONST(137539.18961652822/8.0),
+ REAL_CONST(137564.86727902229/8.0),
+ REAL_CONST(137590.54613981131/8.0),
+ REAL_CONST(137616.22619878338/8.0),
+ REAL_CONST(137641.90745582676/8.0),
+ REAL_CONST(137667.58991082967/8.0),
+ REAL_CONST(137693.27356368033/8.0),
+ REAL_CONST(137718.95841426702/8.0),
+ REAL_CONST(137744.64446247809/8.0),
+ REAL_CONST(137770.33170820182/8.0),
+ REAL_CONST(137796.02015132661/8.0),
+ REAL_CONST(137821.70979174081/8.0),
+ REAL_CONST(137847.40062933284/8.0),
+ REAL_CONST(137873.09266399115/8.0),
+ REAL_CONST(137898.78589560417/8.0),
+ REAL_CONST(137924.48032406042/8.0),
+ REAL_CONST(137950.17594924837/8.0),
+ REAL_CONST(137975.8727710566/8.0),
+ REAL_CONST(138001.57078937365/8.0),
+ REAL_CONST(138027.27000408815/8.0),
+ REAL_CONST(138052.97041508864/8.0),
+ REAL_CONST(138078.67202226384/8.0),
+ REAL_CONST(138104.3748255024/8.0),
+ REAL_CONST(138130.07882469296/8.0),
+ REAL_CONST(138155.78401972432/8.0),
+ REAL_CONST(138181.49041048516/8.0),
+ REAL_CONST(138207.1979968643/8.0),
+ REAL_CONST(138232.9067787505/8.0),
+ REAL_CONST(138258.61675603263/8.0),
+ REAL_CONST(138284.32792859949/8.0),
+ REAL_CONST(138310.04029633995/8.0),
+ REAL_CONST(138335.75385914298/8.0),
+ REAL_CONST(138361.46861689744/8.0),
+ REAL_CONST(138387.18456949232/8.0),
+ REAL_CONST(138412.90171681659/8.0),
+ REAL_CONST(138438.62005875923/8.0),
+ REAL_CONST(138464.33959520931/8.0),
+ REAL_CONST(138490.06032605586/8.0),
+ REAL_CONST(138515.78225118798/8.0),
+ REAL_CONST(138541.50537049473/8.0),
+ REAL_CONST(138567.2296838653/8.0),
+ REAL_CONST(138592.95519118884/8.0),
+ REAL_CONST(138618.68189235451/8.0),
+ REAL_CONST(138644.40978725153/8.0),
+ REAL_CONST(138670.13887576913/8.0),
+ REAL_CONST(138695.86915779658/8.0),
+ REAL_CONST(138721.60063322316/8.0),
+ REAL_CONST(138747.33330193823/8.0),
+ REAL_CONST(138773.06716383106/8.0),
+ REAL_CONST(138798.80221879104/8.0),
+ REAL_CONST(138824.53846670757/8.0),
+ REAL_CONST(138850.27590747006/8.0),
+ REAL_CONST(138876.01454096794/8.0),
+ REAL_CONST(138901.7543670907/8.0),
+ REAL_CONST(138927.49538572782/8.0),
+ REAL_CONST(138953.2375967688/8.0),
+ REAL_CONST(138978.9810001032/8.0),
+ REAL_CONST(139004.72559562061/8.0),
+ REAL_CONST(139030.47138321059/8.0),
+ REAL_CONST(139056.2183627628/8.0),
+ REAL_CONST(139081.96653416683/8.0),
+ REAL_CONST(139107.71589731239/8.0),
+ REAL_CONST(139133.46645208917/8.0),
+ REAL_CONST(139159.21819838689/8.0),
+ REAL_CONST(139184.97113609532/8.0),
+ REAL_CONST(139210.72526510421/8.0),
+ REAL_CONST(139236.48058530336/8.0),
+ REAL_CONST(139262.23709658257/8.0),
+ REAL_CONST(139287.99479883176/8.0),
+ REAL_CONST(139313.75369194071/8.0),
+ REAL_CONST(139339.51377579942/8.0),
+ REAL_CONST(139365.27505029776/8.0),
+ REAL_CONST(139391.03751532568/8.0),
+ REAL_CONST(139416.80117077316/8.0),
+ REAL_CONST(139442.56601653024/8.0),
+ REAL_CONST(139468.33205248689/8.0),
+ REAL_CONST(139494.09927853322/8.0),
+ REAL_CONST(139519.86769455927/8.0),
+ REAL_CONST(139545.63730045516/8.0),
+ REAL_CONST(139571.408096111/8.0),
+ REAL_CONST(139597.18008141697/8.0),
+ REAL_CONST(139622.95325626322/8.0),
+ REAL_CONST(139648.72762054001/8.0),
+ REAL_CONST(139674.5031741375/8.0),
+ REAL_CONST(139700.27991694602/8.0),
+ REAL_CONST(139726.05784885579/8.0),
+ REAL_CONST(139751.83696975713/8.0),
+ REAL_CONST(139777.61727954043/8.0),
+ REAL_CONST(139803.39877809596/8.0),
+ REAL_CONST(139829.18146531415/8.0),
+ REAL_CONST(139854.96534108539/8.0),
+ REAL_CONST(139880.75040530015/8.0),
+ REAL_CONST(139906.53665784886/8.0),
+ REAL_CONST(139932.32409862199/8.0),
+ REAL_CONST(139958.11272751007/8.0),
+ REAL_CONST(139983.90254440365/8.0),
+ REAL_CONST(140009.69354919327/8.0),
+ REAL_CONST(140035.48574176949/8.0),
+ REAL_CONST(140061.27912202294/8.0),
+ REAL_CONST(140087.07368984428/8.0),
+ REAL_CONST(140112.86944512415/8.0),
+ REAL_CONST(140138.66638775321/8.0),
+ REAL_CONST(140164.4645176222/8.0),
+ REAL_CONST(140190.26383462184/8.0),
+ REAL_CONST(140216.06433864293/8.0),
+ REAL_CONST(140241.86602957622/8.0),
+ REAL_CONST(140267.66890731253/8.0),
+ REAL_CONST(140293.47297174268/8.0),
+ REAL_CONST(140319.27822275754/8.0),
+ REAL_CONST(140345.08466024802/8.0),
+ REAL_CONST(140370.89228410498/8.0),
+ REAL_CONST(140396.70109421943/8.0),
+ REAL_CONST(140422.51109048226/8.0),
+ REAL_CONST(140448.32227278448/8.0),
+ REAL_CONST(140474.13464101712/8.0),
+ REAL_CONST(140499.94819507122/8.0),
+ REAL_CONST(140525.76293483781/8.0),
+ REAL_CONST(140551.57886020801/8.0),
+ REAL_CONST(140577.3959710729/8.0),
+ REAL_CONST(140603.21426732364/8.0),
+ REAL_CONST(140629.03374885136/8.0),
+ REAL_CONST(140654.85441554731/8.0),
+ REAL_CONST(140680.67626730262/8.0),
+ REAL_CONST(140706.49930400858/8.0),
+ REAL_CONST(140732.32352555645/8.0),
+ REAL_CONST(140758.1489318375/8.0),
+ REAL_CONST(140783.97552274304/8.0),
+ REAL_CONST(140809.80329816442/8.0),
+ REAL_CONST(140835.63225799298/8.0),
+ REAL_CONST(140861.46240212015/8.0),
+ REAL_CONST(140887.29373043729/8.0),
+ REAL_CONST(140913.12624283586/8.0),
+ REAL_CONST(140938.95993920733/8.0),
+ REAL_CONST(140964.79481944317/8.0),
+ REAL_CONST(140990.63088343487/8.0),
+ REAL_CONST(141016.46813107401/8.0),
+ REAL_CONST(141042.30656225214/8.0),
+ REAL_CONST(141068.14617686081/8.0),
+ REAL_CONST(141093.98697479168/8.0),
+ REAL_CONST(141119.82895593636/8.0),
+ REAL_CONST(141145.6721201865/8.0),
+ REAL_CONST(141171.51646743377/8.0),
+ REAL_CONST(141197.36199756994/8.0),
+ REAL_CONST(141223.20871048668/8.0),
+ REAL_CONST(141249.05660607578/8.0),
+ REAL_CONST(141274.90568422904/8.0),
+ REAL_CONST(141300.75594483822/8.0),
+ REAL_CONST(141326.6073877952/8.0),
+ REAL_CONST(141352.4600129918/8.0),
+ REAL_CONST(141378.31382031992/8.0),
+ REAL_CONST(141404.16880967148/8.0),
+ REAL_CONST(141430.02498093838/8.0),
+ REAL_CONST(141455.8823340126/8.0),
+ REAL_CONST(141481.74086878612/8.0),
+ REAL_CONST(141507.60058515094/8.0),
+ REAL_CONST(141533.46148299909/8.0),
+ REAL_CONST(141559.32356222265/8.0),
+ REAL_CONST(141585.18682271364/8.0),
+ REAL_CONST(141611.05126436421/8.0),
+ REAL_CONST(141636.9168870665/8.0),
+ REAL_CONST(141662.78369071262/8.0),
+ REAL_CONST(141688.65167519479/8.0),
+ REAL_CONST(141714.5208404052/8.0),
+ REAL_CONST(141740.39118623605/8.0),
+ REAL_CONST(141766.26271257963/8.0),
+ REAL_CONST(141792.1354193282/8.0),
+ REAL_CONST(141818.00930637406/8.0),
+ REAL_CONST(141843.88437360956/8.0),
+ REAL_CONST(141869.760620927/8.0),
+ REAL_CONST(141895.6380482188/8.0),
+ REAL_CONST(141921.51665537735/8.0),
+ REAL_CONST(141947.39644229505/8.0),
+ REAL_CONST(141973.27740886438/8.0),
+ REAL_CONST(141999.15955497778/8.0),
+ REAL_CONST(142025.04288052776/8.0),
+ REAL_CONST(142050.92738540689/8.0),
+ REAL_CONST(142076.81306950765/8.0),
+ REAL_CONST(142102.69993272264/8.0),
+ REAL_CONST(142128.58797494444/8.0),
+ REAL_CONST(142154.47719606571/8.0),
+ REAL_CONST(142180.36759597904/8.0),
+ REAL_CONST(142206.25917457714/8.0),
+ REAL_CONST(142232.15193175265/8.0),
+ REAL_CONST(142258.04586739838/8.0),
+ REAL_CONST(142283.94098140698/8.0),
+ REAL_CONST(142309.83727367126/8.0),
+ REAL_CONST(142335.73474408401/8.0),
+ REAL_CONST(142361.63339253806/8.0),
+ REAL_CONST(142387.5332189262/8.0),
+ REAL_CONST(142413.43422314132/8.0),
+ REAL_CONST(142439.33640507635/8.0),
+ REAL_CONST(142465.23976462413/8.0),
+ REAL_CONST(142491.14430167765/8.0),
+ REAL_CONST(142517.05001612983/8.0),
+ REAL_CONST(142542.95690787368/8.0),
+ REAL_CONST(142568.86497680223/8.0),
+ REAL_CONST(142594.77422280848/8.0),
+ REAL_CONST(142620.68464578551/8.0),
+ REAL_CONST(142646.5962456264/8.0),
+ REAL_CONST(142672.50902222423/8.0),
+ REAL_CONST(142698.42297547215/8.0),
+ REAL_CONST(142724.33810526333/8.0),
+ REAL_CONST(142750.25441149093/8.0),
+ REAL_CONST(142776.17189404817/8.0),
+ REAL_CONST(142802.09055282827/8.0),
+ REAL_CONST(142828.01038772447/8.0),
+ REAL_CONST(142853.93139863008/8.0),
+ REAL_CONST(142879.85358543837/8.0),
+ REAL_CONST(142905.77694804268/8.0),
+ REAL_CONST(142931.70148633636/8.0),
+ REAL_CONST(142957.62720021277/8.0),
+ REAL_CONST(142983.55408956532/8.0),
+ REAL_CONST(143009.48215428743/8.0),
+ REAL_CONST(143035.41139427255/8.0),
+ REAL_CONST(143061.34180941415/8.0),
+ REAL_CONST(143087.27339960571/8.0),
+ REAL_CONST(143113.20616474075/8.0),
+ REAL_CONST(143139.14010471283/8.0),
+ REAL_CONST(143165.07521941551/8.0),
+ REAL_CONST(143191.01150874238/8.0),
+ REAL_CONST(143216.94897258704/8.0),
+ REAL_CONST(143242.88761084314/8.0),
+ REAL_CONST(143268.82742340435/8.0),
+ REAL_CONST(143294.76841016437/8.0),
+ REAL_CONST(143320.71057101688/8.0),
+ REAL_CONST(143346.65390585564/8.0),
+ REAL_CONST(143372.59841457437/8.0),
+ REAL_CONST(143398.54409706692/8.0),
+ REAL_CONST(143424.49095322701/8.0),
+ REAL_CONST(143450.43898294857/8.0),
+ REAL_CONST(143476.38818612538/8.0),
+ REAL_CONST(143502.33856265133/8.0),
+ REAL_CONST(143528.29011242036/8.0),
+ REAL_CONST(143554.24283532638/8.0),
+ REAL_CONST(143580.19673126334/8.0),
+ REAL_CONST(143606.1518001252/8.0),
+ REAL_CONST(143632.10804180597/8.0),
+ REAL_CONST(143658.06545619969/8.0),
+ REAL_CONST(143684.02404320039/8.0),
+ REAL_CONST(143709.98380270213/8.0),
+ REAL_CONST(143735.944734599/8.0),
+ REAL_CONST(143761.90683878519/8.0),
+ REAL_CONST(143787.87011515474/8.0),
+ REAL_CONST(143813.83456360188/8.0),
+ REAL_CONST(143839.8001840208/8.0),
+ REAL_CONST(143865.76697630569/8.0),
+ REAL_CONST(143891.73494035081/8.0),
+ REAL_CONST(143917.7040760504/8.0),
+ REAL_CONST(143943.67438329876/8.0),
+ REAL_CONST(143969.6458619902/8.0),
+ REAL_CONST(143995.61851201905/8.0),
+ REAL_CONST(144021.59233327967/8.0),
+ REAL_CONST(144047.56732566646/8.0),
+ REAL_CONST(144073.54348907378/8.0),
+ REAL_CONST(144099.52082339607/8.0),
+ REAL_CONST(144125.49932852783/8.0),
+ REAL_CONST(144151.4790043635/8.0),
+ REAL_CONST(144177.45985079758/8.0),
+ REAL_CONST(144203.44186772458/8.0),
+ REAL_CONST(144229.42505503909/8.0),
+ REAL_CONST(144255.40941263564/8.0),
+ REAL_CONST(144281.39494040885/8.0),
+ REAL_CONST(144307.38163825331/8.0),
+ REAL_CONST(144333.36950606373/8.0),
+ REAL_CONST(144359.35854373468/8.0),
+ REAL_CONST(144385.34875116093/8.0),
+ REAL_CONST(144411.34012823718/8.0),
+ REAL_CONST(144437.33267485813/8.0),
+ REAL_CONST(144463.32639091855/8.0),
+ REAL_CONST(144489.32127631325/8.0),
+ REAL_CONST(144515.31733093705/8.0),
+ REAL_CONST(144541.31455468474/8.0),
+ REAL_CONST(144567.3129474512/8.0),
+ REAL_CONST(144593.3125091313/8.0),
+ REAL_CONST(144619.31323961995/8.0),
+ REAL_CONST(144645.31513881206/8.0),
+ REAL_CONST(144671.31820660262/8.0),
+ REAL_CONST(144697.32244288657/8.0),
+ REAL_CONST(144723.32784755889/8.0),
+ REAL_CONST(144749.33442051467/8.0),
+ REAL_CONST(144775.34216164888/8.0),
+ REAL_CONST(144801.35107085665/8.0),
+ REAL_CONST(144827.36114803303/8.0),
+ REAL_CONST(144853.37239307314/8.0),
+ REAL_CONST(144879.38480587213/8.0),
+ REAL_CONST(144905.39838632516/8.0),
+ REAL_CONST(144931.41313432742/8.0),
+ REAL_CONST(144957.4290497741/8.0),
+ REAL_CONST(144983.44613256046/8.0),
+ REAL_CONST(145009.46438258173/8.0),
+ REAL_CONST(145035.48379973322/8.0),
+ REAL_CONST(145061.50438391021/8.0),
+ REAL_CONST(145087.52613500805/8.0),
+ REAL_CONST(145113.54905292206/8.0),
+ REAL_CONST(145139.57313754765/8.0),
+ REAL_CONST(145165.59838878017/8.0),
+ REAL_CONST(145191.62480651509/8.0),
+ REAL_CONST(145217.65239064783/8.0),
+ REAL_CONST(145243.68114107384/8.0),
+ REAL_CONST(145269.71105768863/8.0),
+ REAL_CONST(145295.74214038774/8.0),
+ REAL_CONST(145321.77438906668/8.0),
+ REAL_CONST(145347.80780362099/8.0),
+ REAL_CONST(145373.84238394629/8.0),
+ REAL_CONST(145399.87812993818/8.0),
+ REAL_CONST(145425.91504149229/8.0),
+ REAL_CONST(145451.95311850426/8.0),
+ REAL_CONST(145477.9923608698/8.0),
+ REAL_CONST(145504.03276848458/8.0),
+ REAL_CONST(145530.07434124436/8.0),
+ REAL_CONST(145556.11707904484/8.0),
+ REAL_CONST(145582.16098178181/8.0),
+ REAL_CONST(145608.20604935108/8.0),
+ REAL_CONST(145634.25228164849/8.0),
+ REAL_CONST(145660.29967856981/8.0),
+ REAL_CONST(145686.34824001096/8.0),
+ REAL_CONST(145712.39796586783/8.0),
+ REAL_CONST(145738.4488560363/8.0),
+ REAL_CONST(145764.50091041232/8.0),
+ REAL_CONST(145790.55412889185/8.0),
+ REAL_CONST(145816.60851137087/8.0),
+ REAL_CONST(145842.66405774537/8.0),
+ REAL_CONST(145868.72076791141/8.0),
+ REAL_CONST(145894.77864176501/8.0),
+ REAL_CONST(145920.83767920226/8.0),
+ REAL_CONST(145946.89788011924/8.0),
+ REAL_CONST(145972.95924441208/8.0),
+ REAL_CONST(145999.02177197693/8.0),
+ REAL_CONST(146025.08546270995/8.0),
+ REAL_CONST(146051.15031650732/8.0),
+ REAL_CONST(146077.21633326527/8.0),
+ REAL_CONST(146103.28351288004/8.0),
+ REAL_CONST(146129.35185524789/8.0),
+ REAL_CONST(146155.42136026506/8.0),
+ REAL_CONST(146181.49202782792/8.0),
+ REAL_CONST(146207.56385783272/8.0),
+ REAL_CONST(146233.63685017588/8.0),
+ REAL_CONST(146259.71100475377/8.0),
+ REAL_CONST(146285.78632146274/8.0),
+ REAL_CONST(146311.86280019928/8.0),
+ REAL_CONST(146337.94044085976/8.0),
+ REAL_CONST(146364.01924334071/8.0),
+ REAL_CONST(146390.09920753856/8.0),
+ REAL_CONST(146416.18033334985/8.0),
+ REAL_CONST(146442.26262067116/8.0),
+ REAL_CONST(146468.34606939898/8.0),
+ REAL_CONST(146494.43067942993/8.0),
+ REAL_CONST(146520.51645066062/8.0),
+ REAL_CONST(146546.60338298764/8.0),
+ REAL_CONST(146572.69147630769/8.0),
+ REAL_CONST(146598.78073051744/8.0),
+ REAL_CONST(146624.87114551352/8.0),
+ REAL_CONST(146650.96272119274/8.0),
+ REAL_CONST(146677.05545745179/8.0),
+ REAL_CONST(146703.14935418745/8.0),
+ REAL_CONST(146729.2444112965/8.0),
+ REAL_CONST(146755.34062867577/8.0),
+ REAL_CONST(146781.43800622207/8.0),
+ REAL_CONST(146807.53654383228/8.0),
+ REAL_CONST(146833.63624140329/8.0),
+ REAL_CONST(146859.73709883197/8.0),
+ REAL_CONST(146885.83911601527/8.0),
+ REAL_CONST(146911.94229285014/8.0),
+ REAL_CONST(146938.04662923355/8.0),
+ REAL_CONST(146964.15212506248/8.0),
+ REAL_CONST(146990.25878023397/8.0),
+ REAL_CONST(147016.36659464505/8.0),
+ REAL_CONST(147042.47556819281/8.0),
+ REAL_CONST(147068.58570077427/8.0),
+ REAL_CONST(147094.6969922866/8.0),
+ REAL_CONST(147120.80944262692/8.0),
+ REAL_CONST(147146.92305169237/8.0),
+ REAL_CONST(147173.03781938017/8.0),
+ REAL_CONST(147199.15374558745/8.0),
+ REAL_CONST(147225.27083021149/8.0),
+ REAL_CONST(147251.38907314953/8.0),
+ REAL_CONST(147277.50847429881/8.0),
+ REAL_CONST(147303.62903355664/8.0),
+ REAL_CONST(147329.75075082036/8.0),
+ REAL_CONST(147355.87362598727/8.0),
+ REAL_CONST(147381.99765895473/8.0),
+ REAL_CONST(147408.12284962015/8.0),
+ REAL_CONST(147434.24919788091/8.0),
+ REAL_CONST(147460.37670363448/8.0),
+ REAL_CONST(147486.50536677826/8.0),
+ REAL_CONST(147512.63518720976/8.0),
+ REAL_CONST(147538.76616482646/8.0),
+ REAL_CONST(147564.89829952587/8.0),
+ REAL_CONST(147591.03159120557/8.0),
+ REAL_CONST(147617.16603976308/8.0),
+ REAL_CONST(147643.30164509601/8.0),
+ REAL_CONST(147669.43840710199/8.0),
+ REAL_CONST(147695.57632567859/8.0),
+ REAL_CONST(147721.71540072354/8.0),
+ REAL_CONST(147747.85563213445/8.0),
+ REAL_CONST(147773.99701980909/8.0),
+ REAL_CONST(147800.13956364512/8.0),
+ REAL_CONST(147826.28326354033/8.0),
+ REAL_CONST(147852.42811939248/8.0),
+ REAL_CONST(147878.57413109933/8.0),
+ REAL_CONST(147904.72129855872/8.0),
+ REAL_CONST(147930.86962166851/8.0),
+ REAL_CONST(147957.01910032652/8.0),
+ REAL_CONST(147983.16973443062/8.0),
+ REAL_CONST(148009.32152387875/8.0),
+ REAL_CONST(148035.47446856883/8.0),
+ REAL_CONST(148061.62856839882/8.0),
+ REAL_CONST(148087.78382326665/8.0),
+ REAL_CONST(148113.94023307035/8.0),
+ REAL_CONST(148140.09779770792/8.0),
+ REAL_CONST(148166.25651707739/8.0),
+ REAL_CONST(148192.41639107687/8.0),
+ REAL_CONST(148218.57741960438/8.0),
+ REAL_CONST(148244.73960255808/8.0),
+ REAL_CONST(148270.90293983606/8.0),
+ REAL_CONST(148297.0674313365/8.0),
+ REAL_CONST(148323.23307695755/8.0),
+ REAL_CONST(148349.39987659742/8.0),
+ REAL_CONST(148375.56783015432/8.0),
+ REAL_CONST(148401.73693752653/8.0),
+ REAL_CONST(148427.90719861226/8.0),
+ REAL_CONST(148454.07861330983/8.0),
+ REAL_CONST(148480.25118151752/8.0),
+ REAL_CONST(148506.42490313368/8.0),
+ REAL_CONST(148532.59977805667/8.0),
+ REAL_CONST(148558.77580618486/8.0),
+ REAL_CONST(148584.95298741665/8.0),
+ REAL_CONST(148611.13132165043/8.0),
+ REAL_CONST(148637.31080878471/8.0),
+ REAL_CONST(148663.49144871789/8.0),
+ REAL_CONST(148689.6732413485/8.0),
+ REAL_CONST(148715.85618657502/8.0),
+ REAL_CONST(148742.040284296/8.0),
+ REAL_CONST(148768.22553440998/8.0),
+ REAL_CONST(148794.41193681557/8.0),
+ REAL_CONST(148820.59949141133/8.0),
+ REAL_CONST(148846.78819809589/8.0),
+ REAL_CONST(148872.97805676793/8.0),
+ REAL_CONST(148899.16906732606/8.0),
+ REAL_CONST(148925.36122966901/8.0),
+ REAL_CONST(148951.55454369547/8.0),
+ REAL_CONST(148977.74900930419/8.0),
+ REAL_CONST(149003.9446263939/8.0),
+ REAL_CONST(149030.1413948634/8.0),
+ REAL_CONST(149056.33931461151/8.0),
+ REAL_CONST(149082.53838553699/8.0),
+ REAL_CONST(149108.73860753875/8.0),
+ REAL_CONST(149134.9399805156/8.0),
+ REAL_CONST(149161.14250436646/8.0),
+ REAL_CONST(149187.34617899026/8.0),
+ REAL_CONST(149213.5510042859/8.0),
+ REAL_CONST(149239.75698015234/8.0),
+ REAL_CONST(149265.96410648854/8.0),
+ REAL_CONST(149292.17238319354/8.0),
+ REAL_CONST(149318.38181016635/8.0),
+ REAL_CONST(149344.59238730598/8.0),
+ REAL_CONST(149370.80411451156/8.0),
+ REAL_CONST(149397.01699168212/8.0),
+ REAL_CONST(149423.23101871679/8.0),
+ REAL_CONST(149449.44619551473/8.0),
+ REAL_CONST(149475.66252197503/8.0),
+ REAL_CONST(149501.87999799693/8.0),
+ REAL_CONST(149528.0986234796/8.0),
+ REAL_CONST(149554.31839832227/8.0),
+ REAL_CONST(149580.53932242419/8.0),
+ REAL_CONST(149606.76139568459/8.0),
+ REAL_CONST(149632.98461800278/8.0),
+ REAL_CONST(149659.20898927809/8.0),
+ REAL_CONST(149685.43450940982/8.0),
+ REAL_CONST(149711.66117829733/8.0),
+ REAL_CONST(149737.88899584001/8.0),
+ REAL_CONST(149764.11796193724/8.0),
+ REAL_CONST(149790.34807648844/8.0),
+ REAL_CONST(149816.57933939309/8.0),
+ REAL_CONST(149842.81175055061/8.0),
+ REAL_CONST(149869.04530986046/8.0),
+ REAL_CONST(149895.28001722222/8.0),
+ REAL_CONST(149921.51587253538/8.0),
+ REAL_CONST(149947.75287569952/8.0),
+ REAL_CONST(149973.99102661415/8.0),
+ REAL_CONST(150000.23032517891/8.0),
+ REAL_CONST(150026.47077129342/8.0),
+ REAL_CONST(150052.71236485732/8.0),
+ REAL_CONST(150078.95510577026/8.0),
+ REAL_CONST(150105.1989939319/8.0),
+ REAL_CONST(150131.444029242/8.0),
+ REAL_CONST(150157.69021160025/8.0),
+ REAL_CONST(150183.93754090639/8.0),
+ REAL_CONST(150210.18601706024/8.0),
+ REAL_CONST(150236.43563996154/8.0),
+ REAL_CONST(150262.68640951012/8.0),
+ REAL_CONST(150288.93832560582/8.0),
+ REAL_CONST(150315.19138814852/8.0),
+ REAL_CONST(150341.44559703805/8.0),
+ REAL_CONST(150367.70095217437/8.0),
+ REAL_CONST(150393.95745345735/8.0),
+ REAL_CONST(150420.21510078697/8.0),
+ REAL_CONST(150446.47389406321/8.0),
+ REAL_CONST(150472.73383318601/8.0),
+ REAL_CONST(150498.99491805542/8.0),
+ REAL_CONST(150525.25714857146/8.0),
+ REAL_CONST(150551.52052463419/8.0),
+ REAL_CONST(150577.78504614369/8.0),
+ REAL_CONST(150604.05071300003/8.0),
+ REAL_CONST(150630.31752510337/8.0),
+ REAL_CONST(150656.58548235384/8.0),
+ REAL_CONST(150682.85458465159/8.0),
+ REAL_CONST(150709.1248318968/8.0),
+ REAL_CONST(150735.39622398972/8.0),
+ REAL_CONST(150761.66876083051/8.0),
+ REAL_CONST(150787.9424423195/8.0),
+ REAL_CONST(150814.21726835691/8.0),
+ REAL_CONST(150840.49323884305/8.0),
+ REAL_CONST(150866.77035367821/8.0),
+ REAL_CONST(150893.04861276277/8.0),
+ REAL_CONST(150919.32801599705/8.0),
+ REAL_CONST(150945.60856328148/8.0),
+ REAL_CONST(150971.89025451642/8.0),
+ REAL_CONST(150998.17308960229/8.0),
+ REAL_CONST(151024.45706843957/8.0),
+ REAL_CONST(151050.74219092872/8.0),
+ REAL_CONST(151077.02845697021/8.0),
+ REAL_CONST(151103.31586646455/8.0),
+ REAL_CONST(151129.60441931229/8.0),
+ REAL_CONST(151155.894115414/8.0),
+ REAL_CONST(151182.1849546702/8.0),
+ REAL_CONST(151208.47693698155/8.0),
+ REAL_CONST(151234.77006224863/8.0),
+ REAL_CONST(151261.06433037209/8.0),
+ REAL_CONST(151287.35974125259/8.0),
+ REAL_CONST(151313.65629479082/8.0),
+ REAL_CONST(151339.95399088747/8.0),
+ REAL_CONST(151366.25282944329/8.0),
+ REAL_CONST(151392.55281035902/8.0),
+ REAL_CONST(151418.85393353543/8.0),
+ REAL_CONST(151445.1561988733/8.0),
+ REAL_CONST(151471.45960627345/8.0),
+ REAL_CONST(151497.76415563675/8.0),
+ REAL_CONST(151524.06984686397/8.0),
+ REAL_CONST(151550.37667985607/8.0),
+ REAL_CONST(151576.68465451393/8.0),
+ REAL_CONST(151602.99377073845/8.0),
+ REAL_CONST(151629.30402843058/8.0),
+ REAL_CONST(151655.61542749128/8.0),
+ REAL_CONST(151681.92796782157/8.0),
+ REAL_CONST(151708.24164932242/8.0),
+ REAL_CONST(151734.55647189484/8.0),
+ REAL_CONST(151760.87243543993/8.0),
+ REAL_CONST(151787.18953985872/8.0),
+ REAL_CONST(151813.50778505235/8.0),
+ REAL_CONST(151839.82717092187/8.0),
+ REAL_CONST(151866.14769736846/8.0),
+ REAL_CONST(151892.46936429327/8.0),
+ REAL_CONST(151918.79217159748/8.0),
+ REAL_CONST(151945.11611918229/8.0),
+ REAL_CONST(151971.44120694889/8.0),
+ REAL_CONST(151997.76743479856/8.0),
+ REAL_CONST(152024.09480263255/8.0),
+ REAL_CONST(152050.42331035214/8.0),
+ REAL_CONST(152076.75295785864/8.0),
+ REAL_CONST(152103.08374505339/8.0),
+ REAL_CONST(152129.41567183775/8.0),
+ REAL_CONST(152155.74873811303/8.0),
+ REAL_CONST(152182.08294378067/8.0),
+ REAL_CONST(152208.41828874208/8.0),
+ REAL_CONST(152234.75477289871/8.0),
+ REAL_CONST(152261.09239615197/8.0),
+ REAL_CONST(152287.43115840337/8.0),
+ REAL_CONST(152313.77105955439/8.0),
+ REAL_CONST(152340.11209950657/8.0),
+ REAL_CONST(152366.45427816146/8.0),
+ REAL_CONST(152392.79759542056/8.0),
+ REAL_CONST(152419.14205118554/8.0),
+ REAL_CONST(152445.48764535793/8.0),
+ REAL_CONST(152471.8343778394/8.0),
+ REAL_CONST(152498.18224853161/8.0),
+ REAL_CONST(152524.53125733617/8.0),
+ REAL_CONST(152550.88140415482/8.0),
+ REAL_CONST(152577.23268888926/8.0),
+ REAL_CONST(152603.58511144121/8.0),
+ REAL_CONST(152629.93867171241/8.0),
+ REAL_CONST(152656.29336960468/8.0),
+ REAL_CONST(152682.64920501978/8.0),
+ REAL_CONST(152709.00617785956/8.0),
+ REAL_CONST(152735.36428802583/8.0),
+ REAL_CONST(152761.72353542043/8.0),
+ REAL_CONST(152788.08391994529/8.0),
+ REAL_CONST(152814.44544150229/8.0),
+ REAL_CONST(152840.80809999333/8.0),
+ REAL_CONST(152867.17189532038/8.0),
+ REAL_CONST(152893.53682738543/8.0),
+ REAL_CONST(152919.90289609041/8.0),
+ REAL_CONST(152946.27010133737/8.0),
+ REAL_CONST(152972.63844302832/8.0),
+ REAL_CONST(152999.00792106529/8.0),
+ REAL_CONST(153025.37853535041/8.0),
+ REAL_CONST(153051.7502857857/8.0),
+ REAL_CONST(153078.12317227334/8.0),
+ REAL_CONST(153104.4971947154/8.0),
+ REAL_CONST(153130.8723530141/8.0),
+ REAL_CONST(153157.24864707157/8.0),
+ REAL_CONST(153183.62607679001/8.0),
+ REAL_CONST(153210.00464207167/8.0),
+ REAL_CONST(153236.38434281875/8.0),
+ REAL_CONST(153262.76517893354/8.0),
+ REAL_CONST(153289.14715031831/8.0),
+ REAL_CONST(153315.53025687535/8.0),
+ REAL_CONST(153341.91449850702/8.0),
+ REAL_CONST(153368.2998751156/8.0),
+ REAL_CONST(153394.68638660354/8.0),
+ REAL_CONST(153421.07403287315/8.0),
+ REAL_CONST(153447.46281382689/8.0),
+ REAL_CONST(153473.85272936718/8.0),
+ REAL_CONST(153500.24377939643/8.0),
+ REAL_CONST(153526.63596381716/8.0),
+ REAL_CONST(153553.02928253182/8.0),
+ REAL_CONST(153579.42373544298/8.0),
+ REAL_CONST(153605.81932245308/8.0),
+ REAL_CONST(153632.21604346478/8.0),
+ REAL_CONST(153658.61389838057/8.0),
+ REAL_CONST(153685.0128871031/8.0),
+ REAL_CONST(153711.41300953497/8.0),
+ REAL_CONST(153737.81426557881/8.0),
+ REAL_CONST(153764.21665513728/8.0),
+ REAL_CONST(153790.62017811305/8.0),
+ REAL_CONST(153817.02483440886/8.0),
+ REAL_CONST(153843.43062392739/8.0),
+ REAL_CONST(153869.83754657139/8.0),
+ REAL_CONST(153896.24560224367/8.0),
+ REAL_CONST(153922.65479084692/8.0),
+ REAL_CONST(153949.06511228404/8.0),
+ REAL_CONST(153975.4765664578/8.0),
+ REAL_CONST(154001.88915327107/8.0),
+ REAL_CONST(154028.30287262669/8.0),
+ REAL_CONST(154054.71772442761/8.0),
+ REAL_CONST(154081.13370857667/8.0),
+ REAL_CONST(154107.55082497682/8.0),
+ REAL_CONST(154133.96907353101/8.0),
+ REAL_CONST(154160.38845414223/8.0),
+ REAL_CONST(154186.80896671346/8.0),
+ REAL_CONST(154213.23061114774/8.0),
+ REAL_CONST(154239.65338734805/8.0),
+ REAL_CONST(154266.07729521746/8.0),
+ REAL_CONST(154292.50233465908/8.0),
+ REAL_CONST(154318.92850557598/8.0),
+ REAL_CONST(154345.35580787127/8.0),
+ REAL_CONST(154371.7842414481/8.0),
+ REAL_CONST(154398.21380620965/8.0),
+ REAL_CONST(154424.64450205903/8.0),
+ REAL_CONST(154451.07632889951/8.0),
+ REAL_CONST(154477.50928663427/8.0),
+ REAL_CONST(154503.94337516659/8.0),
+ REAL_CONST(154530.37859439969/8.0),
+ REAL_CONST(154556.81494423689/8.0),
+ REAL_CONST(154583.25242458144/8.0),
+ REAL_CONST(154609.69103533673/8.0),
+ REAL_CONST(154636.13077640603/8.0),
+ REAL_CONST(154662.57164769279/8.0),
+ REAL_CONST(154689.01364910032/8.0),
+ REAL_CONST(154715.45678053208/8.0),
+ REAL_CONST(154741.90104189145/8.0),
+ REAL_CONST(154768.34643308193/8.0),
+ REAL_CONST(154794.79295400696/8.0),
+ REAL_CONST(154821.24060457002/8.0),
+ REAL_CONST(154847.68938467462/8.0),
+ REAL_CONST(154874.13929422433/8.0),
+ REAL_CONST(154900.59033312264/8.0),
+ REAL_CONST(154927.04250127316/8.0),
+ REAL_CONST(154953.49579857948/8.0),
+ REAL_CONST(154979.95022494521/8.0),
+ REAL_CONST(155006.40578027396/8.0),
+ REAL_CONST(155032.86246446942/8.0),
+ REAL_CONST(155059.32027743524/8.0),
+ REAL_CONST(155085.77921907514/8.0),
+ REAL_CONST(155112.2392892928/8.0),
+ REAL_CONST(155138.70048799197/8.0),
+ REAL_CONST(155165.16281507642/8.0),
+ REAL_CONST(155191.62627044989/8.0),
+ REAL_CONST(155218.09085401625/8.0),
+ REAL_CONST(155244.55656567923/8.0),
+ REAL_CONST(155271.02340534274/8.0),
+ REAL_CONST(155297.49137291059/8.0),
+ REAL_CONST(155323.96046828668/8.0),
+ REAL_CONST(155350.4306913749/8.0),
+ REAL_CONST(155376.90204207919/8.0),
+ REAL_CONST(155403.37452030348/8.0),
+ REAL_CONST(155429.84812595171/8.0),
+ REAL_CONST(155456.32285892789/8.0),
+ REAL_CONST(155482.79871913602/8.0),
+ REAL_CONST(155509.27570648011/8.0),
+ REAL_CONST(155535.75382086422/8.0),
+ REAL_CONST(155562.23306219239/8.0),
+ REAL_CONST(155588.71343036872/8.0),
+ REAL_CONST(155615.19492529731/8.0),
+ REAL_CONST(155641.67754688227/8.0),
+ REAL_CONST(155668.16129502779/8.0),
+ REAL_CONST(155694.64616963797/8.0),
+ REAL_CONST(155721.13217061706/8.0),
+ REAL_CONST(155747.61929786921/8.0),
+ REAL_CONST(155774.10755129869/8.0),
+ REAL_CONST(155800.59693080973/8.0),
+ REAL_CONST(155827.08743630661/8.0),
+ REAL_CONST(155853.57906769359/8.0),
+ REAL_CONST(155880.07182487496/8.0),
+ REAL_CONST(155906.56570775513/8.0),
+ REAL_CONST(155933.06071623837/8.0),
+ REAL_CONST(155959.55685022907/8.0),
+ REAL_CONST(155986.05410963166/8.0),
+ REAL_CONST(156012.5524943505/8.0),
+ REAL_CONST(156039.05200429002/8.0),
+ REAL_CONST(156065.55263935472/8.0),
+ REAL_CONST(156092.054399449/8.0),
+ REAL_CONST(156118.5572844774/8.0),
+ REAL_CONST(156145.06129434443/8.0),
+ REAL_CONST(156171.5664289546/8.0),
+ REAL_CONST(156198.07268821247/8.0),
+ REAL_CONST(156224.5800720226/8.0),
+ REAL_CONST(156251.08858028959/8.0),
+ REAL_CONST(156277.59821291809/8.0),
+ REAL_CONST(156304.10896981266/8.0),
+ REAL_CONST(156330.62085087801/8.0),
+ REAL_CONST(156357.1338560188/8.0),
+ REAL_CONST(156383.64798513969/8.0),
+ REAL_CONST(156410.16323814544/8.0),
+ REAL_CONST(156436.67961494075/8.0),
+ REAL_CONST(156463.1971154304/8.0),
+ REAL_CONST(156489.71573951913/8.0),
+ REAL_CONST(156516.23548711176/8.0),
+ REAL_CONST(156542.75635811311/8.0),
+ REAL_CONST(156569.27835242799/8.0),
+ REAL_CONST(156595.80146996127/8.0),
+ REAL_CONST(156622.32571061782/8.0),
+ REAL_CONST(156648.85107430254/8.0),
+ REAL_CONST(156675.37756092031/8.0),
+ REAL_CONST(156701.90517037612/8.0),
+ REAL_CONST(156728.43390257491/8.0),
+ REAL_CONST(156754.96375742162/8.0),
+ REAL_CONST(156781.49473482129/8.0),
+ REAL_CONST(156808.02683467892/8.0),
+ REAL_CONST(156834.5600568995/8.0),
+ REAL_CONST(156861.09440138817/8.0),
+ REAL_CONST(156887.62986804993/8.0),
+ REAL_CONST(156914.16645678994/8.0),
+ REAL_CONST(156940.70416751326/8.0),
+ REAL_CONST(156967.24300012505/8.0),
+ REAL_CONST(156993.78295453047/8.0),
+ REAL_CONST(157020.32403063469/8.0),
+ REAL_CONST(157046.8662283429/8.0),
+ REAL_CONST(157073.40954756032/8.0),
+ REAL_CONST(157099.9539881922/8.0),
+ REAL_CONST(157126.49955014378/8.0),
+ REAL_CONST(157153.04623332032/8.0),
+ REAL_CONST(157179.59403762716/8.0),
+ REAL_CONST(157206.14296296958/8.0),
+ REAL_CONST(157232.69300925292/8.0),
+ REAL_CONST(157259.24417638258/8.0),
+ REAL_CONST(157285.79646426387/8.0),
+ REAL_CONST(157312.34987280221/8.0),
+ REAL_CONST(157338.90440190304/8.0),
+ REAL_CONST(157365.46005147175/8.0),
+ REAL_CONST(157392.01682141385/8.0),
+ REAL_CONST(157418.57471163478/8.0),
+ REAL_CONST(157445.13372204005/8.0),
+ REAL_CONST(157471.69385253513/8.0),
+ REAL_CONST(157498.25510302564/8.0),
+ REAL_CONST(157524.81747341706/8.0),
+ REAL_CONST(157551.38096361503/8.0),
+ REAL_CONST(157577.9455735251/8.0),
+ REAL_CONST(157604.51130305286/8.0),
+ REAL_CONST(157631.07815210402/8.0),
+ REAL_CONST(157657.64612058419/8.0),
+ REAL_CONST(157684.21520839902/8.0),
+ REAL_CONST(157710.78541545427/8.0),
+ REAL_CONST(157737.35674165559/8.0),
+ REAL_CONST(157763.92918690876/8.0),
+ REAL_CONST(157790.50275111952/8.0),
+ REAL_CONST(157817.07743419363/8.0),
+ REAL_CONST(157843.65323603692/8.0),
+ REAL_CONST(157870.23015655516/8.0),
+ REAL_CONST(157896.80819565422/8.0),
+ REAL_CONST(157923.3873532399/8.0),
+ REAL_CONST(157949.96762921812/8.0),
+ REAL_CONST(157976.54902349479/8.0),
+ REAL_CONST(158003.13153597576/8.0),
+ REAL_CONST(158029.71516656701/8.0),
+ REAL_CONST(158056.29991517449/8.0),
+ REAL_CONST(158082.88578170416/8.0),
+ REAL_CONST(158109.47276606198/8.0),
+ REAL_CONST(158136.06086815402/8.0),
+ REAL_CONST(158162.65008788629/8.0),
+ REAL_CONST(158189.24042516484/8.0),
+ REAL_CONST(158215.83187989573/8.0),
+ REAL_CONST(158242.42445198505/8.0),
+ REAL_CONST(158269.01814133892/8.0),
+ REAL_CONST(158295.61294786347/8.0),
+ REAL_CONST(158322.20887146486/8.0),
+ REAL_CONST(158348.80591204923/8.0),
+ REAL_CONST(158375.4040695228/8.0),
+ REAL_CONST(158402.00334379176/8.0),
+ REAL_CONST(158428.60373476235/8.0),
+ REAL_CONST(158455.2052423408/8.0),
+ REAL_CONST(158481.80786643337/8.0),
+ REAL_CONST(158508.41160694641/8.0),
+ REAL_CONST(158535.01646378616/8.0),
+ REAL_CONST(158561.62243685898/8.0),
+ REAL_CONST(158588.2295260712/8.0),
+ REAL_CONST(158614.8377313292/8.0),
+ REAL_CONST(158641.44705253936/8.0),
+ REAL_CONST(158668.05748960807/8.0),
+ REAL_CONST(158694.66904244179/8.0),
+ REAL_CONST(158721.28171094693/8.0),
+ REAL_CONST(158747.89549502998/8.0),
+ REAL_CONST(158774.5103945974/8.0),
+ REAL_CONST(158801.12640955573/8.0),
+ REAL_CONST(158827.74353981143/8.0),
+ REAL_CONST(158854.36178527112/8.0),
+ REAL_CONST(158880.9811458413/8.0),
+ REAL_CONST(158907.60162142856/8.0),
+ REAL_CONST(158934.22321193956/8.0),
+ REAL_CONST(158960.84591728085/8.0),
+ REAL_CONST(158987.46973735912/8.0),
+ REAL_CONST(159014.09467208097/8.0),
+ REAL_CONST(159040.72072135314/8.0),
+ REAL_CONST(159067.3478850823/8.0),
+ REAL_CONST(159093.97616317519/8.0),
+ REAL_CONST(159120.60555553852/8.0),
+ REAL_CONST(159147.23606207906/8.0),
+ REAL_CONST(159173.8676827036/8.0),
+ REAL_CONST(159200.50041731889/8.0),
+ REAL_CONST(159227.13426583182/8.0),
+ REAL_CONST(159253.76922814918/8.0),
+ REAL_CONST(159280.40530417781/8.0),
+ REAL_CONST(159307.04249382461/8.0),
+ REAL_CONST(159333.68079699649/8.0),
+ REAL_CONST(159360.32021360032/8.0),
+ REAL_CONST(159386.96074354305/8.0),
+ REAL_CONST(159413.60238673165/8.0),
+ REAL_CONST(159440.24514307309/8.0),
+ REAL_CONST(159466.88901247433/8.0),
+ REAL_CONST(159493.53399484244/8.0),
+ REAL_CONST(159520.18009008438/8.0),
+ REAL_CONST(159546.82729810724/8.0),
+ REAL_CONST(159573.47561881805/8.0),
+ REAL_CONST(159600.12505212394/8.0),
+ REAL_CONST(159626.77559793202/8.0),
+ REAL_CONST(159653.42725614941/8.0),
+ REAL_CONST(159680.08002668325/8.0),
+ REAL_CONST(159706.73390944069/8.0),
+ REAL_CONST(159733.38890432892/8.0),
+ REAL_CONST(159760.04501125516/8.0),
+ REAL_CONST(159786.70223012666/8.0),
+ REAL_CONST(159813.36056085059/8.0),
+ REAL_CONST(159840.02000333427/8.0),
+ REAL_CONST(159866.68055748497/8.0),
+ REAL_CONST(159893.34222320997/8.0),
+ REAL_CONST(159920.00500041663/8.0),
+ REAL_CONST(159946.66888901225/8.0),
+ REAL_CONST(159973.33388890422/8.0),
+ REAL_CONST(159999.99999999988/8.0),
+ REAL_CONST(160026.66722220668/8.0),
+ REAL_CONST(160053.33555543202/8.0),
+ REAL_CONST(160080.0049995833/8.0),
+ REAL_CONST(160106.67555456801/8.0),
+ REAL_CONST(160133.3472202936/8.0),
+ REAL_CONST(160160.0199966676/8.0),
+ REAL_CONST(160186.6938835975/8.0),
+ REAL_CONST(160213.36888099083/8.0),
+ REAL_CONST(160240.04498875517/8.0),
+ REAL_CONST(160266.72220679806/8.0),
+ REAL_CONST(160293.40053502709/8.0),
+ REAL_CONST(160320.07997334987/8.0),
+ REAL_CONST(160346.76052167406/8.0),
+ REAL_CONST(160373.44217990729/8.0),
+ REAL_CONST(160400.1249479572/8.0),
+ REAL_CONST(160426.80882573154/8.0),
+ REAL_CONST(160453.49381313793/8.0),
+ REAL_CONST(160480.17991008417/8.0),
+ REAL_CONST(160506.86711647795/8.0),
+ REAL_CONST(160533.55543222709/8.0),
+ REAL_CONST(160560.24485723933/8.0),
+ REAL_CONST(160586.93539142248/8.0),
+ REAL_CONST(160613.62703468435/8.0),
+ REAL_CONST(160640.31978693281/8.0),
+ REAL_CONST(160667.01364807569/8.0),
+ REAL_CONST(160693.70861802087/8.0),
+ REAL_CONST(160720.40469667627/8.0),
+ REAL_CONST(160747.1018839498/8.0),
+ REAL_CONST(160773.80017974938/8.0),
+ REAL_CONST(160800.49958398298/8.0),
+ REAL_CONST(160827.20009655855/8.0),
+ REAL_CONST(160853.90171738411/8.0),
+ REAL_CONST(160880.60444636765/8.0),
+ REAL_CONST(160907.30828341722/8.0),
+ REAL_CONST(160934.01322844089/8.0),
+ REAL_CONST(160960.71928134665/8.0),
+ REAL_CONST(160987.42644204266/8.0),
+ REAL_CONST(161014.13471043704/8.0),
+ REAL_CONST(161040.84408643784/8.0),
+ REAL_CONST(161067.55456995327/8.0),
+ REAL_CONST(161094.26616089148/8.0),
+ REAL_CONST(161120.97885916062/8.0),
+ REAL_CONST(161147.69266466892/8.0),
+ REAL_CONST(161174.40757732463/8.0),
+ REAL_CONST(161201.12359703594/8.0),
+ REAL_CONST(161227.84072371112/8.0),
+ REAL_CONST(161254.55895725847/8.0),
+ REAL_CONST(161281.27829758628/8.0),
+ REAL_CONST(161307.99874460287/8.0),
+ REAL_CONST(161334.72029821656/8.0),
+ REAL_CONST(161361.44295833571/8.0),
+ REAL_CONST(161388.1667248687/8.0),
+ REAL_CONST(161414.89159772391/8.0),
+ REAL_CONST(161441.61757680977/8.0),
+ REAL_CONST(161468.34466203468/8.0),
+ REAL_CONST(161495.07285330712/8.0),
+ REAL_CONST(161521.80215053557/8.0),
+ REAL_CONST(161548.53255362847/8.0),
+ REAL_CONST(161575.26406249436/8.0),
+ REAL_CONST(161601.99667704175/8.0),
+ REAL_CONST(161628.7303971792/8.0),
+ REAL_CONST(161655.46522281526/8.0),
+ REAL_CONST(161682.20115385848/8.0),
+ REAL_CONST(161708.93819021754/8.0),
+ REAL_CONST(161735.67633180099/8.0),
+ REAL_CONST(161762.41557851751/8.0),
+ REAL_CONST(161789.15593027571/8.0),
+ REAL_CONST(161815.89738698432/8.0),
+ REAL_CONST(161842.63994855201/8.0),
+ REAL_CONST(161869.38361488748/8.0),
+ REAL_CONST(161896.1283858995/8.0),
+ REAL_CONST(161922.87426149679/8.0),
+ REAL_CONST(161949.62124158812/8.0),
+ REAL_CONST(161976.36932608229/8.0),
+ REAL_CONST(162003.1185148881/8.0),
+ REAL_CONST(162029.8688079144/8.0),
+ REAL_CONST(162056.62020507001/8.0),
+ REAL_CONST(162083.37270626382/8.0),
+ REAL_CONST(162110.12631140469/8.0),
+ REAL_CONST(162136.88102040152/8.0),
+ REAL_CONST(162163.63683316324/8.0),
+ REAL_CONST(162190.39374959879/8.0),
+ REAL_CONST(162217.15176961714/8.0),
+ REAL_CONST(162243.91089312723/8.0),
+ REAL_CONST(162270.67112003808/8.0),
+ REAL_CONST(162297.43245025873/8.0),
+ REAL_CONST(162324.19488369819/8.0),
+ REAL_CONST(162350.9584202655/8.0),
+ REAL_CONST(162377.72305986975/8.0),
+ REAL_CONST(162404.48880242003/8.0),
+ REAL_CONST(162431.25564782543/8.0),
+ REAL_CONST(162458.02359599507/8.0),
+ REAL_CONST(162484.79264683815/8.0),
+ REAL_CONST(162511.56280026378/8.0),
+ REAL_CONST(162538.33405618116/8.0),
+ REAL_CONST(162565.10641449949/8.0),
+ REAL_CONST(162591.87987512801/8.0),
+ REAL_CONST(162618.65443797593/8.0),
+ REAL_CONST(162645.43010295252/8.0),
+ REAL_CONST(162672.20686996708/8.0),
+ REAL_CONST(162698.98473892888/8.0),
+ REAL_CONST(162725.76370974723/8.0),
+ REAL_CONST(162752.54378233149/8.0),
+ REAL_CONST(162779.32495659095/8.0),
+ REAL_CONST(162806.10723243505/8.0),
+ REAL_CONST(162832.89060977317/8.0),
+ REAL_CONST(162859.67508851466/8.0),
+ REAL_CONST(162886.46066856899/8.0),
+ REAL_CONST(162913.24734984562/8.0),
+ REAL_CONST(162940.03513225398/8.0),
+ REAL_CONST(162966.82401570358/8.0),
+ REAL_CONST(162993.6140001039/8.0),
+ REAL_CONST(163020.40508536444/8.0),
+ REAL_CONST(163047.19727139481/8.0),
+ REAL_CONST(163073.99055810447/8.0),
+ REAL_CONST(163100.78494540305/8.0),
+ REAL_CONST(163127.58043320014/8.0),
+ REAL_CONST(163154.37702140535/8.0),
+ REAL_CONST(163181.17470992831/8.0),
+ REAL_CONST(163207.97349867865/8.0),
+ REAL_CONST(163234.77338756606/8.0),
+ REAL_CONST(163261.57437650024/8.0),
+ REAL_CONST(163288.37646539087/8.0),
+ REAL_CONST(163315.17965414765/8.0),
+ REAL_CONST(163341.98394268038/8.0),
+ REAL_CONST(163368.78933089875/8.0),
+ REAL_CONST(163395.59581871261/8.0),
+ REAL_CONST(163422.40340603172/8.0),
+ REAL_CONST(163449.2120927659/8.0),
+ REAL_CONST(163476.02187882498/8.0),
+ REAL_CONST(163502.83276411882/8.0),
+ REAL_CONST(163529.6447485573/8.0),
+ REAL_CONST(163556.45783205028/8.0),
+ REAL_CONST(163583.2720145077/8.0),
+ REAL_CONST(163610.08729583945/8.0),
+ REAL_CONST(163636.90367595552/8.0),
+ REAL_CONST(163663.72115476584/8.0),
+ REAL_CONST(163690.53973218042/8.0),
+ REAL_CONST(163717.35940810922/8.0),
+ REAL_CONST(163744.18018246227/8.0),
+ REAL_CONST(163771.00205514964/8.0),
+ REAL_CONST(163797.82502608138/8.0),
+ REAL_CONST(163824.64909516752/8.0),
+ REAL_CONST(163851.4742623182/8.0),
+ REAL_CONST(163878.3005274435/8.0),
+ REAL_CONST(163905.12789045356/8.0),
+ REAL_CONST(163931.95635125853/8.0),
+ REAL_CONST(163958.78590976857/8.0),
+ REAL_CONST(163985.61656589387/8.0),
+ REAL_CONST(164012.44831954464/8.0),
+ REAL_CONST(164039.28117063109/8.0),
+ REAL_CONST(164066.11511906344/8.0),
+ REAL_CONST(164092.95016475199/8.0),
+ REAL_CONST(164119.78630760699/8.0),
+ REAL_CONST(164146.62354753874/8.0),
+ REAL_CONST(164173.46188445756/8.0),
+ REAL_CONST(164200.30131827376/8.0),
+ REAL_CONST(164227.14184889771/8.0),
+ REAL_CONST(164253.98347623978/8.0),
+ REAL_CONST(164280.82620021031/8.0),
+ REAL_CONST(164307.67002071979/8.0),
+ REAL_CONST(164334.51493767856/8.0),
+ REAL_CONST(164361.3609509971/8.0),
+ REAL_CONST(164388.20806058586/8.0),
+ REAL_CONST(164415.05626635533/8.0),
+ REAL_CONST(164441.905568216/8.0),
+ REAL_CONST(164468.75596607837/8.0),
+ REAL_CONST(164495.607459853/8.0),
+ REAL_CONST(164522.4600494504/8.0),
+ REAL_CONST(164549.31373478117/8.0),
+ REAL_CONST(164576.16851575591/8.0),
+ REAL_CONST(164603.02439228518/8.0),
+ REAL_CONST(164629.88136427966/8.0),
+ REAL_CONST(164656.73943164994/8.0),
+ REAL_CONST(164683.59859430668/8.0),
+ REAL_CONST(164710.45885216061/8.0),
+ REAL_CONST(164737.32020512238/8.0),
+ REAL_CONST(164764.1826531027/8.0),
+ REAL_CONST(164791.04619601235/8.0),
+ REAL_CONST(164817.91083376206/8.0),
+ REAL_CONST(164844.77656626256/8.0),
+ REAL_CONST(164871.64339342469/8.0),
+ REAL_CONST(164898.51131515924/8.0),
+ REAL_CONST(164925.38033137703/8.0),
+ REAL_CONST(164952.25044198887/8.0),
+ REAL_CONST(164979.1216469057/8.0),
+ REAL_CONST(165005.9939460383/8.0),
+ REAL_CONST(165032.86733929763/8.0),
+ REAL_CONST(165059.7418265946/8.0),
+ REAL_CONST(165086.61740784015/8.0),
+ REAL_CONST(165113.4940829452/8.0)
+#endif
};
#endif
--- a/libfaad/mdct.c
+++ b/libfaad/mdct.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: mdct.c,v 1.39 2004/03/19 10:37:55 menno Exp $
+** $Id: mdct.c,v 1.43 2004/09/04 14:56:28 menno Exp $
**/
/*
@@ -53,140 +53,41 @@
#include "cfft.h"
#include "mdct.h"
+#include "mdct_tab.h"
-/* const_tab[]:
- 0: sqrt(2 / N)
- 1: cos(2 * PI / N)
- 2: sin(2 * PI / N)
- 3: cos(2 * PI * (1/8) / N)
- 4: sin(2 * PI * (1/8) / N)
- */
-#ifdef FIXED_POINT
-real_t const_tab[][5] =
-{
- { /* 2048 */
- COEF_CONST(1),
- FRAC_CONST(0.99999529380957619),
- FRAC_CONST(0.0030679567629659761),
- FRAC_CONST(0.99999992646571789),
- FRAC_CONST(0.00038349518757139556)
- }, { /* 1920 */
- COEF_CONST(/* sqrt(1024/960) */ 1.0327955589886444),
- FRAC_CONST(0.99999464540169647),
- FRAC_CONST(0.0032724865065266251),
- FRAC_CONST(0.99999991633432805),
- FRAC_CONST(0.00040906153202803459)
- }, { /* 1024 */
- COEF_CONST(1),
- FRAC_CONST(0.99998117528260111),
- FRAC_CONST(0.0061358846491544753),
- FRAC_CONST(0.99999970586288223),
- FRAC_CONST(0.00076699031874270449)
- }, { /* 960 */
- COEF_CONST(/* sqrt(512/480) */ 1.0327955589886444),
- FRAC_CONST(0.99997858166412923),
- FRAC_CONST(0.0065449379673518581),
- FRAC_CONST(0.99999966533732598),
- FRAC_CONST(0.00081812299560725323)
- }, { /* 256 */
- COEF_CONST(1),
- FRAC_CONST(0.99969881869620425),
- FRAC_CONST(0.024541228522912288),
- FRAC_CONST(0.99999529380957619),
- FRAC_CONST(0.0030679567629659761)
- }, { /* 240 */
- COEF_CONST(/* sqrt(256/240) */ 1.0327955589886444),
- FRAC_CONST(0.99965732497555726),
- FRAC_CONST(0.026176948307873149),
- FRAC_CONST(0.99999464540169647),
- FRAC_CONST(0.0032724865065266251)
- }
-#ifdef SSR_DEC
- ,{ /* 512 */
- COEF_CONST(1),
- FRAC_CONST(0.9999247018391445),
- FRAC_CONST(0.012271538285719925),
- FRAC_CONST(0.99999882345170188),
- FRAC_CONST(0.0015339801862847655)
- }, { /* 64 */
- COEF_CONST(1),
- FRAC_CONST(0.99518472667219693),
- FRAC_CONST(0.098017140329560604),
- FRAC_CONST(0.9999247018391445),
- FRAC_CONST(0.012271538285719925)
- }
-#endif
-};
-#endif
-#ifdef FIXED_POINT
-static uint8_t map_N_to_idx(uint16_t N)
-{
- /* gives an index into const_tab above */
- /* for normal AAC deocding (eg. no scalable profile) only */
- /* index 0 and 4 will be used */
- switch(N)
- {
- case 2048: return 0;
- case 1920: return 1;
- case 1024: return 2;
- case 960: return 3;
- case 256: return 4;
- case 240: return 5;
-#ifdef SSR_DEC
- case 512: return 6;
- case 64: return 7;
-#endif
- }
- return 0;
-}
-#endif
-
mdct_info *faad_mdct_init(uint16_t N)
{
- uint16_t k;
-#ifdef FIXED_POINT
- uint16_t N_idx;
- real_t cangle, sangle, c, s, cold;
-#endif
- real_t scale;
-
mdct_info *mdct = (mdct_info*)faad_malloc(sizeof(mdct_info));
assert(N % 8 == 0);
mdct->N = N;
- mdct->sincos = (complex_t*)faad_malloc(N/4*sizeof(complex_t));
-#ifdef FIXED_POINT
- N_idx = map_N_to_idx(N);
+ /* NOTE: For "small framelengths" in FIXED_POINT the coefficients need to be
+ * scaled by sqrt("(nearest power of 2) > N" / N) */
- scale = const_tab[N_idx][0];
- cangle = const_tab[N_idx][1];
- sangle = const_tab[N_idx][2];
- c = const_tab[N_idx][3];
- s = const_tab[N_idx][4];
-#else
- scale = (real_t)sqrt(2.0 / (real_t)N);
-#endif
-
- /* (co)sine table build using recurrence relations */
- /* this can also be done using static table lookup or */
- /* some form of interpolation */
- for (k = 0; k < N/4; k++)
+ /* RE(mdct->sincos[k]) = scale*(real_t)(cos(2.0*M_PI*(k+1./8.) / (real_t)N));
+ * IM(mdct->sincos[k]) = scale*(real_t)(sin(2.0*M_PI*(k+1./8.) / (real_t)N)); */
+ /* scale is 1 for fixed point, sqrt(N) for floating point */
+ switch (N)
{
-#ifdef FIXED_POINT
- RE(mdct->sincos[k]) = c; //MUL_C_C(c,scale);
- IM(mdct->sincos[k]) = s; //MUL_C_C(s,scale);
-
- cold = c;
- c = MUL_F(c,cangle) - MUL_F(s,sangle);
- s = MUL_F(s,cangle) + MUL_F(cold,sangle);
-#else
- /* no recurrence, just sines */
- RE(mdct->sincos[k]) = scale*(real_t)(cos(2.0*M_PI*(k+1./8.) / (real_t)N));
- IM(mdct->sincos[k]) = scale*(real_t)(sin(2.0*M_PI*(k+1./8.) / (real_t)N));
+ case 2048: mdct->sincos = (complex_t*)mdct_tab_2048; break;
+ case 256: mdct->sincos = (complex_t*)mdct_tab_256; break;
+#ifdef LD_DEC
+ case 1024: mdct->sincos = (complex_t*)mdct_tab_1024; break;
#endif
+#ifdef ALLOW_SMALL_FRAMELENGTH
+ case 1920: mdct->sincos = (complex_t*)mdct_tab_1920; break;
+ case 240: mdct->sincos = (complex_t*)mdct_tab_240; break;
+#ifdef LD_DEC
+ case 960: mdct->sincos = (complex_t*)mdct_tab_960; break;
+#endif
+#endif
+#ifdef SSR_DEC
+ case 512: mdct->sincos = (complex_t*)mdct_tab_512; break;
+ case 64: mdct->sincos = (complex_t*)mdct_tab_64; break;
+#endif
}
/* initialise fft */
@@ -211,8 +112,6 @@
cfftu(mdct->cfft);
- if (mdct->sincos) faad_free(mdct->sincos);
-
faad_free(mdct);
}
}
@@ -222,6 +121,11 @@
uint16_t k;
complex_t x;
+#ifdef ALLOW_SMALL_FRAMELENGTH
+#ifdef FIXED_POINT
+ real_t scale, b_scale = 0;
+#endif
+#endif
ALIGN complex_t Z1[512];
complex_t *sincos = mdct->sincos;
@@ -234,6 +138,19 @@
int64_t count1, count2 = faad_get_ts();
#endif
+#ifdef ALLOW_SMALL_FRAMELENGTH
+#ifdef FIXED_POINT
+ /* detect non-power of 2 */
+ if (N & (N-1))
+ {
+ /* adjust scale for non-power of 2 MDCT */
+ /* 2048/1920 */
+ b_scale = 1;
+ scale = COEF_CONST(1.0666666666666667);
+ }
+#endif
+#endif
+
/* pre-IFFT complex multiplication */
for (k = 0; k < N4; k++)
{
@@ -259,6 +176,17 @@
IM(x) = IM(Z1[k]);
ComplexMult(&IM(Z1[k]), &RE(Z1[k]),
IM(x), RE(x), RE(sincos[k]), IM(sincos[k]));
+
+#ifdef ALLOW_SMALL_FRAMELENGTH
+#ifdef FIXED_POINT
+ /* non-power of 2 MDCT scaling */
+ if (b_scale)
+ {
+ RE(Z1[k]) = MUL_C(RE(Z1[k]), scale);
+ IM(Z1[k]) = MUL_C(IM(Z1[k]), scale);
+ }
+#endif
+#endif
}
/* reordering */
@@ -296,166 +224,6 @@
#endif
}
-#ifdef USE_SSE
-void faad_imdct_sse(mdct_info *mdct, real_t *X_in, real_t *X_out)
-{
- uint16_t k;
-
- ALIGN complex_t Z1[512];
- complex_t *sincos = mdct->sincos;
-
- uint16_t N = mdct->N;
- uint16_t N2 = N >> 1;
- uint16_t N4 = N >> 2;
- uint16_t N8 = N >> 3;
-
-#ifdef PROFILE
- int64_t count1, count2 = faad_get_ts();
-#endif
-
- /* pre-IFFT complex multiplication */
- for (k = 0; k < N4; k+=4)
- {
- __m128 m12, m13, m14, m0, m1, m2, m3, m4, m5, m6, m7, m8, m9, m10, m11;
- __m128 n12, n13, n14, n0, n1, n2, n3, n4, n5, n6, n7, n8, n9, n10, n11;
- n12 = _mm_load_ps(&X_in[N2 - 2*k - 8]);
- m12 = _mm_load_ps(&X_in[N2 - 2*k - 4]);
- m13 = _mm_load_ps(&X_in[2*k]);
- n13 = _mm_load_ps(&X_in[2*k + 4]);
- m1 = _mm_load_ps(&RE(sincos[k]));
- n1 = _mm_load_ps(&RE(sincos[k+2]));
-
- m0 = _mm_shuffle_ps(m12, m13, _MM_SHUFFLE(2,0,1,3));
- m2 = _mm_shuffle_ps(m1, m1, _MM_SHUFFLE(2,3,0,1));
- m14 = _mm_shuffle_ps(m0, m0, _MM_SHUFFLE(3,1,2,0));
- n0 = _mm_shuffle_ps(n12, n13, _MM_SHUFFLE(2,0,1,3));
- n2 = _mm_shuffle_ps(n1, n1, _MM_SHUFFLE(2,3,0,1));
- n14 = _mm_shuffle_ps(n0, n0, _MM_SHUFFLE(3,1,2,0));
-
- m3 = _mm_mul_ps(m14, m1);
- n3 = _mm_mul_ps(n14, n1);
- m4 = _mm_mul_ps(m14, m2);
- n4 = _mm_mul_ps(n14, n2);
-
- m5 = _mm_shuffle_ps(m3, m4, _MM_SHUFFLE(2,0,2,0));
- n5 = _mm_shuffle_ps(n3, n4, _MM_SHUFFLE(2,0,2,0));
- m6 = _mm_shuffle_ps(m3, m4, _MM_SHUFFLE(3,1,3,1));
- n6 = _mm_shuffle_ps(n3, n4, _MM_SHUFFLE(3,1,3,1));
-
- m7 = _mm_add_ps(m5, m6);
- n7 = _mm_add_ps(n5, n6);
- m8 = _mm_sub_ps(m5, m6);
- n8 = _mm_sub_ps(n5, n6);
-
- m9 = _mm_shuffle_ps(m7, m7, _MM_SHUFFLE(3,2,3,2));
- n9 = _mm_shuffle_ps(n7, n7, _MM_SHUFFLE(3,2,3,2));
- m10 = _mm_shuffle_ps(m8, m8, _MM_SHUFFLE(1,0,1,0));
- n10 = _mm_shuffle_ps(n8, n8, _MM_SHUFFLE(1,0,1,0));
-
- m11 = _mm_unpacklo_ps(m10, m9);
- n11 = _mm_unpacklo_ps(n10, n9);
-
- _mm_store_ps(&RE(Z1[k]), m11);
- _mm_store_ps(&RE(Z1[k+2]), n11);
- }
-
-#ifdef PROFILE
- count1 = faad_get_ts();
-#endif
-
- /* complex IFFT, any non-scaling FFT can be used here */
- cfftb_sse(mdct->cfft, Z1);
-
-#ifdef PROFILE
- count1 = faad_get_ts() - count1;
-#endif
-
- /* post-IFFT complex multiplication */
- for (k = 0; k < N4; k+=4)
- {
- __m128 m0, m1, m2, m3, m4, m5, m6, m7, m8, m9, m10, m11;
- __m128 n0, n1, n2, n3, n4, n5, n6, n7, n8, n9, n10, n11;
- m0 = _mm_load_ps(&RE(Z1[k]));
- n0 = _mm_load_ps(&RE(Z1[k+2]));
- m1 = _mm_load_ps(&RE(sincos[k]));
- n1 = _mm_load_ps(&RE(sincos[k+2]));
-
- m2 = _mm_shuffle_ps(m1, m1, _MM_SHUFFLE(2,3,0,1));
- n2 = _mm_shuffle_ps(n1, n1, _MM_SHUFFLE(2,3,0,1));
-
- m3 = _mm_mul_ps(m0, m1);
- n3 = _mm_mul_ps(n0, n1);
- m4 = _mm_mul_ps(m0, m2);
- n4 = _mm_mul_ps(n0, n2);
-
- m5 = _mm_shuffle_ps(m3, m4, _MM_SHUFFLE(2,0,2,0));
- n5 = _mm_shuffle_ps(n3, n4, _MM_SHUFFLE(2,0,2,0));
- m6 = _mm_shuffle_ps(m3, m4, _MM_SHUFFLE(3,1,3,1));
- n6 = _mm_shuffle_ps(n3, n4, _MM_SHUFFLE(3,1,3,1));
-
- m7 = _mm_add_ps(m5, m6);
- n7 = _mm_add_ps(n5, n6);
- m8 = _mm_sub_ps(m5, m6);
- n8 = _mm_sub_ps(n5, n6);
-
- m9 = _mm_shuffle_ps(m7, m7, _MM_SHUFFLE(3,2,3,2));
- n9 = _mm_shuffle_ps(n7, n7, _MM_SHUFFLE(3,2,3,2));
- m10 = _mm_shuffle_ps(m8, m8, _MM_SHUFFLE(1,0,1,0));
- n10 = _mm_shuffle_ps(n8, n8, _MM_SHUFFLE(1,0,1,0));
-
- m11 = _mm_unpacklo_ps(m10, m9);
- n11 = _mm_unpacklo_ps(n10, n9);
-
- _mm_store_ps(&RE(Z1[k]), m11);
- _mm_store_ps(&RE(Z1[k+2]), n11);
- }
-
- /* reordering */
- for (k = 0; k < N8; k+=2)
- {
- __m128 m0, m1, m2, m3, m4, m5, m6, m7, m8, m9, m10, m11, m13;
- __m128 n4, n5, n6, n7, n8, n9;
- __m128 neg1 = _mm_set_ps(-1.0, 1.0, -1.0, 1.0);
- __m128 neg2 = _mm_set_ps(-1.0, -1.0, -1.0, -1.0);
-
- m0 = _mm_load_ps(&RE(Z1[k]));
- m1 = _mm_load_ps(&RE(Z1[N8 - 2 - k]));
- m2 = _mm_load_ps(&RE(Z1[N8 + k]));
- m3 = _mm_load_ps(&RE(Z1[N4 - 2 - k]));
-
- m10 = _mm_mul_ps(m0, neg1);
- m11 = _mm_mul_ps(m1, neg2);
- m13 = _mm_mul_ps(m3, neg1);
-
- m5 = _mm_shuffle_ps(m2, m2, _MM_SHUFFLE(3,1,2,0));
- n4 = _mm_shuffle_ps(m10, m10, _MM_SHUFFLE(3,1,2,0));
- m4 = _mm_shuffle_ps(m11, m11, _MM_SHUFFLE(3,1,2,0));
- n5 = _mm_shuffle_ps(m13, m13, _MM_SHUFFLE(3,1,2,0));
-
- m6 = _mm_shuffle_ps(m4, m5, _MM_SHUFFLE(3,2,1,0));
- n6 = _mm_shuffle_ps(n4, n5, _MM_SHUFFLE(3,2,1,0));
- m7 = _mm_shuffle_ps(m5, m4, _MM_SHUFFLE(3,2,1,0));
- n7 = _mm_shuffle_ps(n5, n4, _MM_SHUFFLE(3,2,1,0));
-
- m8 = _mm_shuffle_ps(m6, m6, _MM_SHUFFLE(0,3,1,2));
- n8 = _mm_shuffle_ps(n6, n6, _MM_SHUFFLE(2,1,3,0));
- m9 = _mm_shuffle_ps(m7, m7, _MM_SHUFFLE(2,1,3,0));
- n9 = _mm_shuffle_ps(n7, n7, _MM_SHUFFLE(0,3,1,2));
-
- _mm_store_ps(&X_out[2*k], m8);
- _mm_store_ps(&X_out[N4 + 2*k], n8);
- _mm_store_ps(&X_out[N2 + 2*k], m9);
- _mm_store_ps(&X_out[N2 + N4 + 2*k], n9);
- }
-
-#ifdef PROFILE
- count2 = faad_get_ts() - count2;
- mdct->fft_cycles += count1;
- mdct->cycles += (count2 - count1);
-#endif
-}
-#endif
-
#ifdef LTP_DEC
void faad_mdct(mdct_info *mdct, real_t *X_in, real_t *X_out)
{
@@ -474,6 +242,18 @@
real_t scale = REAL_CONST(N);
#else
real_t scale = REAL_CONST(4.0/N);
+#endif
+
+#ifdef ALLOW_SMALL_FRAMELENGTH
+#ifdef FIXED_POINT
+ /* detect non-power of 2 */
+ if (N & (N-1))
+ {
+ /* adjust scale for non-power of 2 MDCT */
+ /* *= sqrt(2048/1920) */
+ scale = MUL_C(scale, COEF_CONST(1.0327955589886444));
+ }
+#endif
#endif
/* pre-FFT complex multiplication */
--- a/libfaad/ps_dec.c
+++ b/libfaad/ps_dec.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: ps_dec.c,v 1.6 2004/04/12 18:17:42 menno Exp $
+** $Id: ps_dec.c,v 1.7 2004/05/17 10:18:03 menno Exp $
**/
#include "common.h"
@@ -36,7 +36,7 @@
/* constants */
#define NEGATE_IPD_MASK (0x1000)
#define DECAY_SLOPE FRAC_CONST(0.05)
-#define COEF_SQRT2 COEF_CONST(sqrt(2.0))
+#define COEF_SQRT2 COEF_CONST(1.4142135623731)
/* tables */
/* filters are mirrored in coef 6, second half left out */
@@ -217,6 +217,30 @@
return hyb;
}
+static void hybrid_free(hyb_info *hyb)
+{
+ uint8_t i;
+
+ if (hyb->work)
+ faad_free(hyb->work);
+
+ for (i = 0; i < 5; i++)
+ {
+ if (hyb->buffer[i])
+ faad_free(hyb->buffer[i]);
+ }
+ if (hyb->buffer)
+ faad_free(hyb->buffer);
+
+ for (i = 0; i < hyb->frame_len; i++)
+ {
+ if (hyb->temp[i])
+ faad_free(hyb->temp[i]);
+ }
+ if (hyb->temp)
+ faad_free(hyb->temp);
+}
+
/* real filter, size 2 */
static void channel_filter2(hyb_info *hyb, uint8_t frame_len, const real_t *filter,
qmf_t *buffer, qmf_t **X_hybrid)
@@ -430,14 +454,14 @@
{
if (n == 0)
{
- input_re1[0] = filter[6] * QMF_RE(buffer[6+i]);
- input_re2[0] = filter[6] * QMF_IM(buffer[6+i]);
+ input_re1[0] = MUL_F(QMF_RE(buffer[6+i]), filter[6]);
+ input_re2[0] = MUL_F(QMF_IM(buffer[6+i]), filter[6]);
} else {
- input_re1[6-n] = filter[n] * (QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i]));
- input_re2[6-n] = filter[n] * (QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i]));
+ input_re1[6-n] = MUL_F((QMF_RE(buffer[n+i]) + QMF_RE(buffer[12-n+i])), filter[n]);
+ input_re2[6-n] = MUL_F((QMF_IM(buffer[n+i]) + QMF_IM(buffer[12-n+i])), filter[n]);
}
- input_im2[n] = filter[n] * (QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i]));
- input_im1[n] = filter[n] * (QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i]));
+ input_im2[n] = MUL_F((QMF_RE(buffer[n+i]) - QMF_RE(buffer[12-n+i])), filter[n]);
+ input_im1[n] = MUL_F((QMF_IM(buffer[n+i]) - QMF_IM(buffer[12-n+i])), filter[n]);
}
DCT3_6_unscaled(out_re1, input_re1);
@@ -1703,6 +1727,9 @@
void ps_free(ps_info *ps)
{
+ /* free hybrid filterbank structures */
+ hybrid_free(ps->hyb);
+
faad_free(ps);
}
--- a/libfaad/sbr_dec.c
+++ b/libfaad/sbr_dec.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_dec.c,v 1.35 2004/04/12 18:17:42 menno Exp $
+** $Id: sbr_dec.c,v 1.36 2004/05/17 10:18:03 menno Exp $
**/
@@ -41,9 +41,12 @@
#include "sbr_hfgen.h"
#include "sbr_hfadj.h"
+
/* static function declarations */
static uint8_t sbr_save_prev_data(sbr_info *sbr, uint8_t ch);
+static void sbr_save_matrix(sbr_info *sbr, uint8_t ch);
+
sbr_info *sbrDecodeInit(uint16_t framelength, uint8_t id_aac,
uint32_t sample_rate, uint8_t downSampledSBR
#ifdef DRM
@@ -119,8 +122,6 @@
memset(sbr->Xsbr[0], 0, (sbr->numTimeSlotsRate+sbr->tHFGen)*64 * sizeof(qmf_t));
memset(sbr->Xsbr[1], 0, (sbr->numTimeSlotsRate+sbr->tHFGen)*64 * sizeof(qmf_t));
- memset(sbr->Xcodec[0], 0, (sbr->numTimeSlotsRate+sbr->tHFGen)*32 * sizeof(qmf_t));
- memset(sbr->Xcodec[1], 0, (sbr->numTimeSlotsRate+sbr->tHFGen)*32 * sizeof(qmf_t));
} else {
/* mono */
uint8_t j;
@@ -135,7 +136,6 @@
}
memset(sbr->Xsbr[0], 0, (sbr->numTimeSlotsRate+sbr->tHFGen)*64 * sizeof(qmf_t));
- memset(sbr->Xcodec[0], 0, (sbr->numTimeSlotsRate+sbr->tHFGen)*32 * sizeof(qmf_t));
}
return sbr;
@@ -193,13 +193,13 @@
return 19;
sbr->f_prev[ch] = sbr->f[ch][sbr->L_E[ch] - 1];
- for (i = 0; i < 64; i++)
+ for (i = 0; i < MAX_M; i++)
{
sbr->E_prev[ch][i] = sbr->E[ch][i][sbr->L_E[ch] - 1];
sbr->Q_prev[ch][i] = sbr->Q[ch][i][sbr->L_Q[ch] - 1];
}
- for (i = 0; i < 64; i++)
+ for (i = 0; i < MAX_M; i++)
{
sbr->bs_add_harmonic_prev[ch][i] = sbr->bs_add_harmonic[ch][i];
}
@@ -213,11 +213,25 @@
return 0;
}
+static void sbr_save_matrix(sbr_info *sbr, uint8_t ch)
+{
+ uint8_t i;
+
+ for (i = 0; i < sbr->tHFGen; i++)
+ {
+ memmove(sbr->Xsbr[ch][i], sbr->Xsbr[ch][i+sbr->numTimeSlotsRate], 64 * sizeof(qmf_t));
+ }
+ for (i = sbr->tHFGen; i < MAX_NTSRHFG; i++)
+ {
+ memset(sbr->Xsbr[ch][i], 0, 64 * sizeof(qmf_t));
+ }
+}
+
static void sbr_process_channel(sbr_info *sbr, real_t *channel_buf, qmf_t X[MAX_NTSR][64],
uint8_t ch, uint8_t dont_process,
const uint8_t downSampledSBR)
{
- int16_t i, k, l;
+ int16_t k, l;
#ifdef SBR_LOW_POWER
ALIGN real_t deg[64];
@@ -236,9 +250,9 @@
/* subband analysis */
if (dont_process)
- sbr_qmf_analysis_32(sbr, sbr->qmfa[ch], channel_buf, sbr->Xcodec[ch], sbr->tHFGen, 32);
+ sbr_qmf_analysis_32(sbr, sbr->qmfa[ch], channel_buf, sbr->Xsbr[ch], sbr->tHFGen, 32);
else
- sbr_qmf_analysis_32(sbr, sbr->qmfa[ch], channel_buf, sbr->Xcodec[ch], sbr->tHFGen, sbr->kx);
+ sbr_qmf_analysis_32(sbr, sbr->qmfa[ch], channel_buf, sbr->Xsbr[ch], sbr->tHFGen, sbr->kx);
if (!dont_process)
{
@@ -245,7 +259,7 @@
#if 1
/* insert high frequencies here */
/* hf generation using patching */
- hf_generation(sbr, sbr->Xcodec[ch], sbr->Xsbr[ch]
+ hf_generation(sbr, sbr->Xsbr[ch], sbr->Xsbr[ch]
#ifdef SBR_LOW_POWER
,deg
#endif
@@ -278,9 +292,9 @@
{
for (k = 0; k < 32; k++)
{
- QMF_RE(X[l][k]) = QMF_RE(sbr->Xcodec[ch][l + sbr->tHFAdj][k]);
+ QMF_RE(X[l][k]) = QMF_RE(sbr->Xsbr[ch][l + sbr->tHFAdj][k]);
#ifndef SBR_LOW_POWER
- QMF_IM(X[l][k]) = QMF_IM(sbr->Xcodec[ch][l + sbr->tHFAdj][k]);
+ QMF_IM(X[l][k]) = QMF_IM(sbr->Xsbr[ch][l + sbr->tHFAdj][k]);
#endif
}
for (k = 32; k < 64; k++)
@@ -310,8 +324,8 @@
#ifndef SBR_LOW_POWER
for (k = 0; k < kx_band + bsco_band; k++)
{
- QMF_RE(X[l][k]) = QMF_RE(sbr->Xcodec[ch][l + sbr->tHFAdj][k]);
- QMF_IM(X[l][k]) = QMF_IM(sbr->Xcodec[ch][l + sbr->tHFAdj][k]);
+ QMF_RE(X[l][k]) = QMF_RE(sbr->Xsbr[ch][l + sbr->tHFAdj][k]);
+ QMF_IM(X[l][k]) = QMF_IM(sbr->Xsbr[ch][l + sbr->tHFAdj][k]);
}
for (k = kx_band + bsco_band; k < kx_band + M_band; k++)
{
@@ -326,7 +340,7 @@
#else
for (k = 0; k < kx_band + bsco_band; k++)
{
- QMF_RE(X[l][k]) = QMF_RE(sbr->Xcodec[ch][l + sbr->tHFAdj][k]);
+ QMF_RE(X[l][k]) = QMF_RE(sbr->Xsbr[ch][l + sbr->tHFAdj][k]);
}
for (k = kx_band + bsco_band; k < min(kx_band + M_band, 63); k++)
{
@@ -341,12 +355,6 @@
#endif
}
}
-
- for (i = 0; i < sbr->tHFGen; i++)
- {
- memmove(sbr->Xcodec[ch][i], sbr->Xcodec[ch][i+sbr->numTimeSlotsRate], 32 * sizeof(qmf_t));
- memmove(sbr->Xsbr[ch][i], sbr->Xsbr[ch][i+sbr->numTimeSlotsRate], 64 * sizeof(qmf_t));
- }
}
uint8_t sbrDecodeCoupleFrame(sbr_info *sbr, real_t *left_chan, real_t *right_chan,
@@ -409,6 +417,9 @@
if (ret) return ret;
}
+ sbr_save_matrix(sbr, 0);
+ sbr_save_matrix(sbr, 1);
+
sbr->frame++;
return 0;
@@ -463,6 +474,8 @@
if (ret) return ret;
}
+ sbr_save_matrix(sbr, 0);
+
sbr->frame++;
return 0;
@@ -514,8 +527,8 @@
{
for (k = 0; k < 5; k++)
{
- QMF_RE(X_left[l][k]) = QMF_RE(sbr->Xcodec[0][sbr->tHFAdj+l][k]);
- QMF_IM(X_left[l][k]) = QMF_IM(sbr->Xcodec[0][sbr->tHFAdj+l][k]);
+ QMF_RE(X_left[l][k]) = QMF_RE(sbr->Xsbr[0][sbr->tHFAdj+l][k]);
+ QMF_IM(X_left[l][k]) = QMF_IM(sbr->Xsbr[0][sbr->tHFAdj+l][k]);
}
}
@@ -551,6 +564,8 @@
ret = sbr_save_prev_data(sbr, 0);
if (ret) return ret;
}
+
+ sbr_save_matrix(sbr, 0);
sbr->frame++;
--- a/libfaad/sbr_dec.h
+++ b/libfaad/sbr_dec.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_dec.h,v 1.31 2004/04/12 18:17:42 menno Exp $
+** $Id: sbr_dec.h,v 1.32 2004/05/17 10:18:03 menno Exp $
**/
#ifndef __SBR_DEC_H__
@@ -113,11 +113,15 @@
int16_t E[2][64][MAX_L_E];
int16_t E_prev[2][64];
+#ifndef FIXED_POINT
real_t E_orig[2][64][MAX_L_E];
+#endif
real_t E_curr[2][64][MAX_L_E];
int32_t Q[2][64][2];
+#ifndef FIXED_POINT
real_t Q_div[2][64][2];
real_t Q_div2[2][64][2];
+#endif
int32_t Q_prev[2][64];
int8_t l_A[2];
@@ -162,7 +166,6 @@
qmfs_info *qmfs[2];
qmf_t Xsbr[2][MAX_NTSRHFG][64];
- qmf_t Xcodec[2][MAX_NTSRHFG][32];
#ifdef DRM
uint8_t Is_DRM_SBR;
--- a/libfaad/sbr_e_nf.c
+++ b/libfaad/sbr_e_nf.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_e_nf.c,v 1.14 2004/03/19 10:37:55 menno Exp $
+** $Id: sbr_e_nf.c,v 1.17 2004/09/04 14:56:28 menno Exp $
**/
#include "common.h"
@@ -139,6 +139,8 @@
}
}
+#ifndef FIXED_POINT
+
/* table for Q_div values when no coupling */
static const real_t Q_div_tab[31] = {
FRAC_CONST(0.0153846), FRAC_CONST(0.030303),
@@ -376,7 +378,6 @@
}
}
-#ifndef FIXED_POINT
static const real_t E_deq_tab[64] = {
64.0f, 128.0f, 256.0f, 512.0f, 1024.0f, 2048.0f, 4096.0f, 8192.0f,
16384.0f, 32768.0f, 65536.0f, 131072.0f, 262144.0f, 524288.0f, 1.04858E+006f, 2.09715E+006f,
@@ -387,14 +388,6 @@
1.80144E+016f, 3.60288E+016f, 7.20576E+016f, 1.44115E+017f, 2.8823E+017f, 5.76461E+017f, 1.15292E+018f, 2.30584E+018f,
4.61169E+018f, 9.22337E+018f, 1.84467E+019f, 3.68935E+019f, 7.3787E+019f, 1.47574E+020f, 2.95148E+020f, 5.90296E+020f
};
-#else
-static const int32_t E_deq_tab[31] = {
- 1, 2, 4, 8, 16, 32, 64, 128,
- 256, 512, 1024, 2048, 4096, 8192, 16384, 32768,
- 65536, 131072, 262144, 524288, 1048576, 2097152, 4194304, 8388608,
- 16777216, 33554432, 67108864, 134217728, 268435456, 536870912, 1073741824
-};
-#endif
void envelope_noise_dequantisation(sbr_info *sbr, uint8_t ch)
{
@@ -411,16 +404,10 @@
/* +6 for the *64 and -10 for the /32 in the synthesis QMF (fixed)
* since this is a energy value: (x/32)^2 = (x^2)/1024
*/
- /* exp = (sbr->E[ch][k][l] >> amp) + 6 - 10; */
+ /* exp = (sbr->E[ch][k][l] >> amp) + 6; */
exp = (sbr->E[ch][k][l] >> amp);
- if ((exp < 0) ||
-#ifndef FIXED_POINT
- (exp >= 64)
-#else
- (exp >= 32)
-#endif
- )
+ if ((exp < 0) || (exp >= 64))
{
sbr->E_orig[ch][k][l] = 0;
} else {
@@ -474,8 +461,7 @@
{
for (k = 0; k < sbr->n[sbr->f[0][l]]; k++)
{
- /* +6: * 64 ; +1: * 2 ; -10: /1024 QMF (fixed) */
- /* exp0 = (sbr->E[0][k][l] >> amp0) + 7 - 10 */
+ /* +6: * 64 ; +1: * 2 ; */
exp0 = (sbr->E[0][k][l] >> amp0) + 1;
/* UN_MAP removed: (x / 4096) same as (x >> 12) */
@@ -485,12 +471,7 @@
/* exp1 = (sbr->E[1][k][l] >> amp1) - 12; */
exp1 = (sbr->E[1][k][l] >> amp1);
- if ((exp0 < 0) ||
-#ifndef FIXED_POINT
- (exp0 >= 64) ||
-#else
- (exp0 >= 32) ||
-#endif
+ if ((exp0 < 0) || (exp0 >= 64) ||
(exp1 < 0) || (exp1 > 24))
{
sbr->E_orig[1][k][l] = 0;
@@ -520,5 +501,7 @@
}
}
}
+
+#endif
#endif
--- a/libfaad/sbr_e_nf.h
+++ b/libfaad/sbr_e_nf.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_e_nf.h,v 1.11 2004/03/10 19:45:41 menno Exp $
+** $Id: sbr_e_nf.h,v 1.14 2004/09/04 14:56:28 menno Exp $
**/
#ifndef __SBR_E_NF_H__
@@ -35,8 +35,10 @@
void extract_envelope_data(sbr_info *sbr, uint8_t ch);
void extract_noise_floor_data(sbr_info *sbr, uint8_t ch);
+#ifndef FIXED_POINT
void envelope_noise_dequantisation(sbr_info *sbr, uint8_t ch);
void unmap_envelope_noise(sbr_info *sbr);
+#endif
#ifdef __cplusplus
}
--- a/libfaad/sbr_fbt.c
+++ b/libfaad/sbr_fbt.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_fbt.c,v 1.13 2004/04/12 18:17:42 menno Exp $
+** $Id: sbr_fbt.c,v 1.16 2004/09/04 14:56:28 menno Exp $
**/
/* Calculate frequency band tables */
@@ -355,6 +355,9 @@
uint8_t temp1[] = { 6, 5, 4 };
real_t q, qk;
int32_t A_1;
+#ifdef FIXED_POINT
+ real_t rk2, rk0;
+#endif
/* mft only defined for k2 > k0 */
if (k2 <= k0)
@@ -366,7 +369,9 @@
bands = temp1[bs_freq_scale-1];
#ifdef FIXED_POINT
- if (REAL_CONST(k2) > MUL_R(REAL_CONST(k0),REAL_CONST(2.2449)))
+ rk0 = (real_t)k0 << REAL_BITS;
+ rk2 = (real_t)k2 << REAL_BITS;
+ if (rk2 > MUL_C(rk0, COEF_CONST(2.2449)))
#else
if ((float)k2/(float)k0 > 2.2449)
#endif
@@ -384,10 +389,12 @@
return 1;
q = find_initial_power(nrBand0, k0, k1);
- qk = REAL_CONST(k0);
#ifdef FIXED_POINT
- A_1 = (int32_t)((qk + REAL_CONST(0.5)) >> REAL_BITS);
+ qk = (real_t)k0 << REAL_BITS;
+ //A_1 = (int32_t)((qk + REAL_CONST(0.5)) >> REAL_BITS);
+ A_1 = k0;
#else
+ qk = REAL_CONST(k0);
A_1 = (int32_t)(qk + .5);
#endif
for (k = 0; k <= nrBand0; k++)
@@ -428,10 +435,12 @@
nrBand1 = min(nrBand1, 63);
q = find_initial_power(nrBand1, k1, k2);
- qk = REAL_CONST(k1);
#ifdef FIXED_POINT
- A_1 = (int32_t)((qk + REAL_CONST(0.5)) >> REAL_BITS);
+ qk = (real_t)k1 << REAL_BITS;
+ //A_1 = (int32_t)((qk + REAL_CONST(0.5)) >> REAL_BITS);
+ A_1 = k1;
#else
+ qk = REAL_CONST(k1);
A_1 = (int32_t)(qk + .5);
#endif
for (k = 0; k <= nrBand1 - 1; k++)
@@ -677,7 +686,7 @@
nOctaves = REAL_CONST(log((float)limTable[k]/(float)limTable[k-1])/log(2.0));
#else
#ifdef FIXED_POINT
- nOctaves = DIV_R(REAL_CONST(limTable[k]),REAL_CONST(limTable[k-1]));
+ nOctaves = DIV_R((limTable[k]<<REAL_BITS),REAL_CONST(limTable[k-1]));
#else
nOctaves = (real_t)limTable[k]/(real_t)limTable[k-1];
#endif
--- a/libfaad/sbr_hfadj.c
+++ b/libfaad/sbr_hfadj.c
@@ -1,19 +1,19 @@
/*
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
** Copyright (C) 2003-2004 M. Bakker, Ahead Software AG, http://www.nero.com
-**
+**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
-**
+**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
-**
+**
** You should have received a copy of the GNU General Public License
-** along with this program; if not, write to the Free Software
+** along with this program; if not, write to the Free Software
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
**
** Any non-GPL usage of this software or parts of this software is strictly
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_hfadj.c,v 1.14 2004/04/12 18:17:42 menno Exp $
+** $Id: sbr_hfadj.c,v 1.15 2004/05/17 10:18:03 menno Exp $
**/
/* High Frequency adjustment */
@@ -39,8 +39,6 @@
/* static function declarations */
-static void map_noise_data(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch);
-static void map_sinusoids(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch);
static void estimate_current_envelope(sbr_info *sbr, sbr_hfadj_info *adj,
qmf_t Xsbr[MAX_NTSRHFG][64], uint8_t ch);
static void calculate_gain(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch);
@@ -59,55 +57,6 @@
{
ALIGN sbr_hfadj_info adj = {{{0}}};
- map_noise_data(sbr, &adj, ch);
- map_sinusoids(sbr, &adj, ch);
-
- estimate_current_envelope(sbr, &adj, Xsbr, ch);
-
- calculate_gain(sbr, &adj, ch);
-
-#ifdef SBR_LOW_POWER
- calc_gain_groups(sbr, &adj, deg, ch);
- aliasing_reduction(sbr, &adj, deg, ch);
-#endif
-
- hf_assembly(sbr, &adj, Xsbr, ch);
-}
-
-static void map_noise_data(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch)
-{
- uint8_t l, i;
- uint8_t m;
-
- for (l = 0; l < sbr->L_E[ch]; l++)
- {
- uint8_t k;
-
- /* select the noise time band k that completely holds the current envelope time band l */
- for (k = 0; k < 2; k++)
- {
- if ((sbr->t_E[ch][l] >= sbr->t_Q[ch][k]) && (sbr->t_E[ch][l+1] <= sbr->t_Q[ch][k+1]))
- {
- for (i = 0; i < sbr->N_Q; i++)
- {
- for (m = sbr->f_table_noise[i]; m < sbr->f_table_noise[i+1]; m++)
- {
- adj->Q_div_mapped[l][m - sbr->kx] =
- sbr->Q_div[ch][i][k];
-
- adj->Q_div2_mapped[l][m - sbr->kx] =
- sbr->Q_div2[ch][i][k];
- }
- }
- }
- }
- }
-}
-
-static void map_sinusoids(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch)
-{
- uint8_t l, i, m, k, k1, k2, delta_S, l_i, u_i;
-
if (sbr->bs_frame_class[ch] == FIXFIX)
{
sbr->l_A[ch] = -1;
@@ -123,72 +72,16 @@
sbr->l_A[ch] = sbr->L_E[ch] + 1 - sbr->bs_pointer[ch];
}
- for (l = 0; l < 5; l++)
- {
- for (i = 0; i < 64; i++)
- {
- adj->S_index_mapped[l][i] = 0;
- adj->S_mapped[l][i] = 0;
- }
- }
+ estimate_current_envelope(sbr, &adj, Xsbr, ch);
- for (l = 0; l < sbr->L_E[ch]; l++)
- {
- for (i = 0; i < sbr->N_high; i++)
- {
- if ((l >= sbr->l_A[ch]) ||
- (sbr->bs_add_harmonic_prev[ch][i] && sbr->bs_add_harmonic_flag_prev[ch]))
- {
- /* find the middle subband of the frequency band */
- m = (sbr->f_table_res[HI_RES][i+1] + sbr->f_table_res[HI_RES][i]) >> 1;
- adj->S_index_mapped[l][m - sbr->kx] = /*delta_step **/ sbr->bs_add_harmonic[ch][i];
- }
- }
- }
+ calculate_gain(sbr, &adj, ch);
- for (l = 0; l < sbr->L_E[ch]; l++)
- {
- for (i = 0; i < sbr->N_high; i++)
- {
- if (sbr->f[ch][l] == HI_RES)
- {
- k1 = i;
- k2 = i + 1;
- } else {
- for (k1 = 0; k1 < sbr->N_low; k1++)
- {
- if ((sbr->f_table_res[HI_RES][i] >= sbr->f_table_res[LO_RES][k1]) &&
- (sbr->f_table_res[HI_RES][i+1] <= sbr->f_table_res[LO_RES][k1+1]))
- {
- break;
- }
- }
- for (k2 = 0; k2 < sbr->N_low; k2++)
- {
- if ((sbr->f_table_res[HI_RES][i+1] >= sbr->f_table_res[LO_RES][k2]) &&
- (sbr->f_table_res[HI_RES][i+2] <= sbr->f_table_res[LO_RES][k2+1]))
- {
- break;
- }
- }
- }
+#ifdef SBR_LOW_POWER
+ calc_gain_groups(sbr, &adj, deg, ch);
+ aliasing_reduction(sbr, &adj, deg, ch);
+#endif
- l_i = sbr->f_table_res[sbr->f[ch][l]][k1];
- u_i = sbr->f_table_res[sbr->f[ch][l]][k2];
-
- delta_S = 0;
- for (k = l_i; k < u_i; k++)
- {
- if (adj->S_index_mapped[l][k - sbr->kx] == 1)
- delta_S = 1;
- }
-
- for (m = l_i; m < u_i; m++)
- {
- adj->S_mapped[l][m - sbr->kx] = delta_S;
- }
- }
- }
+ hf_assembly(sbr, &adj, Xsbr, ch);
}
static uint8_t get_S_mapped(sbr_info *sbr, uint8_t ch, uint8_t l, uint8_t current_band)
@@ -335,182 +228,244 @@
}
#ifdef FIXED_POINT
-#define step(shift) \
- if ((0x40000000l >> shift) + root <= value) \
- { \
- value -= (0x40000000l >> shift) + root; \
- root = (root >> 1) | (0x40000000l >> shift); \
- } else { \
- root = root >> 1; \
- }
+#define EPS (1) /* smallest number available in fixed point */
+#else
+#define EPS (1e-12)
+#endif
-/* fixed point square root approximation */
-real_t sbr_sqrt(real_t value)
-{
- real_t root = 0;
- step( 0); step( 2); step( 4); step( 6);
- step( 8); step(10); step(12); step(14);
- step(16); step(18); step(20); step(22);
- step(24); step(26); step(28); step(30);
- if (root < value)
- ++root;
+#ifdef FIXED_POINT
- root <<= (REAL_BITS/2);
+/* log2 values of [0..63] */
+static const real_t log2_int_tab[] = {
+ LOG2_MIN_INF, REAL_CONST(0.000000000000000), REAL_CONST(1.000000000000000), REAL_CONST(1.584962500721156),
+ REAL_CONST(2.000000000000000), REAL_CONST(2.321928094887362), REAL_CONST(2.584962500721156), REAL_CONST(2.807354922057604),
+ REAL_CONST(3.000000000000000), REAL_CONST(3.169925001442313), REAL_CONST(3.321928094887363), REAL_CONST(3.459431618637297),
+ REAL_CONST(3.584962500721156), REAL_CONST(3.700439718141092), REAL_CONST(3.807354922057604), REAL_CONST(3.906890595608519),
+ REAL_CONST(4.000000000000000), REAL_CONST(4.087462841250339), REAL_CONST(4.169925001442312), REAL_CONST(4.247927513443585),
+ REAL_CONST(4.321928094887362), REAL_CONST(4.392317422778761), REAL_CONST(4.459431618637297), REAL_CONST(4.523561956057013),
+ REAL_CONST(4.584962500721156), REAL_CONST(4.643856189774724), REAL_CONST(4.700439718141093), REAL_CONST(4.754887502163468),
+ REAL_CONST(4.807354922057604), REAL_CONST(4.857980995127572), REAL_CONST(4.906890595608519), REAL_CONST(4.954196310386875),
+ REAL_CONST(5.000000000000000), REAL_CONST(5.044394119358453), REAL_CONST(5.087462841250340), REAL_CONST(5.129283016944966),
+ REAL_CONST(5.169925001442312), REAL_CONST(5.209453365628949), REAL_CONST(5.247927513443585), REAL_CONST(5.285402218862248),
+ REAL_CONST(5.321928094887363), REAL_CONST(5.357552004618084), REAL_CONST(5.392317422778761), REAL_CONST(5.426264754702098),
+ REAL_CONST(5.459431618637297), REAL_CONST(5.491853096329675), REAL_CONST(5.523561956057013), REAL_CONST(5.554588851677637),
+ REAL_CONST(5.584962500721156), REAL_CONST(5.614709844115208), REAL_CONST(5.643856189774724), REAL_CONST(5.672425341971495),
+ REAL_CONST(5.700439718141093), REAL_CONST(5.727920454563200), REAL_CONST(5.754887502163469), REAL_CONST(5.781359713524660),
+ REAL_CONST(5.807354922057605), REAL_CONST(5.832890014164742), REAL_CONST(5.857980995127572), REAL_CONST(5.882643049361842),
+ REAL_CONST(5.906890595608518), REAL_CONST(5.930737337562887), REAL_CONST(5.954196310386876), REAL_CONST(5.977279923499916)
+};
- return root;
-}
+static const real_t pan_log2_tab[] = {
+ REAL_CONST(1.000000000000000), REAL_CONST(0.584962500721156), REAL_CONST(0.321928094887362), REAL_CONST(0.169925001442312), REAL_CONST(0.087462841250339),
+ REAL_CONST(0.044394119358453), REAL_CONST(0.022367813028455), REAL_CONST(0.011227255423254), REAL_CONST(0.005624549193878), REAL_CONST(0.002815015607054),
+ REAL_CONST(0.001408194392808), REAL_CONST(0.000704269011247), REAL_CONST(0.000352177480301), REAL_CONST(0.000176099486443), REAL_CONST(0.000088052430122),
+ REAL_CONST(0.000044026886827), REAL_CONST(0.000022013611360), REAL_CONST(0.000011006847667)
+};
-real_t SBR_SQRT_Q2(real_t value)
+static real_t find_log2_E(sbr_info *sbr, uint8_t k, uint8_t l, uint8_t ch)
{
- real_t root = 0;
+ /* check for coupled energy/noise data */
+ if (sbr->bs_coupling == 1)
+ {
+ uint8_t amp0 = (sbr->amp_res[0]) ? 0 : 1;
+ uint8_t amp1 = (sbr->amp_res[1]) ? 0 : 1;
+ real_t tmp = (7 << REAL_BITS) + (sbr->E[0][k][l] << (REAL_BITS-amp0));
+ real_t pan;
- step( 0); step( 2); step( 4); step( 6);
- step( 8); step(10); step(12); step(14);
- step(16); step(18); step(20); step(22);
- step(24); step(26); step(28); step(30);
+ /* E[1] should always be even so shifting is OK */
+ uint8_t E = sbr->E[1][k][l] >> amp1;
- if (root < value)
- ++root;
+ if (ch == 0)
+ {
+ if (E > 12)
+ {
+ /* negative */
+ pan = pan_log2_tab[-12 + E];
+ } else {
+ /* positive */
+ pan = pan_log2_tab[12 - E] + ((12 - E)<<REAL_BITS);
+ }
+ } else {
+ if (E < 12)
+ {
+ /* negative */
+ pan = pan_log2_tab[-E + 12];
+ } else {
+ /* positive */
+ pan = pan_log2_tab[E - 12] + ((E - 12)<<REAL_BITS);
+ }
+ }
- root <<= (Q2_BITS/2);
+ /* tmp / pan in log2 */
+ return tmp - pan;
+ } else {
+ uint8_t amp = (sbr->amp_res[ch]) ? 0 : 1;
- return root;
+ return (6 << REAL_BITS) + (sbr->E[ch][k][l] << (REAL_BITS-amp));
+ }
}
-real_t sbr_sqrt_int(real_t value)
+static real_t find_log2_Q(sbr_info *sbr, uint8_t k, uint8_t l, uint8_t ch)
{
- real_t root = 0;
+ /* check for coupled energy/noise data */
+ if (sbr->bs_coupling == 1)
+ {
+ real_t tmp = (7 << REAL_BITS) - (sbr->Q[0][k][l] << REAL_BITS);
+ real_t pan;
- step( 0); step( 2); step( 4); step( 6);
- step( 8); step(10); step(12); step(14);
- step(16); step(18); step(20); step(22);
- step(24); step(26); step(28); step(30);
+ uint8_t Q = sbr->Q[1][k][l];
- if (root < value)
- ++root;
-
- return root;
-}
-#define SBR_SQRT_FIX(A) sbr_sqrt(A)
-#define SBR_SQRT_INT(A) sbr_sqrt_int(A)
-#endif
-
-#ifdef FIXED_POINT
-#define EPS (1) /* smallest number available in fixed point */
-#else
-#define EPS (1e-12)
-#endif
-
-#ifdef FIXED_POINT
-#define ONE (REAL_CONST(1)>>10)
-#else
-#define ONE (1)
-#endif
-
-
-#ifdef FIXED_POINT
-
-uint8_t G_max_is_biggest(real_t G, real_t G_max,
- uint8_t G_is_frac, uint8_t G_max_is_frac)
-{
- if ((G_is_frac == 1 && G_max_is_frac == 1) || ((G_is_frac == 0 && G_max_is_frac == 0)))
- {
- if (G_max > G)
- return 1;
- } else if (G_is_frac) {
- if (G_max > REAL_CONST(1))
+ if (ch == 0)
{
- return 1;
- } else if (G_max > (G << (FRAC_BITS-REAL_BITS))) {
- return 1;
- }
- } else if (G_max_is_frac) {
- if (G > REAL_CONST(1))
- {
- return 0;
- } else if (G > (G_max >> (FRAC_BITS-REAL_BITS))) {
- return 0;
+ if (Q > 12)
+ {
+ /* negative */
+ pan = pan_log2_tab[-12 + Q];
+ } else {
+ /* positive */
+ pan = pan_log2_tab[12 - Q] + ((12 - Q)<<REAL_BITS);
+ }
} else {
- return 1;
+ if (Q < 12)
+ {
+ /* negative */
+ pan = pan_log2_tab[-Q + 12];
+ } else {
+ /* positive */
+ pan = pan_log2_tab[Q - 12] + ((Q - 12)<<REAL_BITS);
+ }
}
- }
- return 0;
+ /* tmp / pan in log2 */
+ return tmp - pan;
+ } else {
+ return (6 << REAL_BITS) - (sbr->Q[ch][k][l] << REAL_BITS);
+ }
}
-/* frac */
-real_t div_G_max_G(real_t G, real_t G_max,
- uint8_t G_is_frac, uint8_t G_max_is_frac, uint8_t *is_real)
-{
- *is_real = 0;
+static const real_t log_Qplus1_pan[31][13] = {
+ { REAL_CONST(0.044383447617292), REAL_CONST(0.169768601655960), REAL_CONST(0.583090126514435), REAL_CONST(1.570089221000671), REAL_CONST(3.092446088790894), REAL_CONST(4.733354568481445), REAL_CONST(6.022367954254150), REAL_CONST(6.692092418670654), REAL_CONST(6.924463272094727), REAL_CONST(6.989034175872803), REAL_CONST(7.005646705627441), REAL_CONST(7.009829998016357), REAL_CONST(7.010877609252930) },
+ { REAL_CONST(0.022362394258380), REAL_CONST(0.087379962205887), REAL_CONST(0.320804953575134), REAL_CONST(0.988859415054321), REAL_CONST(2.252387046813965), REAL_CONST(3.786596298217773), REAL_CONST(5.044394016265869), REAL_CONST(5.705977916717529), REAL_CONST(5.936291694641113), REAL_CONST(6.000346660614014), REAL_CONST(6.016829967498779), REAL_CONST(6.020981311798096), REAL_CONST(6.022020816802979) },
+ { REAL_CONST(0.011224525049329), REAL_CONST(0.044351425021887), REAL_CONST(0.169301137328148), REAL_CONST(0.577544987201691), REAL_CONST(1.527246952056885), REAL_CONST(2.887525320053101), REAL_CONST(4.087462902069092), REAL_CONST(4.733354568481445), REAL_CONST(4.959661006927490), REAL_CONST(5.022709369659424), REAL_CONST(5.038940429687500), REAL_CONST(5.043028831481934), REAL_CONST(5.044052600860596) },
+ { REAL_CONST(0.005623178556561), REAL_CONST(0.022346137091517), REAL_CONST(0.087132595479488), REAL_CONST(0.317482173442841), REAL_CONST(0.956931233406067), REAL_CONST(2.070389270782471), REAL_CONST(3.169924974441528), REAL_CONST(3.786596298217773), REAL_CONST(4.005294322967529), REAL_CONST(4.066420555114746), REAL_CONST(4.082170009613037), REAL_CONST(4.086137294769287), REAL_CONST(4.087131500244141) },
+ { REAL_CONST(0.002814328996465), REAL_CONST(0.011216334067285), REAL_CONST(0.044224001467228), REAL_CONST(0.167456731200218), REAL_CONST(0.556393325328827), REAL_CONST(1.378511548042297), REAL_CONST(2.321928024291992), REAL_CONST(2.887525320053101), REAL_CONST(3.092446088790894), REAL_CONST(3.150059700012207), REAL_CONST(3.164926528930664), REAL_CONST(3.168673276901245), REAL_CONST(3.169611930847168) },
+ { REAL_CONST(0.001407850766554), REAL_CONST(0.005619067233056), REAL_CONST(0.022281449288130), REAL_CONST(0.086156636476517), REAL_CONST(0.304854571819305), REAL_CONST(0.847996890544891), REAL_CONST(1.584962487220764), REAL_CONST(2.070389270782471), REAL_CONST(2.252387046813965), REAL_CONST(2.304061651229858), REAL_CONST(2.317430257797241), REAL_CONST(2.320801734924316), REAL_CONST(2.321646213531494) },
+ { REAL_CONST(0.000704097095877), REAL_CONST(0.002812269143760), REAL_CONST(0.011183738708496), REAL_CONST(0.043721374124289), REAL_CONST(0.160464659333229), REAL_CONST(0.485426813364029), REAL_CONST(1.000000000000000), REAL_CONST(1.378511548042297), REAL_CONST(1.527246952056885), REAL_CONST(1.570089221000671), REAL_CONST(1.581215262413025), REAL_CONST(1.584023833274841), REAL_CONST(1.584727644920349) },
+ { REAL_CONST(0.000352177477907), REAL_CONST(0.001406819908880), REAL_CONST(0.005602621007711), REAL_CONST(0.022026389837265), REAL_CONST(0.082462236285210), REAL_CONST(0.263034462928772), REAL_CONST(0.584962487220764), REAL_CONST(0.847996890544891), REAL_CONST(0.956931233406067), REAL_CONST(0.988859415054321), REAL_CONST(0.997190535068512), REAL_CONST(0.999296069145203), REAL_CONST(0.999823868274689) },
+ { REAL_CONST(0.000176099492819), REAL_CONST(0.000703581434209), REAL_CONST(0.002804030198604), REAL_CONST(0.011055230163038), REAL_CONST(0.041820213198662), REAL_CONST(0.137503549456596), REAL_CONST(0.321928083896637), REAL_CONST(0.485426813364029), REAL_CONST(0.556393325328827), REAL_CONST(0.577544987201691), REAL_CONST(0.583090126514435), REAL_CONST(0.584493279457092), REAL_CONST(0.584845066070557) },
+ { REAL_CONST(0.000088052431238), REAL_CONST(0.000351833587047), REAL_CONST(0.001402696361765), REAL_CONST(0.005538204684854), REAL_CONST(0.021061634644866), REAL_CONST(0.070389263331890), REAL_CONST(0.169925004243851), REAL_CONST(0.263034462928772), REAL_CONST(0.304854571819305), REAL_CONST(0.317482173442841), REAL_CONST(0.320804953575134), REAL_CONST(0.321646571159363), REAL_CONST(0.321857661008835) },
+ { REAL_CONST(0.000044026888645), REAL_CONST(0.000175927518285), REAL_CONST(0.000701518612914), REAL_CONST(0.002771759871393), REAL_CONST(0.010569252073765), REAL_CONST(0.035623874515295), REAL_CONST(0.087462842464447), REAL_CONST(0.137503549456596), REAL_CONST(0.160464659333229), REAL_CONST(0.167456731200218), REAL_CONST(0.169301137328148), REAL_CONST(0.169768601655960), REAL_CONST(0.169885858893394) },
+ { REAL_CONST(0.000022013611670), REAL_CONST(0.000088052431238), REAL_CONST(0.000350801943569), REAL_CONST(0.001386545598507), REAL_CONST(0.005294219125062), REAL_CONST(0.017921976745129), REAL_CONST(0.044394120573997), REAL_CONST(0.070389263331890), REAL_CONST(0.082462236285210), REAL_CONST(0.086156636476517), REAL_CONST(0.087132595479488), REAL_CONST(0.087379962205887), REAL_CONST(0.087442122399807) },
+ { REAL_CONST(0.000011006847672), REAL_CONST(0.000044026888645), REAL_CONST(0.000175411638338), REAL_CONST(0.000693439331371), REAL_CONST(0.002649537986144), REAL_CONST(0.008988817222416), REAL_CONST(0.022367812693119), REAL_CONST(0.035623874515295), REAL_CONST(0.041820213198662), REAL_CONST(0.043721374124289), REAL_CONST(0.044224001467228), REAL_CONST(0.044351425021887), REAL_CONST(0.044383447617292) },
+ { REAL_CONST(0.000005503434295), REAL_CONST(0.000022013611670), REAL_CONST(0.000087708482170), REAL_CONST(0.000346675369656), REAL_CONST(0.001325377263129), REAL_CONST(0.004501323681325), REAL_CONST(0.011227255687118), REAL_CONST(0.017921976745129), REAL_CONST(0.021061634644866), REAL_CONST(0.022026389837265), REAL_CONST(0.022281449288130), REAL_CONST(0.022346137091517), REAL_CONST(0.022362394258380) },
+ { REAL_CONST(0.000002751719876), REAL_CONST(0.000011006847672), REAL_CONST(0.000043854910473), REAL_CONST(0.000173348103999), REAL_CONST(0.000662840844598), REAL_CONST(0.002252417383716), REAL_CONST(0.005624548997730), REAL_CONST(0.008988817222416), REAL_CONST(0.010569252073765), REAL_CONST(0.011055230163038), REAL_CONST(0.011183738708496), REAL_CONST(0.011216334067285), REAL_CONST(0.011224525049329) },
+ { REAL_CONST(0.000001375860506), REAL_CONST(0.000005503434295), REAL_CONST(0.000022013611670), REAL_CONST(0.000086676649516), REAL_CONST(0.000331544462824), REAL_CONST(0.001126734190620), REAL_CONST(0.002815015614033), REAL_CONST(0.004501323681325), REAL_CONST(0.005294219125062), REAL_CONST(0.005538204684854), REAL_CONST(0.005602621007711), REAL_CONST(0.005619067233056), REAL_CONST(0.005623178556561) },
+ { REAL_CONST(0.000000687930424), REAL_CONST(0.000002751719876), REAL_CONST(0.000011006847672), REAL_CONST(0.000043338975956), REAL_CONST(0.000165781748365), REAL_CONST(0.000563477107789), REAL_CONST(0.001408194424585), REAL_CONST(0.002252417383716), REAL_CONST(0.002649537986144), REAL_CONST(0.002771759871393), REAL_CONST(0.002804030198604), REAL_CONST(0.002812269143760), REAL_CONST(0.002814328996465) },
+ { REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000005503434295), REAL_CONST(0.000021669651687), REAL_CONST(0.000082893253420), REAL_CONST(0.000281680084299), REAL_CONST(0.000704268983100), REAL_CONST(0.001126734190620), REAL_CONST(0.001325377263129), REAL_CONST(0.001386545598507), REAL_CONST(0.001402696361765), REAL_CONST(0.001406819908880), REAL_CONST(0.001407850766554) },
+ { REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002751719876), REAL_CONST(0.000010834866771), REAL_CONST(0.000041447223339), REAL_CONST(0.000140846910654), REAL_CONST(0.000352177477907), REAL_CONST(0.000563477107789), REAL_CONST(0.000662840844598), REAL_CONST(0.000693439331371), REAL_CONST(0.000701518612914), REAL_CONST(0.000703581434209), REAL_CONST(0.000704097095877) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000005503434295), REAL_CONST(0.000020637769921), REAL_CONST(0.000070511166996), REAL_CONST(0.000176099492819), REAL_CONST(0.000281680084299), REAL_CONST(0.000331544462824), REAL_CONST(0.000346675369656), REAL_CONST(0.000350801943569), REAL_CONST(0.000351833587047), REAL_CONST(0.000352177477907) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002751719876), REAL_CONST(0.000010318922250), REAL_CONST(0.000035256012779), REAL_CONST(0.000088052431238), REAL_CONST(0.000140846910654), REAL_CONST(0.000165781748365), REAL_CONST(0.000173348103999), REAL_CONST(0.000175411638338), REAL_CONST(0.000175927518285), REAL_CONST(0.000176099492819) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000005159470220), REAL_CONST(0.000017542124624), REAL_CONST(0.000044026888645), REAL_CONST(0.000070511166996), REAL_CONST(0.000082893253420), REAL_CONST(0.000086676649516), REAL_CONST(0.000087708482170), REAL_CONST(0.000088052431238), REAL_CONST(0.000088052431238) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002579737384), REAL_CONST(0.000008771088687), REAL_CONST(0.000022013611670), REAL_CONST(0.000035256012779), REAL_CONST(0.000041447223339), REAL_CONST(0.000043338975956), REAL_CONST(0.000043854910473), REAL_CONST(0.000044026888645), REAL_CONST(0.000044026888645) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000004471542070), REAL_CONST(0.000011006847672), REAL_CONST(0.000017542124624), REAL_CONST(0.000020637769921), REAL_CONST(0.000021669651687), REAL_CONST(0.000022013611670), REAL_CONST(0.000022013611670), REAL_CONST(0.000022013611670) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002235772627), REAL_CONST(0.000005503434295), REAL_CONST(0.000008771088687), REAL_CONST(0.000010318922250), REAL_CONST(0.000010834866771), REAL_CONST(0.000011006847672), REAL_CONST(0.000011006847672), REAL_CONST(0.000011006847672) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001031895522), REAL_CONST(0.000002751719876), REAL_CONST(0.000004471542070), REAL_CONST(0.000005159470220), REAL_CONST(0.000005503434295), REAL_CONST(0.000005503434295), REAL_CONST(0.000005503434295), REAL_CONST(0.000005503434295) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000515947875), REAL_CONST(0.000001375860506), REAL_CONST(0.000002235772627), REAL_CONST(0.000002579737384), REAL_CONST(0.000002751719876), REAL_CONST(0.000002751719876), REAL_CONST(0.000002751719876), REAL_CONST(0.000002751719876) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000000687930424), REAL_CONST(0.000001031895522), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000343965269), REAL_CONST(0.000000515947875), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634) }
+};
- if (G_is_frac == 1)
+static const real_t log_Qplus1[31] = {
+ REAL_CONST(6.022367813028454), REAL_CONST(5.044394119358453), REAL_CONST(4.087462841250339),
+ REAL_CONST(3.169925001442313), REAL_CONST(2.321928094887362), REAL_CONST(1.584962500721156),
+ REAL_CONST(1.000000000000000), REAL_CONST(0.584962500721156), REAL_CONST(0.321928094887362),
+ REAL_CONST(0.169925001442312), REAL_CONST(0.087462841250339), REAL_CONST(0.044394119358453),
+ REAL_CONST(0.022367813028455), REAL_CONST(0.011227255423254), REAL_CONST(0.005624549193878),
+ REAL_CONST(0.002815015607054), REAL_CONST(0.001408194392808), REAL_CONST(0.000704269011247),
+ REAL_CONST(0.000352177480301), REAL_CONST(0.000176099486443), REAL_CONST(0.000088052430122),
+ REAL_CONST(0.000044026886827), REAL_CONST(0.000022013611360), REAL_CONST(0.000011006847667),
+ REAL_CONST(0.000005503434331), REAL_CONST(0.000002751719790), REAL_CONST(0.000001375860551),
+ REAL_CONST(0.000000687930439), REAL_CONST(0.000000343965261), REAL_CONST(0.000000171982641),
+ REAL_CONST(0.000000000000000)
+};
+
+static real_t find_log2_Qplus1(sbr_info *sbr, uint8_t k, uint8_t l, uint8_t ch)
+{
+ /* check for coupled energy/noise data */
+ if (sbr->bs_coupling == 1)
{
- /* divide by a frac */
- return ((int64_t)G_max << FRAC_BITS)/G;
- } else {
- /* divide by a real but answer is a frac */
- if (G_max_is_frac == 1)
+ if ((sbr->Q[0][k][l] >= 0) && (sbr->Q[0][k][l] <= 30) &&
+ (sbr->Q[1][k][l] >= 0) && (sbr->Q[1][k][l] <= 24))
{
- /* G_max is already a frac */
- if (G < REAL_CONST(1))
+ if (ch == 0)
{
- *is_real = 1;
- return ((int64_t)G_max >> 3)/G;
+ return log_Qplus1_pan[sbr->Q[0][k][l]][sbr->Q[1][k][l] >> 1];
} else {
- return ((int64_t)G_max << REAL_BITS)/G;
+ return log_Qplus1_pan[sbr->Q[0][k][l]][12 - (sbr->Q[1][k][l] >> 1)];
}
} else {
- /* turn G_max into a frac before dividing */
- return ((int64_t)G_max << REAL_BITS+(FRAC_BITS-REAL_BITS))/G;
+ return 0;
}
+ } else {
+ if (sbr->Q[ch][k][l] >= 0 && sbr->Q[ch][k][l] <= 30)
+ {
+ return log_Qplus1[sbr->Q[ch][k][l]];
+ } else {
+ return 0;
+ }
}
}
static void calculate_gain(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch)
{
- uint8_t m, l, k, i;
+ /* log2 values of limiter gains */
+ static real_t limGain[] = {
+ REAL_CONST(-1.0), REAL_CONST(0.0), REAL_CONST(1.0), REAL_CONST(33.219)
+ };
+ uint8_t m, l, k;
+ uint8_t current_t_noise_band = 0;
+ uint8_t S_mapped;
+
ALIGN real_t Q_M_lim[MAX_M];
ALIGN real_t G_lim[MAX_M];
ALIGN real_t G_boost;
ALIGN real_t S_M[MAX_M];
- ALIGN uint8_t table_map_res_to_m[MAX_M];
- ALIGN uint8_t G_is_frac[MAX_M];
- ALIGN uint8_t Q_M_is_real[MAX_M];
for (l = 0; l < sbr->L_E[ch]; l++)
{
+ uint8_t current_f_noise_band = 0;
+ uint8_t current_res_band = 0;
+ uint8_t current_res_band2 = 0;
+ uint8_t current_hi_res_band = 0;
+
real_t delta = (l == sbr->l_A[ch] || l == sbr->prevEnvIsShort[ch]) ? 0 : 1;
- for (i = 0; i < sbr->n[sbr->f[ch][l]]; i++)
+ S_mapped = get_S_mapped(sbr, ch, l, current_res_band2);
+
+ if (sbr->t_E[ch][l+1] > sbr->t_Q[ch][current_t_noise_band+1])
{
- for (m = sbr->f_table_res[sbr->f[ch][l]][i]; m < sbr->f_table_res[sbr->f[ch][l]][i+1]; m++)
- {
- table_map_res_to_m[m - sbr->kx] = i;
- }
+ current_t_noise_band++;
}
for (k = 0; k < sbr->N_L[sbr->bs_limiter_bands]; k++)
{
+ real_t Q_M = 0;
real_t G_max;
real_t den = 0;
- real_t den_int = 0;
- real_t den_real = 0;
real_t acc1 = 0;
- real_t acc1_coef = 0;
- real_t acct = 0;
real_t acc2 = 0;
- uint8_t G_max_infinite = 0;
- uint8_t min_pow = 0;
- uint8_t G_max_is_frac = 0;
+ uint8_t current_res_band_size = 0;
+ uint8_t Q_M_size = 0;
uint8_t ml1, ml2;
-
+ /* bounds of current limiter bands */
ml1 = sbr->f_table_lim[sbr->bs_limiter_bands][k];
ml2 = sbr->f_table_lim[sbr->bs_limiter_bands][k+1];
@@ -518,246 +473,658 @@
/* calculate the accumulated E_orig and E_curr over the limiter band */
for (m = ml1; m < ml2; m++)
{
- /* E_orig: integer */
- if (sbr->E_orig[ch][table_map_res_to_m[m]][l] > (1<<4))
+ if ((m + sbr->kx) < sbr->f_table_res[sbr->f[ch][l]][current_res_band+1])
{
- acc1 += (sbr->E_orig[ch][table_map_res_to_m[m]][l]>>4);
+ current_res_band_size++;
} else {
- acc1_coef += (sbr->E_orig[ch][table_map_res_to_m[m]][l] << (COEF_BITS-4));
- if (acc1_coef > COEF_CONST(3))
- {
- acc1 += (acc1_coef+(1<<(COEF_BITS-1)))>>COEF_BITS;
- acc1_coef = 0;
- }
+ acc1 += pow2_int(-REAL_CONST(10) + log2_int_tab[current_res_band_size] + find_log2_E(sbr, current_res_band, l, ch));
+
+ current_res_band++;
+ current_res_band_size = 1;
}
- /* E_curr: integer */
+
acc2 += sbr->E_curr[ch][m][l];
}
+ acc1 += pow2_int(-REAL_CONST(10) + log2_int_tab[current_res_band_size] + find_log2_E(sbr, current_res_band, l, ch));
- acc1 += (acc1_coef+(1<<(COEF_BITS-1)))>>COEF_BITS;
+ if (acc1 == 0)
+ acc1 = LOG2_MIN_INF;
+ else
+ acc1 = log2_int(acc1);
- /* G_max: fixed point */
- if ((acc2 == 0) && (acc1 > 3)) /* chosen 3 here, kind of arbitrary but it works (0 doesn't) */
+
+ /* calculate the maximum gain */
+ /* ratio of the energy of the original signal and the energy
+ * of the HF generated signal
+ */
+ G_max = acc1 - log2_int(acc2) + limGain[sbr->bs_limiter_gains];
+ G_max = min(G_max, limGain[3]);
+
+
+ for (m = ml1; m < ml2; m++)
{
- G_max = 0xFFFFFFF;
- G_max_infinite = 1;
- } else if (acc2 == 0) {
- G_max = 0;
- G_max_infinite = 0;
- } else {
- G_max_infinite = 0;
- switch (sbr->bs_limiter_gains)
+ real_t G;
+ real_t E_curr, E_orig;
+ real_t Q_orig, Q_orig_plus1;
+ uint8_t S_index_mapped;
+
+
+ /* check if m is on a noise band border */
+ if ((m + sbr->kx) == sbr->f_table_noise[current_f_noise_band+1])
{
- case 0: acct = acc1 >> 1; break;
- case 2: acct = acc1 << 1; break;
- case 3: acct = acc1; G_max_infinite = 1; break;
- default: acct = acc1; break;
+ /* step to next noise band */
+ current_f_noise_band++;
}
- if (acc2 > acct)
+
+ /* check if m is on a resolution band border */
+ if ((m + sbr->kx) == sbr->f_table_res[sbr->f[ch][l]][current_res_band2+1])
{
- G_max_is_frac = 1;
- G_max = (((int64_t)acct)<<FRAC_BITS) / acc2;
+ /* accumulate a whole range of equal Q_Ms */
+ if (Q_M_size > 0)
+ den += pow2_int(log2_int_tab[Q_M_size] + Q_M);
+ Q_M_size = 0;
+
+ /* step to next resolution band */
+ current_res_band2++;
+
+ /* if we move to a new resolution band, we should check if we are
+ * going to add a sinusoid in this band
+ */
+ S_mapped = get_S_mapped(sbr, ch, l, current_res_band2);
+ }
+
+
+ /* check if m is on a HI_RES band border */
+ if ((m + sbr->kx) == sbr->f_table_res[HI_RES][current_hi_res_band+1])
+ {
+ /* step to next HI_RES band */
+ current_hi_res_band++;
+ }
+
+
+ /* find S_index_mapped
+ * S_index_mapped can only be 1 for the m in the middle of the
+ * current HI_RES band
+ */
+ S_index_mapped = 0;
+ if ((l >= sbr->l_A[ch]) ||
+ (sbr->bs_add_harmonic_prev[ch][current_hi_res_band] && sbr->bs_add_harmonic_flag_prev[ch]))
+ {
+ /* find the middle subband of the HI_RES frequency band */
+ if ((m + sbr->kx) == (sbr->f_table_res[HI_RES][current_hi_res_band+1] + sbr->f_table_res[HI_RES][current_hi_res_band]) >> 1)
+ S_index_mapped = sbr->bs_add_harmonic[ch][current_hi_res_band];
+ }
+
+
+ /* find bitstream parameters */
+ if (sbr->E_curr[ch][m][l] == 0)
+ E_curr = LOG2_MIN_INF;
+ else
+ E_curr = log2_int(sbr->E_curr[ch][m][l]);
+ E_orig = -REAL_CONST(10) + find_log2_E(sbr, current_res_band2, l, ch);
+
+
+ Q_orig = find_log2_Q(sbr, current_f_noise_band, current_t_noise_band, ch);
+ Q_orig_plus1 = find_log2_Qplus1(sbr, current_f_noise_band, current_t_noise_band, ch);
+
+
+ /* Q_M only depends on E_orig and Q_div2:
+ * since N_Q <= N_Low <= N_High we only need to recalculate Q_M on
+ * a change of current res band (HI or LO)
+ */
+ Q_M = E_orig + Q_orig - Q_orig_plus1;
+
+
+ /* S_M only depends on E_orig, Q_div and S_index_mapped:
+ * S_index_mapped can only be non-zero once per HI_RES band
+ */
+ if (S_index_mapped == 0)
+ {
+ S_M[m] = LOG2_MIN_INF; /* -inf */
} else {
- G_max_is_frac = 0;
- G_max = (((int64_t)acct)<<REAL_BITS) / acc2;
+ S_M[m] = E_orig - Q_orig_plus1;
+
+ /* accumulate sinusoid part of the total energy */
+ den += pow2_int(S_M[m]);
}
+
+
+ /* calculate gain */
+ /* ratio of the energy of the original signal and the energy
+ * of the HF generated signal
+ */
+ /* E_curr here is officially E_curr+1 so the log2() of that can never be < 0 */
+ /* scaled by -10 */
+ G = E_orig - max(-REAL_CONST(10), E_curr);
+ if ((S_mapped == 0) && (delta == 1))
+ {
+ /* G = G * 1/(1+Q) */
+ G -= Q_orig_plus1;
+ } else if (S_mapped == 1) {
+ /* G = G * Q/(1+Q) */
+ G += Q_orig - Q_orig_plus1;
+ }
+
+
+ /* limit the additional noise energy level */
+ /* and apply the limiter */
+ if (G_max > G)
+ {
+ Q_M_lim[m] = Q_M;
+ G_lim[m] = G;
+
+ if ((S_index_mapped == 0) && (l != sbr->l_A[ch]))
+ {
+ Q_M_size++;
+ }
+ } else {
+ /* G > G_max */
+ Q_M_lim[m] = Q_M + G_max - G;
+ G_lim[m] = G_max;
+
+ /* accumulate limited Q_M */
+ if ((S_index_mapped == 0) && (l != sbr->l_A[ch]))
+ {
+ den += pow2_int(Q_M_lim[m]);
+ }
+ }
+
+
+ /* accumulate the total energy */
+ /* E_curr changes for every m so we do need to accumulate every m */
+ den += pow2_int(E_curr + G_lim[m]);
}
+ /* accumulate last range of equal Q_Ms */
+ if (Q_M_size > 0)
+ {
+ den += pow2_int(log2_int_tab[Q_M_size] + Q_M);
+ }
+
+
+ /* calculate the final gain */
+ /* G_boost: [0..2.51188643] */
+ G_boost = acc1 - log2_int(den /*+ EPS*/);
+ G_boost = min(G_boost, REAL_CONST(1.328771237) /* log2(1.584893192 ^ 2) */);
+
+
for (m = ml1; m < ml2; m++)
{
- real_t Q_M, G;
- real_t Q_div1, Q_div2;
- real_t E_orig;
- /* set to 1 to start with */
- uint8_t G_max_biggest = 1;
+ /* apply compensation to gain, noise floor sf's and sinusoid levels */
+#ifndef SBR_LOW_POWER
+ adj->G_lim_boost[l][m] = pow2_fix((G_lim[m] + G_boost) >> 1);
+#else
+ /* sqrt() will be done after the aliasing reduction to save a
+ * few multiplies
+ */
+ adj->G_lim_boost[l][m] = pow2_fix(G_lim[m] + G_boost);
+#endif
+ adj->Q_M_lim_boost[l][m] = pow2_fix((Q_M_lim[m] + G_boost) >> 1);
+ if (S_M[m] != LOG2_MIN_INF)
+ {
+ adj->S_M_boost[l][m] = pow2_int((S_M[m] + G_boost) >> 1);
+ } else {
+ adj->S_M_boost[l][m] = 0;
+ }
+ }
+ }
+ }
+}
- /* Q_mapped: fixed point */
+#else
- /* Q_div1: [0..1] FRAC_CONST */
- Q_div1 = adj->Q_div_mapped[l][m];
- /* Q_div2: [0..1] FRAC_CONST */
- Q_div2 = adj->Q_div2_mapped[l][m];
+//#define LOG2_TEST
- /* E_orig: integer */
- E_orig = sbr->E_orig[ch][table_map_res_to_m[m]][l];
+#ifdef LOG2_TEST
- /* Q_M: REAL */
- /* S_M: integer */
- if ((E_orig > (1<<22)) && (Q_div2 > FRAC_CONST(0.8)))
- {
- /* Q_M will not fit in a real */
- Q_M = ((int64_t)(E_orig>>4) * Q_div2) >> FRAC_BITS;
- Q_M_is_real[m] = 0;
+#define LOG2_MIN_INF -100000
+
+__inline float pow2(float val)
+{
+ return pow(2.0, val);
+}
+__inline float log2(float val)
+{
+ return log(val)/log(2.0);
+}
- S_M[m] = adj->S_index_mapped[l][m] * MUL_F((E_orig>>4), Q_div1);
- } else if (E_orig > (1<<4)) {
- Q_M = ((int64_t)(E_orig>>4) * Q_div2) >> (FRAC_BITS-REAL_BITS);
- Q_M_is_real[m] = 1;
+#define RB 14
- S_M[m] = adj->S_index_mapped[l][m] * MUL_F((E_orig>>4), Q_div1);
- } else {
- Q_M = ((int64_t)E_orig * Q_div2) >> (FRAC_BITS-REAL_BITS);
- Q_M >>= 4;
- Q_M_is_real[m] = 1;
+float QUANTISE2REAL(float val)
+{
+ __int32 ival = (__int32)(val * (1<<RB));
+ return (float)ival / (float)((1<<RB));
+}
- S_M[m] = adj->S_index_mapped[l][m] * MUL_F(E_orig, Q_div1);
- S_M[m] >>= 4;
- }
+float QUANTISE2INT(float val)
+{
+ return floor(val);
+}
+/* log2 values of [0..63] */
+static const real_t log2_int_tab[] = {
+ LOG2_MIN_INF, 0.000000000000000, 1.000000000000000, 1.584962500721156,
+ 2.000000000000000, 2.321928094887362, 2.584962500721156, 2.807354922057604,
+ 3.000000000000000, 3.169925001442313, 3.321928094887363, 3.459431618637297,
+ 3.584962500721156, 3.700439718141092, 3.807354922057604, 3.906890595608519,
+ 4.000000000000000, 4.087462841250339, 4.169925001442312, 4.247927513443585,
+ 4.321928094887362, 4.392317422778761, 4.459431618637297, 4.523561956057013,
+ 4.584962500721156, 4.643856189774724, 4.700439718141093, 4.754887502163468,
+ 4.807354922057604, 4.857980995127572, 4.906890595608519, 4.954196310386875,
+ 5.000000000000000, 5.044394119358453, 5.087462841250340, 5.129283016944966,
+ 5.169925001442312, 5.209453365628949, 5.247927513443585, 5.285402218862248,
+ 5.321928094887363, 5.357552004618084, 5.392317422778761, 5.426264754702098,
+ 5.459431618637297, 5.491853096329675, 5.523561956057013, 5.554588851677637,
+ 5.584962500721156, 5.614709844115208, 5.643856189774724, 5.672425341971495,
+ 5.700439718141093, 5.727920454563200, 5.754887502163469, 5.781359713524660,
+ 5.807354922057605, 5.832890014164742, 5.857980995127572, 5.882643049361842,
+ 5.906890595608518, 5.930737337562887, 5.954196310386876, 5.977279923499916
+};
- /* G: fixed point */
- if (sbr->E_curr[ch][m][l] != 0)
- {
- /* E_curr = INT */
- if (sbr->E_curr[ch][m][l] > (E_orig>>4))
- {
- /*frac*/
- G = (((int64_t)E_orig)<<(FRAC_BITS-4)) / sbr->E_curr[ch][m][l];
+static const real_t pan_log2_tab[] = {
+ 1.000000000000000, 0.584962500721156, 0.321928094887362, 0.169925001442312, 0.087462841250339,
+ 0.044394119358453, 0.022367813028455, 0.011227255423254, 0.005624549193878, 0.002815015607054,
+ 0.001408194392808, 0.000704269011247, 0.000352177480301, 0.000176099486443, 0.000088052430122,
+ 0.000044026886827, 0.000022013611360, 0.000011006847667
+};
+
+static real_t find_log2_E(sbr_info *sbr, uint8_t k, uint8_t l, uint8_t ch)
+{
+ /* check for coupled energy/noise data */
+ if (sbr->bs_coupling == 1)
+ {
+ real_t amp0 = (sbr->amp_res[0]) ? 1.0 : 0.5;
+ real_t amp1 = (sbr->amp_res[1]) ? 1.0 : 0.5;
+ float tmp = QUANTISE2REAL(7.0 + (real_t)sbr->E[0][k][l] * amp0);
+ float pan;
- G_is_frac[m] = 1;
- } else {
- /*real*/
- G = (((int64_t)E_orig)<<(REAL_BITS-4)) / sbr->E_curr[ch][m][l];
+ int E = (int)(sbr->E[1][k][l] * amp1);
+
+ if (ch == 0)
+ {
+ if (E > 12)
+ {
+ /* negative */
+ pan = QUANTISE2REAL(pan_log2_tab[-12 + E]);
+ } else {
+ /* positive */
+ pan = QUANTISE2REAL(pan_log2_tab[12 - E] + (12 - E));
+ }
+ } else {
+ if (E < 12)
+ {
+ /* negative */
+ pan = QUANTISE2REAL(pan_log2_tab[-E + 12]);
+ } else {
+ /* positive */
+ pan = QUANTISE2REAL(pan_log2_tab[E - 12] + (E - 12));
+ }
+ }
+
+ /* tmp / pan in log2 */
+ return QUANTISE2REAL(tmp - pan);
+ } else {
+ real_t amp = (sbr->amp_res[ch]) ? 1.0 : 0.5;
- G_is_frac[m] = 0;
- }
- } else {
- /* E_curr == 0, check if E_orig happens to be really big */
- if (G_max_is_frac == 0)
- {
- if ((E_orig<<4) > (G_max>>REAL_BITS))
- {
- G_max_biggest = 0;
- }
- } else {
- /* G_max is fractional type */
- if (E_orig != 0)
- {
- G_max_biggest = 0;
- }
- }
+ return QUANTISE2REAL(6.0 + (real_t)sbr->E[ch][k][l] * amp);
+ }
+}
+
+static real_t find_log2_Q(sbr_info *sbr, uint8_t k, uint8_t l, uint8_t ch)
+{
+ /* check for coupled energy/noise data */
+ if (sbr->bs_coupling == 1)
+ {
+ float tmp = QUANTISE2REAL(7.0 - (real_t)sbr->Q[0][k][l]);
+ float pan;
+
+ int Q = (int)(sbr->Q[1][k][l]);
+
+ if (ch == 0)
+ {
+ if (Q > 12)
+ {
+ /* negative */
+ pan = QUANTISE2REAL(pan_log2_tab[-12 + Q]);
+ } else {
+ /* positive */
+ pan = QUANTISE2REAL(pan_log2_tab[12 - Q] + (12 - Q));
+ }
+ } else {
+ if (Q < 12)
+ {
+ /* negative */
+ pan = QUANTISE2REAL(pan_log2_tab[-Q + 12]);
+ } else {
+ /* positive */
+ pan = QUANTISE2REAL(pan_log2_tab[Q - 12] + (Q - 12));
+ }
+ }
+
+ /* tmp / pan in log2 */
+ return QUANTISE2REAL(tmp - pan);
+ } else {
+ return QUANTISE2REAL(6.0 - (real_t)sbr->Q[ch][k][l]);
+ }
+}
+
+static const real_t log_Qplus1_pan[31][13] = {
+ { REAL_CONST(0.044383447617292), REAL_CONST(0.169768601655960), REAL_CONST(0.583090126514435), REAL_CONST(1.570089221000671), REAL_CONST(3.092446088790894), REAL_CONST(4.733354568481445), REAL_CONST(6.022367954254150), REAL_CONST(6.692092418670654), REAL_CONST(6.924463272094727), REAL_CONST(6.989034175872803), REAL_CONST(7.005646705627441), REAL_CONST(7.009829998016357), REAL_CONST(7.010877609252930) },
+ { REAL_CONST(0.022362394258380), REAL_CONST(0.087379962205887), REAL_CONST(0.320804953575134), REAL_CONST(0.988859415054321), REAL_CONST(2.252387046813965), REAL_CONST(3.786596298217773), REAL_CONST(5.044394016265869), REAL_CONST(5.705977916717529), REAL_CONST(5.936291694641113), REAL_CONST(6.000346660614014), REAL_CONST(6.016829967498779), REAL_CONST(6.020981311798096), REAL_CONST(6.022020816802979) },
+ { REAL_CONST(0.011224525049329), REAL_CONST(0.044351425021887), REAL_CONST(0.169301137328148), REAL_CONST(0.577544987201691), REAL_CONST(1.527246952056885), REAL_CONST(2.887525320053101), REAL_CONST(4.087462902069092), REAL_CONST(4.733354568481445), REAL_CONST(4.959661006927490), REAL_CONST(5.022709369659424), REAL_CONST(5.038940429687500), REAL_CONST(5.043028831481934), REAL_CONST(5.044052600860596) },
+ { REAL_CONST(0.005623178556561), REAL_CONST(0.022346137091517), REAL_CONST(0.087132595479488), REAL_CONST(0.317482173442841), REAL_CONST(0.956931233406067), REAL_CONST(2.070389270782471), REAL_CONST(3.169924974441528), REAL_CONST(3.786596298217773), REAL_CONST(4.005294322967529), REAL_CONST(4.066420555114746), REAL_CONST(4.082170009613037), REAL_CONST(4.086137294769287), REAL_CONST(4.087131500244141) },
+ { REAL_CONST(0.002814328996465), REAL_CONST(0.011216334067285), REAL_CONST(0.044224001467228), REAL_CONST(0.167456731200218), REAL_CONST(0.556393325328827), REAL_CONST(1.378511548042297), REAL_CONST(2.321928024291992), REAL_CONST(2.887525320053101), REAL_CONST(3.092446088790894), REAL_CONST(3.150059700012207), REAL_CONST(3.164926528930664), REAL_CONST(3.168673276901245), REAL_CONST(3.169611930847168) },
+ { REAL_CONST(0.001407850766554), REAL_CONST(0.005619067233056), REAL_CONST(0.022281449288130), REAL_CONST(0.086156636476517), REAL_CONST(0.304854571819305), REAL_CONST(0.847996890544891), REAL_CONST(1.584962487220764), REAL_CONST(2.070389270782471), REAL_CONST(2.252387046813965), REAL_CONST(2.304061651229858), REAL_CONST(2.317430257797241), REAL_CONST(2.320801734924316), REAL_CONST(2.321646213531494) },
+ { REAL_CONST(0.000704097095877), REAL_CONST(0.002812269143760), REAL_CONST(0.011183738708496), REAL_CONST(0.043721374124289), REAL_CONST(0.160464659333229), REAL_CONST(0.485426813364029), REAL_CONST(1.000000000000000), REAL_CONST(1.378511548042297), REAL_CONST(1.527246952056885), REAL_CONST(1.570089221000671), REAL_CONST(1.581215262413025), REAL_CONST(1.584023833274841), REAL_CONST(1.584727644920349) },
+ { REAL_CONST(0.000352177477907), REAL_CONST(0.001406819908880), REAL_CONST(0.005602621007711), REAL_CONST(0.022026389837265), REAL_CONST(0.082462236285210), REAL_CONST(0.263034462928772), REAL_CONST(0.584962487220764), REAL_CONST(0.847996890544891), REAL_CONST(0.956931233406067), REAL_CONST(0.988859415054321), REAL_CONST(0.997190535068512), REAL_CONST(0.999296069145203), REAL_CONST(0.999823868274689) },
+ { REAL_CONST(0.000176099492819), REAL_CONST(0.000703581434209), REAL_CONST(0.002804030198604), REAL_CONST(0.011055230163038), REAL_CONST(0.041820213198662), REAL_CONST(0.137503549456596), REAL_CONST(0.321928083896637), REAL_CONST(0.485426813364029), REAL_CONST(0.556393325328827), REAL_CONST(0.577544987201691), REAL_CONST(0.583090126514435), REAL_CONST(0.584493279457092), REAL_CONST(0.584845066070557) },
+ { REAL_CONST(0.000088052431238), REAL_CONST(0.000351833587047), REAL_CONST(0.001402696361765), REAL_CONST(0.005538204684854), REAL_CONST(0.021061634644866), REAL_CONST(0.070389263331890), REAL_CONST(0.169925004243851), REAL_CONST(0.263034462928772), REAL_CONST(0.304854571819305), REAL_CONST(0.317482173442841), REAL_CONST(0.320804953575134), REAL_CONST(0.321646571159363), REAL_CONST(0.321857661008835) },
+ { REAL_CONST(0.000044026888645), REAL_CONST(0.000175927518285), REAL_CONST(0.000701518612914), REAL_CONST(0.002771759871393), REAL_CONST(0.010569252073765), REAL_CONST(0.035623874515295), REAL_CONST(0.087462842464447), REAL_CONST(0.137503549456596), REAL_CONST(0.160464659333229), REAL_CONST(0.167456731200218), REAL_CONST(0.169301137328148), REAL_CONST(0.169768601655960), REAL_CONST(0.169885858893394) },
+ { REAL_CONST(0.000022013611670), REAL_CONST(0.000088052431238), REAL_CONST(0.000350801943569), REAL_CONST(0.001386545598507), REAL_CONST(0.005294219125062), REAL_CONST(0.017921976745129), REAL_CONST(0.044394120573997), REAL_CONST(0.070389263331890), REAL_CONST(0.082462236285210), REAL_CONST(0.086156636476517), REAL_CONST(0.087132595479488), REAL_CONST(0.087379962205887), REAL_CONST(0.087442122399807) },
+ { REAL_CONST(0.000011006847672), REAL_CONST(0.000044026888645), REAL_CONST(0.000175411638338), REAL_CONST(0.000693439331371), REAL_CONST(0.002649537986144), REAL_CONST(0.008988817222416), REAL_CONST(0.022367812693119), REAL_CONST(0.035623874515295), REAL_CONST(0.041820213198662), REAL_CONST(0.043721374124289), REAL_CONST(0.044224001467228), REAL_CONST(0.044351425021887), REAL_CONST(0.044383447617292) },
+ { REAL_CONST(0.000005503434295), REAL_CONST(0.000022013611670), REAL_CONST(0.000087708482170), REAL_CONST(0.000346675369656), REAL_CONST(0.001325377263129), REAL_CONST(0.004501323681325), REAL_CONST(0.011227255687118), REAL_CONST(0.017921976745129), REAL_CONST(0.021061634644866), REAL_CONST(0.022026389837265), REAL_CONST(0.022281449288130), REAL_CONST(0.022346137091517), REAL_CONST(0.022362394258380) },
+ { REAL_CONST(0.000002751719876), REAL_CONST(0.000011006847672), REAL_CONST(0.000043854910473), REAL_CONST(0.000173348103999), REAL_CONST(0.000662840844598), REAL_CONST(0.002252417383716), REAL_CONST(0.005624548997730), REAL_CONST(0.008988817222416), REAL_CONST(0.010569252073765), REAL_CONST(0.011055230163038), REAL_CONST(0.011183738708496), REAL_CONST(0.011216334067285), REAL_CONST(0.011224525049329) },
+ { REAL_CONST(0.000001375860506), REAL_CONST(0.000005503434295), REAL_CONST(0.000022013611670), REAL_CONST(0.000086676649516), REAL_CONST(0.000331544462824), REAL_CONST(0.001126734190620), REAL_CONST(0.002815015614033), REAL_CONST(0.004501323681325), REAL_CONST(0.005294219125062), REAL_CONST(0.005538204684854), REAL_CONST(0.005602621007711), REAL_CONST(0.005619067233056), REAL_CONST(0.005623178556561) },
+ { REAL_CONST(0.000000687930424), REAL_CONST(0.000002751719876), REAL_CONST(0.000011006847672), REAL_CONST(0.000043338975956), REAL_CONST(0.000165781748365), REAL_CONST(0.000563477107789), REAL_CONST(0.001408194424585), REAL_CONST(0.002252417383716), REAL_CONST(0.002649537986144), REAL_CONST(0.002771759871393), REAL_CONST(0.002804030198604), REAL_CONST(0.002812269143760), REAL_CONST(0.002814328996465) },
+ { REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000005503434295), REAL_CONST(0.000021669651687), REAL_CONST(0.000082893253420), REAL_CONST(0.000281680084299), REAL_CONST(0.000704268983100), REAL_CONST(0.001126734190620), REAL_CONST(0.001325377263129), REAL_CONST(0.001386545598507), REAL_CONST(0.001402696361765), REAL_CONST(0.001406819908880), REAL_CONST(0.001407850766554) },
+ { REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002751719876), REAL_CONST(0.000010834866771), REAL_CONST(0.000041447223339), REAL_CONST(0.000140846910654), REAL_CONST(0.000352177477907), REAL_CONST(0.000563477107789), REAL_CONST(0.000662840844598), REAL_CONST(0.000693439331371), REAL_CONST(0.000701518612914), REAL_CONST(0.000703581434209), REAL_CONST(0.000704097095877) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000005503434295), REAL_CONST(0.000020637769921), REAL_CONST(0.000070511166996), REAL_CONST(0.000176099492819), REAL_CONST(0.000281680084299), REAL_CONST(0.000331544462824), REAL_CONST(0.000346675369656), REAL_CONST(0.000350801943569), REAL_CONST(0.000351833587047), REAL_CONST(0.000352177477907) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002751719876), REAL_CONST(0.000010318922250), REAL_CONST(0.000035256012779), REAL_CONST(0.000088052431238), REAL_CONST(0.000140846910654), REAL_CONST(0.000165781748365), REAL_CONST(0.000173348103999), REAL_CONST(0.000175411638338), REAL_CONST(0.000175927518285), REAL_CONST(0.000176099492819) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000005159470220), REAL_CONST(0.000017542124624), REAL_CONST(0.000044026888645), REAL_CONST(0.000070511166996), REAL_CONST(0.000082893253420), REAL_CONST(0.000086676649516), REAL_CONST(0.000087708482170), REAL_CONST(0.000088052431238), REAL_CONST(0.000088052431238) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002579737384), REAL_CONST(0.000008771088687), REAL_CONST(0.000022013611670), REAL_CONST(0.000035256012779), REAL_CONST(0.000041447223339), REAL_CONST(0.000043338975956), REAL_CONST(0.000043854910473), REAL_CONST(0.000044026888645), REAL_CONST(0.000044026888645) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001375860506), REAL_CONST(0.000004471542070), REAL_CONST(0.000011006847672), REAL_CONST(0.000017542124624), REAL_CONST(0.000020637769921), REAL_CONST(0.000021669651687), REAL_CONST(0.000022013611670), REAL_CONST(0.000022013611670), REAL_CONST(0.000022013611670) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000687930424), REAL_CONST(0.000002235772627), REAL_CONST(0.000005503434295), REAL_CONST(0.000008771088687), REAL_CONST(0.000010318922250), REAL_CONST(0.000010834866771), REAL_CONST(0.000011006847672), REAL_CONST(0.000011006847672), REAL_CONST(0.000011006847672) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000001031895522), REAL_CONST(0.000002751719876), REAL_CONST(0.000004471542070), REAL_CONST(0.000005159470220), REAL_CONST(0.000005503434295), REAL_CONST(0.000005503434295), REAL_CONST(0.000005503434295), REAL_CONST(0.000005503434295) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000515947875), REAL_CONST(0.000001375860506), REAL_CONST(0.000002235772627), REAL_CONST(0.000002579737384), REAL_CONST(0.000002751719876), REAL_CONST(0.000002751719876), REAL_CONST(0.000002751719876), REAL_CONST(0.000002751719876) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000343965269), REAL_CONST(0.000000687930424), REAL_CONST(0.000001031895522), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506), REAL_CONST(0.000001375860506) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000343965269), REAL_CONST(0.000000515947875), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424), REAL_CONST(0.000000687930424) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269), REAL_CONST(0.000000343965269) },
+ { REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000000000000), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634), REAL_CONST(0.000000171982634) }
+};
+
+static const real_t log_Qplus1[31] = {
+ REAL_CONST(6.022367813028454), REAL_CONST(5.044394119358453), REAL_CONST(4.087462841250339),
+ REAL_CONST(3.169925001442313), REAL_CONST(2.321928094887362), REAL_CONST(1.584962500721156),
+ REAL_CONST(1.000000000000000), REAL_CONST(0.584962500721156), REAL_CONST(0.321928094887362),
+ REAL_CONST(0.169925001442312), REAL_CONST(0.087462841250339), REAL_CONST(0.044394119358453),
+ REAL_CONST(0.022367813028455), REAL_CONST(0.011227255423254), REAL_CONST(0.005624549193878),
+ REAL_CONST(0.002815015607054), REAL_CONST(0.001408194392808), REAL_CONST(0.000704269011247),
+ REAL_CONST(0.000352177480301), REAL_CONST(0.000176099486443), REAL_CONST(0.000088052430122),
+ REAL_CONST(0.000044026886827), REAL_CONST(0.000022013611360), REAL_CONST(0.000011006847667),
+ REAL_CONST(0.000005503434331), REAL_CONST(0.000002751719790), REAL_CONST(0.000001375860551),
+ REAL_CONST(0.000000687930439), REAL_CONST(0.000000343965261), REAL_CONST(0.000000171982641),
+ REAL_CONST(0.000000000000000)
+};
+
+static real_t find_log2_Qplus1(sbr_info *sbr, uint8_t k, uint8_t l, uint8_t ch)
+{
+ /* check for coupled energy/noise data */
+ if (sbr->bs_coupling == 1)
+ {
+ if ((sbr->Q[0][k][l] >= 0) && (sbr->Q[0][k][l] <= 30) &&
+ (sbr->Q[1][k][l] >= 0) && (sbr->Q[1][k][l] <= 24))
+ {
+ if (ch == 0)
+ {
+ return QUANTISE2REAL(log_Qplus1_pan[sbr->Q[0][k][l]][sbr->Q[1][k][l] >> 1]);
+ } else {
+ return QUANTISE2REAL(log_Qplus1_pan[sbr->Q[0][k][l]][12 - (sbr->Q[1][k][l] >> 1)]);
+ }
+ } else {
+ return 0;
+ }
+ } else {
+ if (sbr->Q[ch][k][l] >= 0 && sbr->Q[ch][k][l] <= 30)
+ {
+ return QUANTISE2REAL(log_Qplus1[sbr->Q[ch][k][l]]);
+ } else {
+ return 0;
+ }
+ }
+}
- G = (E_orig << (REAL_BITS-4+10));
+static void calculate_gain(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch)
+{
+ /* log2 values of limiter gains */
+ static real_t limGain[] = { -1.0, 0.0, 1.0, 33.219 };
+ uint8_t m, l, k;
- G_is_frac[m] = 0;
+ uint8_t current_t_noise_band = 0;
+ uint8_t S_mapped;
+
+ ALIGN real_t Q_M_lim[MAX_M];
+ ALIGN real_t G_lim[MAX_M];
+ ALIGN real_t G_boost;
+ ALIGN real_t S_M[MAX_M];
+
+
+ for (l = 0; l < sbr->L_E[ch]; l++)
+ {
+ uint8_t current_f_noise_band = 0;
+ uint8_t current_res_band = 0;
+ uint8_t current_res_band2 = 0;
+ uint8_t current_hi_res_band = 0;
+
+ real_t delta = (l == sbr->l_A[ch] || l == sbr->prevEnvIsShort[ch]) ? 0 : 1;
+
+ S_mapped = get_S_mapped(sbr, ch, l, current_res_band2);
+
+ if (sbr->t_E[ch][l+1] > sbr->t_Q[ch][current_t_noise_band+1])
+ {
+ current_t_noise_band++;
+ }
+
+ for (k = 0; k < sbr->N_L[sbr->bs_limiter_bands]; k++)
+ {
+ real_t Q_M = 0;
+ real_t G_max;
+ real_t den = 0;
+ real_t acc1 = 0;
+ real_t acc2 = 0;
+ uint8_t current_res_band_size = 0;
+ uint8_t Q_M_size = 0;
+
+ uint8_t ml1, ml2;
+
+ /* bounds of current limiter bands */
+ ml1 = sbr->f_table_lim[sbr->bs_limiter_bands][k];
+ ml2 = sbr->f_table_lim[sbr->bs_limiter_bands][k+1];
+
+
+ /* calculate the accumulated E_orig and E_curr over the limiter band */
+ for (m = ml1; m < ml2; m++)
+ {
+ if ((m + sbr->kx) < sbr->f_table_res[sbr->f[ch][l]][current_res_band+1])
+ {
+ current_res_band_size++;
+ } else {
+ acc1 += QUANTISE2INT(pow2(-10 + log2_int_tab[current_res_band_size] + find_log2_E(sbr, current_res_band, l, ch)));
+
+ current_res_band++;
+ current_res_band_size = 1;
}
- if (adj->S_mapped[l][m] == 1)
+ acc2 += QUANTISE2INT(sbr->E_curr[ch][m][l]/1024.0);
+ }
+ acc1 += QUANTISE2INT(pow2(-10 + log2_int_tab[current_res_band_size] + find_log2_E(sbr, current_res_band, l, ch)));
+
+ acc1 = QUANTISE2REAL( log2(EPS + acc1) );
+
+
+ /* calculate the maximum gain */
+ /* ratio of the energy of the original signal and the energy
+ * of the HF generated signal
+ */
+ G_max = acc1 - QUANTISE2REAL(log2(EPS + acc2)) + QUANTISE2REAL(limGain[sbr->bs_limiter_gains]);
+ G_max = min(G_max, QUANTISE2REAL(limGain[3]));
+
+
+ for (m = ml1; m < ml2; m++)
+ {
+ real_t G;
+ real_t E_curr, E_orig;
+ real_t Q_orig, Q_orig_plus1;
+ uint8_t S_index_mapped;
+
+
+ /* check if m is on a noise band border */
+ if ((m + sbr->kx) == sbr->f_table_noise[current_f_noise_band+1])
{
- G = MUL_F(G, Q_div2);
- } else if (delta == 1) {
- G = MUL_F(G, Q_div1);
+ /* step to next noise band */
+ current_f_noise_band++;
}
- /* limit the additional noise energy level */
- /* and apply the limiter */
- /* if we still have the default value for G_max_biggest -> compute */
- if (G_max_biggest != 0)
- G_max_biggest = G_max_is_biggest(G, G_max, G_is_frac[m], G_max_is_frac);
+ /* check if m is on a resolution band border */
+ if ((m + sbr->kx) == sbr->f_table_res[sbr->f[ch][l]][current_res_band2+1])
+ {
+ /* accumulate a whole range of equal Q_Ms */
+ if (Q_M_size > 0)
+ den += QUANTISE2INT(pow2(log2_int_tab[Q_M_size] + Q_M));
+ Q_M_size = 0;
- /* G_lim: fixed point */
- /* Q_M_lim: REAL/INT */
- if (G_max_infinite || G_max_biggest)
+ /* step to next resolution band */
+ current_res_band2++;
+
+ /* if we move to a new resolution band, we should check if we are
+ * going to add a sinusoid in this band
+ */
+ S_mapped = get_S_mapped(sbr, ch, l, current_res_band2);
+ }
+
+
+ /* check if m is on a HI_RES band border */
+ if ((m + sbr->kx) == sbr->f_table_res[HI_RES][current_hi_res_band+1])
{
- Q_M_lim[m] = Q_M;
- G_lim[m] = G;
+ /* step to next HI_RES band */
+ current_hi_res_band++;
+ }
+
+
+ /* find S_index_mapped
+ * S_index_mapped can only be 1 for the m in the middle of the
+ * current HI_RES band
+ */
+ S_index_mapped = 0;
+ if ((l >= sbr->l_A[ch]) ||
+ (sbr->bs_add_harmonic_prev[ch][current_hi_res_band] && sbr->bs_add_harmonic_flag_prev[ch]))
+ {
+ /* find the middle subband of the HI_RES frequency band */
+ if ((m + sbr->kx) == (sbr->f_table_res[HI_RES][current_hi_res_band+1] + sbr->f_table_res[HI_RES][current_hi_res_band]) >> 1)
+ S_index_mapped = sbr->bs_add_harmonic[ch][current_hi_res_band];
+ }
+
+
+ /* find bitstream parameters */
+ if (sbr->E_curr[ch][m][l] == 0)
+ E_curr = LOG2_MIN_INF;
+ else
+ E_curr = -10 + log2(sbr->E_curr[ch][m][l]);
+ E_orig = -10 + find_log2_E(sbr, current_res_band2, l, ch);
+
+ Q_orig = find_log2_Q(sbr, current_f_noise_band, current_t_noise_band, ch);
+ Q_orig_plus1 = find_log2_Qplus1(sbr, current_f_noise_band, current_t_noise_band, ch);
+
+
+ /* Q_M only depends on E_orig and Q_div2:
+ * since N_Q <= N_Low <= N_High we only need to recalculate Q_M on
+ * a change of current res band (HI or LO)
+ */
+ Q_M = E_orig + Q_orig - Q_orig_plus1;
+
+
+ /* S_M only depends on E_orig, Q_div and S_index_mapped:
+ * S_index_mapped can only be non-zero once per HI_RES band
+ */
+ if (S_index_mapped == 0)
+ {
+ S_M[m] = LOG2_MIN_INF; /* -inf */
} else {
- real_t tmp;
- uint8_t is_real = 0;
- if (G == 0)
- tmp = 0xFFF;
- else
- tmp = div_G_max_G(G, G_max, G_is_frac[m], G_max_is_frac, &is_real);
+ S_M[m] = E_orig - Q_orig_plus1;
- if (is_real == 0)
- Q_M_lim[m] = MUL_F(Q_M, tmp);
- else
- Q_M_lim[m] = MUL_R(Q_M, tmp);
+ /* accumulate sinusoid part of the total energy */
+ den += pow2(S_M[m]);
+ }
- G_lim[m] = G_max;
- G_is_frac[m] = G_max_is_frac;
+
+ /* calculate gain */
+ /* ratio of the energy of the original signal and the energy
+ * of the HF generated signal
+ */
+ /* E_curr here is officially E_curr+1 so the log2() of that can never be < 0 */
+ /* scaled by -10 */
+ G = E_orig - max(-10, E_curr);
+ if ((S_mapped == 0) && (delta == 1))
+ {
+ /* G = G * 1/(1+Q) */
+ G -= Q_orig_plus1;
+ } else if (S_mapped == 1) {
+ /* G = G * Q/(1+Q) */
+ G += Q_orig - Q_orig_plus1;
}
- /* E_curr: integer/coef */
- if (G_is_frac[m] == 0)
+ /* limit the additional noise energy level */
+ /* and apply the limiter */
+ if (G_max > G)
{
- if (sbr->E_curr[ch][m][l] < (1<<(25-REAL_BITS)))
+ Q_M_lim[m] = QUANTISE2REAL(Q_M);
+ G_lim[m] = QUANTISE2REAL(G);
+
+ if ((S_index_mapped == 0) && (l != sbr->l_A[ch]))
{
- den_real += sbr->E_curr[ch][m][l] * G_lim[m];
- } else {
- den_int += MUL_R(sbr->E_curr[ch][m][l], G_lim[m]);
+ Q_M_size++;
}
} else {
- den_int += MUL_F(sbr->E_curr[ch][m][l], G_lim[m]);
- }
- den_int += S_M[m];
- if ((!adj->S_index_mapped[l][m]) && (l != sbr->l_A[ch]))
- {
- if (Q_M_is_real[m] == 1)
+ /* G > G_max */
+ Q_M_lim[m] = QUANTISE2REAL(Q_M) + G_max - QUANTISE2REAL(G);
+ G_lim[m] = G_max;
+
+ /* accumulate limited Q_M */
+ if ((S_index_mapped == 0) && (l != sbr->l_A[ch]))
{
- if (Q_M_lim[m] > REAL_CONST(100))
- den_int += (Q_M_lim[m]>>REAL_BITS);
- else
- den_real += Q_M_lim[m];
- } else {
- den_int += Q_M_lim[m];
+ den += QUANTISE2INT(pow2(Q_M_lim[m]));
}
}
+
+
+ /* accumulate the total energy */
+ /* E_curr changes for every m so we do need to accumulate every m */
+ den += QUANTISE2INT(pow2(E_curr + G_lim[m]));
}
- den = den_int + ((den_real+(1<<(REAL_BITS-1)))>>REAL_BITS);
+ /* accumulate last range of equal Q_Ms */
+ if (Q_M_size > 0)
+ {
+ den += QUANTISE2INT(pow2(log2_int_tab[Q_M_size] + Q_M));
+ }
- /* G_boost: fixed point */
- if ((den + EPS) == 0 || den == 0)
- G_boost = REAL_CONST(1);//REAL_CONST(2.51188643);
- else if (acc1 > (den<<1)+(den>>1))
- G_boost = REAL_CONST(2.51188643);
- else
- G_boost = (((int64_t)(acc1 + EPS))<<REAL_BITS)/(den + EPS);
- G_boost = min(G_boost, REAL_CONST(2.51188643) /* 1.584893192 ^ 2 */);
+ /* calculate the final gain */
+ /* G_boost: [0..2.51188643] */
+ G_boost = acc1 - QUANTISE2REAL(log2(den + EPS));
+ G_boost = min(G_boost, QUANTISE2REAL(1.328771237) /* log2(1.584893192 ^ 2) */);
+
+
for (m = ml1; m < ml2; m++)
{
/* apply compensation to gain, noise floor sf's and sinusoid levels */
#ifndef SBR_LOW_POWER
- /* G_lim_boost: fixed point */
- if (G_is_frac[m] == 0)
- {
- adj->G_lim_boost[l][m] = SBR_SQRT_Q2(MUL_SHIFT6(G_lim[m], G_boost));
- } else {
- adj->G_lim_boost[l][m] = SBR_SQRT_Q2(MUL_SHIFT23(G_lim[m], G_boost));
- }
+ adj->G_lim_boost[l][m] = QUANTISE2REAL(pow2((G_lim[m] + G_boost) / 2.0));
#else
/* sqrt() will be done after the aliasing reduction to save a
* few multiplies
*/
- /* G_lim_boost: fixed point */
- if (G_is_frac[m] == 0)
- {
- adj->G_lim_boost[l][m] = MUL_SHIFT6(G_lim[m], G_boost);
- } else {
- adj->G_lim_boost[l][m] = MUL_SHIFT23(G_lim[m], G_boost);
- }
+ adj->G_lim_boost[l][m] = QUANTISE2REAL(pow2(G_lim[m] + G_boost));
#endif
- /* Q_M_lim_boost: integer */
- /* Q_M_lim_boost: REAL */
- if (Q_M_is_real[m])
- {
- adj->Q_M_lim_boost[l][m] = SBR_SQRT_FIX(MUL_R(Q_M_lim[m], G_boost));
- } else {
- adj->Q_M_lim_boost[l][m] = SBR_SQRT_INT(MUL_R(Q_M_lim[m], G_boost));
- adj->Q_M_lim_boost[l][m] <<= REAL_BITS;
- }
+ adj->Q_M_lim_boost[l][m] = QUANTISE2REAL(pow2((Q_M_lim[m] + 10 + G_boost) / 2.0));
- /* S_M_boost: integer */
- if (adj->S_index_mapped[l][m])
+ if (S_M[m] != LOG2_MIN_INF)
{
- adj->S_M_boost[l][m] = SBR_SQRT_INT(MUL_R(S_M[m], G_boost));
+ adj->S_M_boost[l][m] = QUANTISE2REAL(pow2((S_M[m] + 10 + G_boost) / 2.0));
} else {
adj->S_M_boost[l][m] = 0;
}
@@ -765,6 +1132,7 @@
}
}
}
+
#else
static void calculate_gain(sbr_info *sbr, sbr_hfadj_info *adj, uint8_t ch)
@@ -965,6 +1333,8 @@
}
}
}
+#endif // log2_test
+
#endif
#ifdef SBR_LOW_POWER
@@ -1001,7 +1371,7 @@
i++;
}
}
- }
+ }
if (grouping)
{
@@ -1023,7 +1393,7 @@
for (k = 0; k < sbr->N_G[l]; k++)
{
E_total_est = E_total = 0;
-
+
for (m = sbr->f_group[l][k<<1]; m < sbr->f_group[l][(k<<1) + 1]; m++)
{
/* E_curr: integer */
@@ -1216,7 +1586,9 @@
QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = G_filt * QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx])
+ MUL_F(Q_filt, RE(V[fIndexNoise]));
#else
- QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = MUL_Q2(G_filt, QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx]))
+ //QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = MUL_Q2(G_filt, QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx]))
+ // + MUL_F(Q_filt, RE(V[fIndexNoise]));
+ QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = MUL_R(G_filt, QMF_RE(Xsbr[i + sbr->tHFAdj][m+sbr->kx]))
+ MUL_F(Q_filt, RE(V[fIndexNoise]));
#endif
if (sbr->bs_extension_id == 3 && sbr->bs_extension_data == 42)
@@ -1226,7 +1598,9 @@
QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = G_filt * QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx])
+ MUL_F(Q_filt, IM(V[fIndexNoise]));
#else
- QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = MUL_Q2(G_filt, QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx]))
+ //QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = MUL_Q2(G_filt, QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx]))
+ // + MUL_F(Q_filt, IM(V[fIndexNoise]));
+ QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx]) = MUL_R(G_filt, QMF_IM(Xsbr[i + sbr->tHFAdj][m+sbr->kx]))
+ MUL_F(Q_filt, IM(V[fIndexNoise]));
#endif
#endif
--- a/libfaad/sbr_hfadj.h
+++ b/libfaad/sbr_hfadj.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_hfadj.h,v 1.12 2004/04/12 18:17:42 menno Exp $
+** $Id: sbr_hfadj.h,v 1.15 2004/09/04 14:56:28 menno Exp $
**/
#ifndef __SBR_HFADJ_H__
@@ -34,16 +34,9 @@
typedef struct
{
- real_t Q_div_mapped[MAX_L_E][MAX_M];
- real_t Q_div2_mapped[MAX_L_E][MAX_M];
-
- uint8_t S_index_mapped[MAX_L_E][MAX_M];
- uint8_t S_mapped[MAX_L_E][MAX_M];
-
real_t G_lim_boost[MAX_L_E][MAX_M];
real_t Q_M_lim_boost[MAX_L_E][MAX_M];
real_t S_M_boost[MAX_L_E][MAX_M];
-
} sbr_hfadj_info;
--- a/libfaad/sbr_hfgen.c
+++ b/libfaad/sbr_hfgen.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_hfgen.c,v 1.17 2004/04/12 18:17:42 menno Exp $
+** $Id: sbr_hfgen.c,v 1.18 2004/05/17 10:18:03 menno Exp $
**/
/* High Frequency generation */
@@ -39,11 +39,11 @@
/* static function declarations */
#ifdef SBR_LOW_POWER
-static void calc_prediction_coef_lp(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][32],
+static void calc_prediction_coef_lp(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][64],
complex_t *alpha_0, complex_t *alpha_1, real_t *rxx);
static void calc_aliasing_degree(sbr_info *sbr, real_t *rxx, real_t *deg);
#else
-static void calc_prediction_coef(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][32],
+static void calc_prediction_coef(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][64],
complex_t *alpha_0, complex_t *alpha_1, uint8_t k);
#endif
static void calc_chirp_factors(sbr_info *sbr, uint8_t ch);
@@ -50,7 +50,7 @@
static void patch_construction(sbr_info *sbr);
-void hf_generation(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][32],
+void hf_generation(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][64],
qmf_t Xhigh[MAX_NTSRHFG][64]
#ifdef SBR_LOW_POWER
,real_t *deg
@@ -67,12 +67,9 @@
uint8_t first = sbr->t_E[ch][0];
uint8_t last = sbr->t_E[ch][sbr->L_E[ch]];
+
calc_chirp_factors(sbr, ch);
- for (i = first; i < last; i++)
- {
- memset(Xhigh[i + offset], 0, 64 * sizeof(qmf_t));
- }
#ifdef SBR_LOW_POWER
memset(deg, 0, 64*sizeof(real_t));
#endif
@@ -84,8 +81,6 @@
#ifdef SBR_LOW_POWER
calc_prediction_coef_lp(sbr, Xlow, alpha_0, alpha_1, rxx);
calc_aliasing_degree(sbr, rxx, deg);
-#else
- //calc_prediction_coef(sbr, Xlow, alpha_0, alpha_1);
#endif
/* actual HF generation */
@@ -184,11 +179,9 @@
real_t det;
} acorr_coef;
-#define SBR_ABS(A) ((A) < 0) ? -(A) : (A)
-
#ifdef SBR_LOW_POWER
static void auto_correlation(sbr_info *sbr, acorr_coef *ac,
- qmf_t buffer[MAX_NTSRHFG][32],
+ qmf_t buffer[MAX_NTSRHFG][64],
uint8_t bd, uint8_t len)
{
real_t r01 = 0, r02 = 0, r11 = 0;
@@ -204,27 +197,20 @@
#ifdef FIXED_POINT
- /*
- * For computing the covariance matrix and the filter coefficients
- * in fixed point, all values are normalised so that the fixed point
- * values don't overflow.
- */
- for (j = offset-2; j < len + offset; j++)
- {
- maxi = max(SBR_ABS(QMF_RE(buffer[j][bd])>>REAL_BITS), maxi);
- }
+ mask = 0;
- /* find the first power of 2 bigger than max to avoid division */
- pow2 = 1;
- exp = 0;
- while (maxi > pow2)
+ for (j = (offset-2); j < (len + offset); j++)
{
- pow2 <<= 1;
- exp++;
+ real_t x;
+ x = QMF_RE(buffer[j][bd])>>REAL_BITS;
+ mask |= x ^ (x >> 31);
}
+ exp = wl_min_lzc(mask);
+
/* improves accuracy */
- exp -= 1;
+ if (exp > 0)
+ exp -= 1;
for (j = offset; j < len + offset; j++)
{
@@ -264,14 +250,13 @@
ac->det = MUL_R(RE(ac->r11), RE(ac->r22)) - MUL_F(MUL_R(RE(ac->r12), RE(ac->r12)), rel);
}
#else
-static void auto_correlation(sbr_info *sbr, acorr_coef *ac, qmf_t buffer[MAX_NTSRHFG][32],
+static void auto_correlation(sbr_info *sbr, acorr_coef *ac, qmf_t buffer[MAX_NTSRHFG][64],
uint8_t bd, uint8_t len)
{
real_t r01r = 0, r01i = 0, r02r = 0, r02i = 0, r11r = 0;
#ifdef FIXED_POINT
const real_t rel = FRAC_CONST(0.999999); // 1 / (1 + 1e-6f);
- uint32_t maxi = 0;
- uint32_t pow2, exp;
+ uint32_t mask, exp;
#else
const real_t rel = 1 / (1 + 1e-6f);
#endif
@@ -279,28 +264,22 @@
uint8_t offset = sbr->tHFAdj;
#ifdef FIXED_POINT
- /*
- * For computing the covariance matrix and the filter coefficients
- * in fixed point, all values are normalised so that the fixed point
- * values don't overflow.
- */
- for (j = offset-2; j < len + offset; j++)
- {
- maxi = max(SBR_ABS(QMF_RE(buffer[j][bd])>>REAL_BITS), maxi);
- maxi = max(SBR_ABS(QMF_IM(buffer[j][bd])>>REAL_BITS), maxi);
- }
+ mask = 0;
- /* find the first power of 2 bigger than max to avoid division */
- pow2 = 1;
- exp = 0;
- while (maxi > pow2)
+ for (j = (offset-2); j < (len + offset); j++)
{
- pow2 <<= 1;
- exp++;
+ real_t x;
+ x = QMF_RE(buffer[j][bd])>>REAL_BITS;
+ mask |= x ^ (x >> 31);
+ x = QMF_IM(buffer[j][bd])>>REAL_BITS;
+ mask |= x ^ (x >> 31);
}
+ exp = wl_min_lzc(mask);
+
/* improves accuracy */
- exp -= 1;
+ if (exp > 0)
+ exp -= 1;
for (j = offset; j < len + offset; j++)
{
@@ -369,7 +348,7 @@
/* calculate linear prediction coefficients using the covariance method */
#ifndef SBR_LOW_POWER
-static void calc_prediction_coef(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][32],
+static void calc_prediction_coef(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][64],
complex_t *alpha_0, complex_t *alpha_1, uint8_t k)
{
real_t tmp;
@@ -421,7 +400,7 @@
}
}
#else
-static void calc_prediction_coef_lp(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][32],
+static void calc_prediction_coef_lp(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][64],
complex_t *alpha_0, complex_t *alpha_1, real_t *rxx)
{
uint8_t k;
--- a/libfaad/sbr_hfgen.h
+++ b/libfaad/sbr_hfgen.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_hfgen.h,v 1.12 2004/03/10 19:45:42 menno Exp $
+** $Id: sbr_hfgen.h,v 1.16 2004/09/04 14:56:28 menno Exp $
**/
#ifndef __SBR_HFGEN_H__
@@ -32,7 +32,7 @@
extern "C" {
#endif
-void hf_generation(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][32],
+void hf_generation(sbr_info *sbr, qmf_t Xlow[MAX_NTSRHFG][64],
qmf_t Xhigh[MAX_NTSRHFG][64]
#ifdef SBR_LOW_POWER
,real_t *deg
--- a/libfaad/sbr_qmf.c
+++ b/libfaad/sbr_qmf.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_qmf.c,v 1.23 2004/03/27 11:14:49 menno Exp $
+** $Id: sbr_qmf.c,v 1.24 2004/05/17 10:18:03 menno Exp $
**/
#include "common.h"
@@ -65,7 +65,7 @@
}
void sbr_qmf_analysis_32(sbr_info *sbr, qmfa_info *qmfa, const real_t *input,
- qmf_t X[MAX_NTSRHFG][32], uint8_t offset, uint8_t kx)
+ qmf_t X[MAX_NTSRHFG][64], uint8_t offset, uint8_t kx)
{
ALIGN real_t u[64];
#ifndef SBR_LOW_POWER
--- a/libfaad/sbr_qmf.h
+++ b/libfaad/sbr_qmf.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_qmf.h,v 1.16 2004/03/10 19:45:42 menno Exp $
+** $Id: sbr_qmf.h,v 1.20 2004/09/04 14:56:28 menno Exp $
**/
#ifndef __SBR_QMF_H__
@@ -38,7 +38,7 @@
void qmfs_end(qmfs_info *qmfs);
void sbr_qmf_analysis_32(sbr_info *sbr, qmfa_info *qmfa, const real_t *input,
- qmf_t X[MAX_NTSRHFG][32], uint8_t offset, uint8_t kx);
+ qmf_t X[MAX_NTSRHFG][64], uint8_t offset, uint8_t kx);
void sbr_qmf_synthesis_32(sbr_info *sbr, qmfs_info *qmfs, qmf_t X[MAX_NTSRHFG][64],
real_t *output);
void sbr_qmf_synthesis_64(sbr_info *sbr, qmfs_info *qmfs, qmf_t X[MAX_NTSRHFG][64],
--- a/libfaad/sbr_syntax.c
+++ b/libfaad/sbr_syntax.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: sbr_syntax.c,v 1.30 2004/04/03 10:49:15 menno Exp $
+** $Id: sbr_syntax.c,v 1.31 2004/05/17 10:18:03 menno Exp $
**/
#include "common.h"
@@ -384,7 +384,9 @@
sbr_envelope(ld, sbr, 0);
sbr_noise(ld, sbr, 0);
+#ifndef FIXED_POINT
envelope_noise_dequantisation(sbr, 0);
+#endif
memset(sbr->bs_add_harmonic[0], 0, 64*sizeof(uint8_t));
@@ -544,11 +546,13 @@
if (sbr->bs_add_harmonic_flag[1])
sinusoidal_coding(ld, sbr, 1);
}
+#ifndef FIXED_POINT
envelope_noise_dequantisation(sbr, 0);
envelope_noise_dequantisation(sbr, 1);
if (sbr->bs_coupling)
unmap_envelope_noise(sbr);
+#endif
sbr->bs_extended_data = faad_get1bit(ld
DEBUGVAR(1,233,"sbr_channel_pair_element(): bs_extended_data[0]"));
--- a/libfaad/specrec.c
+++ b/libfaad/specrec.c
@@ -1,19 +1,19 @@
/*
** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
** Copyright (C) 2003-2004 M. Bakker, Ahead Software AG, http://www.nero.com
-**
+**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
-**
+**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
-**
+**
** You should have received a copy of the GNU General Public License
-** along with this program; if not, write to the Free Software
+** along with this program; if not, write to the Free Software
** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
**
** Any non-GPL usage of this software or parts of this software is strictly
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: specrec.c,v 1.49 2004/04/03 10:49:15 menno Exp $
+** $Id: specrec.c,v 1.50 2004/05/17 10:18:03 menno Exp $
**/
/*
@@ -55,8 +55,9 @@
/* static function declarations */
-static void quant_to_spec(ic_stream *ics, real_t *spec_data, uint16_t frame_len);
-static uint8_t inverse_quantization(real_t *x_invquant, const int16_t *x_quant, const uint16_t frame_len);
+static uint8_t quant_to_spec(NeAACDecHandle hDecoder,
+ ic_stream *ics, int16_t *quant_data,
+ real_t *spec_data, uint16_t frame_len);
#ifdef LD_DEC
@@ -408,66 +409,6 @@
}
}
-/*
- For ONLY_LONG_SEQUENCE windows (num_window_groups = 1,
- window_group_length[0] = 1) the spectral data is in ascending spectral
- order.
- For the EIGHT_SHORT_SEQUENCE window, the spectral order depends on the
- grouping in the following manner:
- - Groups are ordered sequentially
- - Within a group, a scalefactor band consists of the spectral data of all
- grouped SHORT_WINDOWs for the associated scalefactor window band. To
- clarify via example, the length of a group is in the range of one to eight
- SHORT_WINDOWs.
- - If there are eight groups each with length one (num_window_groups = 8,
- window_group_length[0..7] = 1), the result is a sequence of eight spectra,
- each in ascending spectral order.
- - If there is only one group with length eight (num_window_groups = 1,
- window_group_length[0] = 8), the result is that spectral data of all eight
- SHORT_WINDOWs is interleaved by scalefactor window bands.
- - Within a scalefactor window band, the coefficients are in ascending
- spectral order.
-*/
-static void quant_to_spec(ic_stream *ics, real_t *spec_data, uint16_t frame_len)
-{
- uint8_t g, sfb, win;
- uint16_t width, bin, k, gindex;
-
- ALIGN real_t tmp_spec[1024] = {0};
-
- k = 0;
- gindex = 0;
-
- for (g = 0; g < ics->num_window_groups; g++)
- {
- uint16_t j = 0;
- uint16_t gincrease = 0;
- uint16_t win_inc = ics->swb_offset[ics->num_swb];
-
- for (sfb = 0; sfb < ics->num_swb; sfb++)
- {
- width = ics->swb_offset[sfb+1] - ics->swb_offset[sfb];
-
- for (win = 0; win < ics->window_group_length[g]; win++)
- {
- for (bin = 0; bin < width; bin += 4)
- {
- tmp_spec[gindex+(win*win_inc)+j+bin+0] = spec_data[k+0];
- tmp_spec[gindex+(win*win_inc)+j+bin+1] = spec_data[k+1];
- tmp_spec[gindex+(win*win_inc)+j+bin+2] = spec_data[k+2];
- tmp_spec[gindex+(win*win_inc)+j+bin+3] = spec_data[k+3];
- gincrease += 4;
- k += 4;
- }
- }
- j += width;
- }
- gindex += gincrease;
- }
-
- memcpy(spec_data, tmp_spec, frame_len*sizeof(real_t));
-}
-
/* iquant() *
/* output = sign(input)*abs(input)^(4/3) */
/**/
@@ -474,6 +415,11 @@
static INLINE real_t iquant(int16_t q, const real_t *tab, uint8_t *error)
{
#ifdef FIXED_POINT
+/* For FIXED_POINT the iq_table is prescaled by 3 bits (iq_table[]/8) */
+/* BIG_IQ_TABLE allows you to use the full 8192 value table, if this is not
+ * defined a 1026 value table and interpolation will be used
+ */
+#ifndef BIG_IQ_TABLE
static const real_t errcorr[] = {
REAL_CONST(0), REAL_CONST(1.0/8.0), REAL_CONST(2.0/8.0), REAL_CONST(3.0/8.0),
REAL_CONST(4.0/8.0), REAL_CONST(5.0/8.0), REAL_CONST(6.0/8.0), REAL_CONST(7.0/8.0),
@@ -480,6 +426,7 @@
REAL_CONST(0)
};
real_t x1, x2;
+#endif
int16_t sgn = 1;
if (q < 0)
@@ -491,11 +438,23 @@
if (q < IQ_TABLE_SIZE)
return sgn * tab[q];
+#ifndef BIG_IQ_TABLE
+ if (q >= 8192)
+ {
+ *error = 17;
+ return 0;
+ }
+
/* linear interpolation */
x1 = tab[q>>3];
x2 = tab[(q>>3) + 1];
return sgn * 16 * (MUL_R(errcorr[q&7],(x2-x1)) + x1);
#else
+ *error = 17;
+ return 0;
+#endif
+
+#else
if (q < 0)
{
/* tab contains a value for all possible q [0,8192] */
@@ -515,23 +474,6 @@
#endif
}
-static uint8_t inverse_quantization(real_t *x_invquant, const int16_t *x_quant, const uint16_t frame_len)
-{
- int16_t i;
- uint8_t error = 0; /* Init error flag */
- const real_t *tab = iq_table;
-
- for (i = 0; i < frame_len; i+=4)
- {
- x_invquant[i] = iquant(x_quant[i], tab, &error);
- x_invquant[i+1] = iquant(x_quant[i+1], tab, &error);
- x_invquant[i+2] = iquant(x_quant[i+2], tab, &error);
- x_invquant[i+3] = iquant(x_quant[i+3], tab, &error);
- }
-
- return error;
-}
-
#ifndef FIXED_POINT
ALIGN static const real_t pow2sf_tab[] = {
2.9802322387695313E-008, 5.9604644775390625E-008, 1.1920928955078125E-007,
@@ -558,8 +500,32 @@
};
#endif
-void apply_scalefactors(NeAACDecHandle hDecoder, ic_stream *ics,
- real_t *x_invquant, uint16_t frame_len)
+/* quant_to_spec: perform dequantisation and scaling
+ * and in case of short block it also does the deinterleaving
+ */
+/*
+ For ONLY_LONG_SEQUENCE windows (num_window_groups = 1,
+ window_group_length[0] = 1) the spectral data is in ascending spectral
+ order.
+ For the EIGHT_SHORT_SEQUENCE window, the spectral order depends on the
+ grouping in the following manner:
+ - Groups are ordered sequentially
+ - Within a group, a scalefactor band consists of the spectral data of all
+ grouped SHORT_WINDOWs for the associated scalefactor window band. To
+ clarify via example, the length of a group is in the range of one to eight
+ SHORT_WINDOWs.
+ - If there are eight groups each with length one (num_window_groups = 8,
+ window_group_length[0..7] = 1), the result is a sequence of eight spectra,
+ each in ascending spectral order.
+ - If there is only one group with length eight (num_window_groups = 1,
+ window_group_length[0] = 8), the result is that spectral data of all eight
+ SHORT_WINDOWs is interleaved by scalefactor window bands.
+ - Within a scalefactor window band, the coefficients are in ascending
+ spectral order.
+*/
+static uint8_t quant_to_spec(NeAACDecHandle hDecoder,
+ ic_stream *ics, int16_t *quant_data,
+ real_t *spec_data, uint16_t frame_len)
{
ALIGN static const real_t pow2_table[] =
{
@@ -568,24 +534,28 @@
COEF_CONST(1.4142135623730950488016887242097), /* 2^0.5 */
COEF_CONST(1.6817928305074290860622509524664) /* 2^0.75 */
};
- uint8_t g, sfb;
- uint16_t top;
- int32_t exp, frac;
- uint8_t groups = 0;
- uint16_t nshort = frame_len/8;
+ const real_t *tab = iq_table;
+ uint8_t g, sfb, win;
+ uint16_t width, bin, k, gindex;
+ uint8_t error = 0; /* Init error flag */
+
+
+ k = 0;
+ gindex = 0;
+
for (g = 0; g < ics->num_window_groups; g++)
{
- uint16_t k = 0;
+ uint16_t j = 0;
+ uint16_t gincrease = 0;
+ uint16_t win_inc = ics->swb_offset[ics->num_swb];
- /* using this nshort*groups doesn't hurt long blocks, because
- long blocks only have 1 group, so that means 'groups' is
- always 0 for long blocks
- */
- for (sfb = 0; sfb < ics->max_sfb; sfb++)
+ for (sfb = 0; sfb < ics->num_swb; sfb++)
{
- top = ics->sect_sfb_offset[g][sfb+1];
+ int32_t exp, frac;
+ width = ics->swb_offset[sfb+1] - ics->swb_offset[sfb];
+
/* this could be scalefactor for IS or PNS, those can be negative or bigger then 255 */
/* just ignore them */
if (ics->scale_factors[g][sfb] < 0 || ics->scale_factors[g][sfb] > 255)
@@ -613,79 +583,53 @@
}
#endif
- /* minimum size of a sf band is 4 and always a multiple of 4 */
- for ( ; k < top; k += 4)
+ for (win = 0; win < ics->window_group_length[g]; win++)
{
-#ifdef FIXED_POINT
- if (exp < 0)
+ for (bin = 0; bin < width; bin += 4)
{
- x_invquant[k+(groups*nshort)] >>= -exp;
- x_invquant[k+(groups*nshort)+1] >>= -exp;
- x_invquant[k+(groups*nshort)+2] >>= -exp;
- x_invquant[k+(groups*nshort)+3] >>= -exp;
- } else {
- x_invquant[k+(groups*nshort)] <<= exp;
- x_invquant[k+(groups*nshort)+1] <<= exp;
- x_invquant[k+(groups*nshort)+2] <<= exp;
- x_invquant[k+(groups*nshort)+3] <<= exp;
- }
+#ifndef FIXED_POINT
+ spec_data[gindex+(win*win_inc)+j+bin+0] = iquant(quant_data[k+0], tab, &error) *
+ pow2sf_tab[exp/*+25*/] * pow2_table[frac];
+ spec_data[gindex+(win*win_inc)+j+bin+1] = iquant(quant_data[k+1], tab, &error) *
+ pow2sf_tab[exp/*+25*/] * pow2_table[frac];
+ spec_data[gindex+(win*win_inc)+j+bin+2] = iquant(quant_data[k+2], tab, &error) *
+ pow2sf_tab[exp/*+25*/] * pow2_table[frac];
+ spec_data[gindex+(win*win_inc)+j+bin+3] = iquant(quant_data[k+3], tab, &error) *
+ pow2sf_tab[exp/*+25*/] * pow2_table[frac];
#else
- x_invquant[k+(groups*nshort)] = x_invquant[k+(groups*nshort)] * pow2sf_tab[exp/*+25*/];
- x_invquant[k+(groups*nshort)+1] = x_invquant[k+(groups*nshort)+1] * pow2sf_tab[exp/*+25*/];
- x_invquant[k+(groups*nshort)+2] = x_invquant[k+(groups*nshort)+2] * pow2sf_tab[exp/*+25*/];
- x_invquant[k+(groups*nshort)+3] = x_invquant[k+(groups*nshort)+3] * pow2sf_tab[exp/*+25*/];
+ real_t iq0 = iquant(quant_data[k+0], tab, &error);
+ real_t iq1 = iquant(quant_data[k+1], tab, &error);
+ real_t iq2 = iquant(quant_data[k+2], tab, &error);
+ real_t iq3 = iquant(quant_data[k+3], tab, &error);
+ if (exp < 0)
+ {
+ spec_data[gindex+(win*win_inc)+j+bin+0] = iq0 >>= -exp;
+ spec_data[gindex+(win*win_inc)+j+bin+1] = iq1 >>= -exp;
+ spec_data[gindex+(win*win_inc)+j+bin+2] = iq2 >>= -exp;
+ spec_data[gindex+(win*win_inc)+j+bin+3] = iq3 >>= -exp;
+ } else {
+ spec_data[gindex+(win*win_inc)+j+bin+0] = iq0 <<= exp;
+ spec_data[gindex+(win*win_inc)+j+bin+1] = iq1 <<= exp;
+ spec_data[gindex+(win*win_inc)+j+bin+2] = iq2 <<= exp;
+ spec_data[gindex+(win*win_inc)+j+bin+3] = iq3 <<= exp;
+ }
+ spec_data[gindex+(win*win_inc)+j+bin+0] = MUL_C(spec_data[gindex+(win*win_inc)+j+bin+0],pow2_table[frac]);
+ spec_data[gindex+(win*win_inc)+j+bin+1] = MUL_C(spec_data[gindex+(win*win_inc)+j+bin+1],pow2_table[frac]);
+ spec_data[gindex+(win*win_inc)+j+bin+2] = MUL_C(spec_data[gindex+(win*win_inc)+j+bin+2],pow2_table[frac]);
+ spec_data[gindex+(win*win_inc)+j+bin+3] = MUL_C(spec_data[gindex+(win*win_inc)+j+bin+3],pow2_table[frac]);
#endif
- x_invquant[k+(groups*nshort)] = MUL_C(x_invquant[k+(groups*nshort)],pow2_table[frac]);
- x_invquant[k+(groups*nshort)+1] = MUL_C(x_invquant[k+(groups*nshort)+1],pow2_table[frac]);
- x_invquant[k+(groups*nshort)+2] = MUL_C(x_invquant[k+(groups*nshort)+2],pow2_table[frac]);
- x_invquant[k+(groups*nshort)+3] = MUL_C(x_invquant[k+(groups*nshort)+3],pow2_table[frac]);
- }
- }
- groups += ics->window_group_length[g];
- }
-}
-
-#ifdef USE_SSE
-void apply_scalefactors_sse(NeAACDecHandle hDecoder, ic_stream *ics,
- real_t *x_invquant, uint16_t frame_len)
-{
- uint8_t g, sfb;
- uint16_t top;
- int32_t exp, frac;
- uint8_t groups = 0;
- uint16_t nshort = frame_len/8;
-
- for (g = 0; g < ics->num_window_groups; g++)
- {
- uint16_t k = 0;
-
- /* using this nshort*groups doesn't hurt long blocks, because
- long blocks only have 1 group, so that means 'groups' is
- always 0 for long blocks
- */
- for (sfb = 0; sfb < ics->max_sfb; sfb++)
- {
- top = ics->sect_sfb_offset[g][sfb+1];
-
- exp = (ics->scale_factors[g][sfb] /* - 100 */) >> 2;
- frac = (ics->scale_factors[g][sfb] /* - 100 */) & 3;
-
- /* minimum size of a sf band is 4 and always a multiple of 4 */
- for ( ; k < top; k += 4)
- {
- __m128 m1 = _mm_load_ps(&x_invquant[k+(groups*nshort)]);
- __m128 m2 = _mm_load_ps1(&pow2sf_tab[exp /*+25*/]);
- __m128 m3 = _mm_load_ps1(&pow2_table[frac /* + 3*/]);
- __m128 m4 = _mm_mul_ps(m1, m2);
- __m128 m5 = _mm_mul_ps(m3, m4);
- _mm_store_ps(&x_invquant[k+(groups*nshort)], m5);
+ gincrease += 4;
+ k += 4;
+ }
}
+ j += width;
}
- groups += ics->window_group_length[g];
+ gindex += gincrease;
}
+
+ return error;
}
-#endif
static uint8_t allocate_single_channel(NeAACDecHandle hDecoder, uint8_t channel,
uint8_t output_channels)
@@ -917,22 +861,11 @@
}
- /* inverse quantization */
- retval = inverse_quantization(spec_coef, spec_data, hDecoder->frameLength);
+ /* dequantisation and scaling */
+ retval = quant_to_spec(hDecoder, ics, spec_data, spec_coef, hDecoder->frameLength);
if (retval > 0)
return retval;
- /* apply scalefactors */
-#ifndef USE_SSE
- apply_scalefactors(hDecoder, ics, spec_coef, hDecoder->frameLength);
-#else
- hDecoder->apply_sf_func(hDecoder, ics, spec_coef, hDecoder->frameLength);
-#endif
-
- /* deinterleave short block grouping */
- if (ics->window_sequence == EIGHT_SHORT_SEQUENCE)
- quant_to_spec(ics, spec_coef, hDecoder->frameLength);
-
#ifdef PROFILE
count = faad_get_ts() - count;
hDecoder->requant_cycles += count;
@@ -991,7 +924,6 @@
drc_decode(hDecoder->drc, spec_coef);
}
-
/* filter bank */
#ifdef SSR_DEC
if (hDecoder->object_type != SSR)
@@ -1053,7 +985,7 @@
/* check if any of the PS tools is used */
#if (defined(PS_DEC) || defined(DRM_PS))
- if (hDecoder->ps_used[hDecoder->fr_ch_ele] == 0)
+ if (hDecoder->ps_used[ele] == 0)
{
#endif
retval = sbrDecodeSingleFrame(hDecoder->sbr[ele], hDecoder->time_out[ch],
@@ -1103,7 +1035,7 @@
#endif
if (hDecoder->element_alloced[hDecoder->fr_ch_ele] == 0)
{
- retval = allocate_channel_pair(hDecoder, cpe->channel, cpe->paired_channel);
+ retval = allocate_channel_pair(hDecoder, cpe->channel, (uint8_t)cpe->paired_channel);
if (retval > 0)
return retval;
@@ -1110,29 +1042,13 @@
hDecoder->element_alloced[hDecoder->fr_ch_ele] = 1;
}
- /* inverse quantization */
- retval = inverse_quantization(spec_coef1, spec_data1, hDecoder->frameLength);
+ /* dequantisation and scaling */
+ retval = quant_to_spec(hDecoder, ics1, spec_data1, spec_coef1, hDecoder->frameLength);
if (retval > 0)
return retval;
-
- retval = inverse_quantization(spec_coef2, spec_data2, hDecoder->frameLength);
+ retval = quant_to_spec(hDecoder, ics2, spec_data2, spec_coef2, hDecoder->frameLength);
if (retval > 0)
return retval;
-
- /* apply scalefactors */
-#ifndef USE_SSE
- apply_scalefactors(hDecoder, ics1, spec_coef1, hDecoder->frameLength);
- apply_scalefactors(hDecoder, ics2, spec_coef2, hDecoder->frameLength);
-#else
- hDecoder->apply_sf_func(hDecoder, ics1, spec_coef1, hDecoder->frameLength);
- hDecoder->apply_sf_func(hDecoder, ics2, spec_coef2, hDecoder->frameLength);
-#endif
-
- /* deinterleave short block grouping */
- if (ics1->window_sequence == EIGHT_SHORT_SEQUENCE)
- quant_to_spec(ics1, spec_coef1, hDecoder->frameLength);
- if (ics2->window_sequence == EIGHT_SHORT_SEQUENCE)
- quant_to_spec(ics2, spec_coef2, hDecoder->frameLength);
#ifdef PROFILE
count = faad_get_ts() - count;
--- a/libfaad/specrec.h
+++ b/libfaad/specrec.h
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: specrec.h,v 1.25 2004/03/02 20:09:58 menno Exp $
+** $Id: specrec.h,v 1.28 2004/09/04 14:56:29 menno Exp $
**/
#ifndef __SPECREC_H__
@@ -35,12 +35,6 @@
#include "syntax.h"
uint8_t window_grouping_info(NeAACDecHandle hDecoder, ic_stream *ics);
-void apply_scalefactors(NeAACDecHandle hDecoder, ic_stream *ics, real_t *x_invquant,
- uint16_t frame_len);
-#ifdef USE_SSE
-void apply_scalefactors_sse(NeAACDecHandle hDecoder, ic_stream *ics, real_t *x_invquant,
- uint16_t frame_len);
-#endif
uint8_t reconstruct_channel_pair(NeAACDecHandle hDecoder, ic_stream *ics1, ic_stream *ics2,
element *cpe, int16_t *spec_data1, int16_t *spec_data2);
uint8_t reconstruct_single_channel(NeAACDecHandle hDecoder, ic_stream *ics, element *sce,
--- a/libfaad/syntax.c
+++ b/libfaad/syntax.c
@@ -22,7 +22,7 @@
** Commercial non-GPL licensing of this software is possible.
** For more info contact Ahead Software through [email protected].
**
-** $Id: syntax.c,v 1.78 2004/04/03 10:49:15 menno Exp $
+** $Id: syntax.c,v 1.79 2004/05/17 10:18:03 menno Exp $
**/
/*
@@ -852,8 +852,14 @@
{
pul->pulse_offset[i] = (uint8_t)faad_getbits(ld, 5
DEBUGVAR(1,58,"pulse_data(): pulse_offset"));
+#if 0
+ printf("%d\n", pul->pulse_offset[i]);
+#endif
pul->pulse_amp[i] = (uint8_t)faad_getbits(ld, 4
DEBUGVAR(1,59,"pulse_data(): pulse_amp"));
+#if 0
+ printf("%d\n", pul->pulse_amp[i]);
+#endif
}
return 0;
@@ -1589,6 +1595,10 @@
ics->sect_cb[g][i] = (uint8_t)faad_getbits(ld, sect_cb_bits
DEBUGVAR(1,71,"section_data(): sect_cb"));
+#if 0
+ printf("%d\n", ics->sect_cb[g][i]);
+#endif
+
if (ics->sect_cb[g][i] == NOISE_HCB)
ics->noise_used = 1;
@@ -1624,6 +1634,13 @@
ics->sect_start[g][i] = k;
ics->sect_end[g][i] = k + sect_len;
+#if 0
+ printf("%d\n", ics->sect_start[g][i]);
+#endif
+#if 0
+ printf("%d\n", ics->sect_end[g][i]);
+#endif
+
if (k + sect_len >= 8*15)
return 15;
if (i >= 8*15)
@@ -1630,7 +1647,12 @@
return 15;
for (sfb = k; sfb < k + sect_len; sfb++)
+ {
ics->sfb_cb[g][sfb] = ics->sect_cb[g][i];
+#if 0
+ printf("%d\n", ics->sfb_cb[g][sfb]);
+#endif
+ }
#if 0
printf(" %6d %6d %6d\n",
@@ -1643,6 +1665,9 @@
i++;
}
ics->num_sec[g] = i;
+#if 0
+ printf("%d\n", ics->num_sec[g]);
+#endif
}
#if 0
@@ -1681,6 +1706,10 @@
{
case ZERO_HCB: /* zero book */
ics->scale_factors[g][sfb] = 0;
+//#define SF_PRINT
+#ifdef SF_PRINT
+ printf("%d\n", ics->scale_factors[g][sfb]);
+#endif
break;
case INTENSITY_HCB: /* intensity books */
case INTENSITY_HCB2:
@@ -1689,6 +1718,9 @@
t = huffman_scale_factor(ld);
is_position += (t - 60);
ics->scale_factors[g][sfb] = is_position;
+#ifdef SF_PRINT
+ printf("%d\n", ics->scale_factors[g][sfb]);
+#endif
break;
case NOISE_HCB: /* noise books */
@@ -1705,6 +1737,9 @@
}
noise_energy += t;
ics->scale_factors[g][sfb] = noise_energy;
+#ifdef SF_PRINT
+ printf("%d\n", ics->scale_factors[g][sfb]);
+#endif
break;
default: /* spectral books */
@@ -1719,6 +1754,9 @@
if (scale_factor < 0 || scale_factor > 255)
return 4;
ics->scale_factors[g][sfb] = scale_factor;
+#ifdef SF_PRINT
+ printf("%d\n", ics->scale_factors[g][sfb]);
+#endif
break;
}
@@ -1778,6 +1816,9 @@
{
tns->n_filt[w] = (uint8_t)faad_getbits(ld, n_filt_bits
DEBUGVAR(1,74,"tns_data(): n_filt"));
+#if 0
+ printf("%d\n", tns->n_filt[w]);
+#endif
if (tns->n_filt[w])
{
@@ -1788,6 +1829,9 @@
} else {
start_coef_bits = 3;
}
+#if 0
+ printf("%d\n", tns->coef_res[w]);
+#endif
}
for (filt = 0; filt < tns->n_filt[w]; filt++)
@@ -1794,14 +1838,26 @@
{
tns->length[w][filt] = (uint8_t)faad_getbits(ld, length_bits
DEBUGVAR(1,76,"tns_data(): length"));
+#if 0
+ printf("%d\n", tns->length[w][filt]);
+#endif
tns->order[w][filt] = (uint8_t)faad_getbits(ld, order_bits
DEBUGVAR(1,77,"tns_data(): order"));
+#if 0
+ printf("%d\n", tns->order[w][filt]);
+#endif
if (tns->order[w][filt])
{
tns->direction[w][filt] = faad_get1bit(ld
DEBUGVAR(1,78,"tns_data(): direction"));
+#if 0
+ printf("%d\n", tns->direction[w][filt]);
+#endif
tns->coef_compress[w][filt] = faad_get1bit(ld
DEBUGVAR(1,79,"tns_data(): coef_compress"));
+#if 0
+ printf("%d\n", tns->coef_compress[w][filt]);
+#endif
coef_bits = start_coef_bits - tns->coef_compress[w][filt];
for (i = 0; i < tns->order[w][filt]; i++)
@@ -1808,6 +1864,9 @@
{
tns->coef[w][filt][i] = (uint8_t)faad_getbits(ld, coef_bits
DEBUGVAR(1,80,"tns_data(): coef"));
+#if 0
+ printf("%d\n", tns->coef[w][filt][i]);
+#endif
}
}
}
@@ -1910,6 +1969,16 @@
case NOISE_HCB:
case INTENSITY_HCB:
case INTENSITY_HCB2:
+//#define SD_PRINT
+#ifdef SD_PRINT
+ {
+ int j;
+ for (j = ics->sect_sfb_offset[g][ics->sect_start[g][i]]; j < ics->sect_sfb_offset[g][ics->sect_end[g][i]]; j++)
+ {
+ printf("%d\n", 0);
+ }
+ }
+#endif
p += (ics->sect_sfb_offset[g][ics->sect_end[g][i]] -
ics->sect_sfb_offset[g][ics->sect_start[g][i]]);
break;
@@ -1919,6 +1988,15 @@
{
if ((result = huffman_spectral_data(sect_cb, ld, &spectral_data[p])) > 0)
return result;
+#ifdef SD_PRINT
+ {
+ int j;
+ for (j = p; j < p+inc; j++)
+ {
+ printf("%d\n", spectral_data[j]);
+ }
+ }
+#endif
p += inc;
}
break;