synth_filter.c
上传用户:wstnjxml
上传日期:2014-04-03
资源大小:7248k
文件大小:23k
源码类别:

Windows CE

开发平台:

C/C++

  1. /*
  2.   Copyright (c) 2005, The Musepack Development Team
  3.   All rights reserved.
  4.   Redistribution and use in source and binary forms, with or without
  5.   modification, are permitted provided that the following conditions are
  6.   met:
  7.   * Redistributions of source code must retain the above copyright
  8.   notice, this list of conditions and the following disclaimer.
  9.   * Redistributions in binary form must reproduce the above
  10.   copyright notice, this list of conditions and the following
  11.   disclaimer in the documentation and/or other materials provided
  12.   with the distribution.
  13.   * Neither the name of the The Musepack Development Team nor the
  14.   names of its contributors may be used to endorse or promote
  15.   products derived from this software without specific prior
  16.   written permission.
  17.   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  18.   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  19.   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  20.   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  21.   OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  22.   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  23.   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  24.   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  25.   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  26.   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  27.   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  28. */
  29. /// file synth_filter.c
  30. /// Synthesis functions.
  31. /// todo document me
  32. #include "musepack/musepack.h"
  33. #include "musepack/internal.h"
  34. //typedef mpc_int32_t ptrdiff_t;
  35. /* C O N S T A N T S */
  36. #undef _
  37. #define MPC_FIXED_POINT_SYNTH_FIX 2
  38. #ifdef MPC_FIXED_POINT
  39. #define _(value)  MPC_MAKE_FRACT_CONST((double)value/(double)(0x40000))
  40. #else
  41. #define _(value)  MAKE_MPC_SAMPLE((double)value/(double)(0x10000))
  42. #endif
  43. static const MPC_SAMPLE_FORMAT  Di_opt [32] [16] = {
  44.     { _(  0), _( -29), _( 213), _( -459), _( 2037), _(-5153), _(  6574), _(-37489), _(75038), _(37489), _(6574), _( 5153), _(2037), _( 459), _(213), _(29) },
  45.     { _( -1), _( -31), _( 218), _( -519), _( 2000), _(-5517), _(  5959), _(-39336), _(74992), _(35640), _(7134), _( 4788), _(2063), _( 401), _(208), _(26) },
  46.     { _( -1), _( -35), _( 222), _( -581), _( 1952), _(-5879), _(  5288), _(-41176), _(74856), _(33791), _(7640), _( 4425), _(2080), _( 347), _(202), _(24) },
  47.     { _( -1), _( -38), _( 225), _( -645), _( 1893), _(-6237), _(  4561), _(-43006), _(74630), _(31947), _(8092), _( 4063), _(2087), _( 294), _(196), _(21) },
  48.     { _( -1), _( -41), _( 227), _( -711), _( 1822), _(-6589), _(  3776), _(-44821), _(74313), _(30112), _(8492), _( 3705), _(2085), _( 244), _(190), _(19) },
  49.     { _( -1), _( -45), _( 228), _( -779), _( 1739), _(-6935), _(  2935), _(-46617), _(73908), _(28289), _(8840), _( 3351), _(2075), _( 197), _(183), _(17) },
  50.     { _( -1), _( -49), _( 228), _( -848), _( 1644), _(-7271), _(  2037), _(-48390), _(73415), _(26482), _(9139), _( 3004), _(2057), _( 153), _(176), _(16) },
  51.     { _( -2), _( -53), _( 227), _( -919), _( 1535), _(-7597), _(  1082), _(-50137), _(72835), _(24694), _(9389), _( 2663), _(2032), _( 111), _(169), _(14) },
  52.     { _( -2), _( -58), _( 224), _( -991), _( 1414), _(-7910), _(    70), _(-51853), _(72169), _(22929), _(9592), _( 2330), _(2001), _(  72), _(161), _(13) },
  53.     { _( -2), _( -63), _( 221), _(-1064), _( 1280), _(-8209), _(  -998), _(-53534), _(71420), _(21189), _(9750), _( 2006), _(1962), _(  36), _(154), _(11) },
  54.     { _( -2), _( -68), _( 215), _(-1137), _( 1131), _(-8491), _( -2122), _(-55178), _(70590), _(19478), _(9863), _( 1692), _(1919), _(   2), _(147), _(10) },
  55.     { _( -3), _( -73), _( 208), _(-1210), _(  970), _(-8755), _( -3300), _(-56778), _(69679), _(17799), _(9935), _( 1388), _(1870), _( -29), _(139), _( 9) },
  56.     { _( -3), _( -79), _( 200), _(-1283), _(  794), _(-8998), _( -4533), _(-58333), _(68692), _(16155), _(9966), _( 1095), _(1817), _( -57), _(132), _( 8) },
  57.     { _( -4), _( -85), _( 189), _(-1356), _(  605), _(-9219), _( -5818), _(-59838), _(67629), _(14548), _(9959), _(  814), _(1759), _( -83), _(125), _( 7) },
  58.     { _( -4), _( -91), _( 177), _(-1428), _(  402), _(-9416), _( -7154), _(-61289), _(66494), _(12980), _(9916), _(  545), _(1698), _(-106), _(117), _( 7) },
  59.     { _( -5), _( -97), _( 163), _(-1498), _(  185), _(-9585), _( -8540), _(-62684), _(65290), _(11455), _(9838), _(  288), _(1634), _(-127), _(111), _( 6) },
  60.     { _( -5), _(-104), _( 146), _(-1567), _(  -45), _(-9727), _( -9975), _(-64019), _(64019), _( 9975), _(9727), _(   45), _(1567), _(-146), _(104), _( 5) },
  61.     { _( -6), _(-111), _( 127), _(-1634), _( -288), _(-9838), _(-11455), _(-65290), _(62684), _( 8540), _(9585), _( -185), _(1498), _(-163), _( 97), _( 5) },
  62.     { _( -7), _(-117), _( 106), _(-1698), _( -545), _(-9916), _(-12980), _(-66494), _(61289), _( 7154), _(9416), _( -402), _(1428), _(-177), _( 91), _( 4) },
  63.     { _( -7), _(-125), _(  83), _(-1759), _( -814), _(-9959), _(-14548), _(-67629), _(59838), _( 5818), _(9219), _( -605), _(1356), _(-189), _( 85), _( 4) },
  64.     { _( -8), _(-132), _(  57), _(-1817), _(-1095), _(-9966), _(-16155), _(-68692), _(58333), _( 4533), _(8998), _( -794), _(1283), _(-200), _( 79), _( 3) },
  65.     { _( -9), _(-139), _(  29), _(-1870), _(-1388), _(-9935), _(-17799), _(-69679), _(56778), _( 3300), _(8755), _( -970), _(1210), _(-208), _( 73), _( 3) },
  66.     { _(-10), _(-147), _(  -2), _(-1919), _(-1692), _(-9863), _(-19478), _(-70590), _(55178), _( 2122), _(8491), _(-1131), _(1137), _(-215), _( 68), _( 2) },
  67.     { _(-11), _(-154), _( -36), _(-1962), _(-2006), _(-9750), _(-21189), _(-71420), _(53534), _(  998), _(8209), _(-1280), _(1064), _(-221), _( 63), _( 2) },
  68.     { _(-13), _(-161), _( -72), _(-2001), _(-2330), _(-9592), _(-22929), _(-72169), _(51853), _(  -70), _(7910), _(-1414), _( 991), _(-224), _( 58), _( 2) },
  69.     { _(-14), _(-169), _(-111), _(-2032), _(-2663), _(-9389), _(-24694), _(-72835), _(50137), _(-1082), _(7597), _(-1535), _( 919), _(-227), _( 53), _( 2) },
  70.     { _(-16), _(-176), _(-153), _(-2057), _(-3004), _(-9139), _(-26482), _(-73415), _(48390), _(-2037), _(7271), _(-1644), _( 848), _(-228), _( 49), _( 1) },
  71.     { _(-17), _(-183), _(-197), _(-2075), _(-3351), _(-8840), _(-28289), _(-73908), _(46617), _(-2935), _(6935), _(-1739), _( 779), _(-228), _( 45), _( 1) },
  72.     { _(-19), _(-190), _(-244), _(-2085), _(-3705), _(-8492), _(-30112), _(-74313), _(44821), _(-3776), _(6589), _(-1822), _( 711), _(-227), _( 41), _( 1) },
  73.     { _(-21), _(-196), _(-294), _(-2087), _(-4063), _(-8092), _(-31947), _(-74630), _(43006), _(-4561), _(6237), _(-1893), _( 645), _(-225), _( 38), _( 1) },
  74.     { _(-24), _(-202), _(-347), _(-2080), _(-4425), _(-7640), _(-33791), _(-74856), _(41176), _(-5288), _(5879), _(-1952), _( 581), _(-222), _( 35), _( 1) },
  75.     { _(-26), _(-208), _(-401), _(-2063), _(-4788), _(-7134), _(-35640), _(-74992), _(39336), _(-5959), _(5517), _(-2000), _( 519), _(-218), _( 31), _( 1) }
  76. };
  77. #undef  _
  78. static void Calculate_New_V ( const MPC_SAMPLE_FORMAT * Sample, MPC_SAMPLE_FORMAT * V )
  79. {
  80.     // Calculating new V-buffer values for left channel
  81.     // calculate new V-values (ISO-11172-3, p. 39)
  82.     // based upon fast-MDCT algorithm by Byeong Gi Lee
  83.     /*static*/ MPC_SAMPLE_FORMAT A00, A01, A02, A03, A04, A05, A06, A07, A08, A09, A10, A11, A12, A13, A14, A15;
  84.     /*static*/ MPC_SAMPLE_FORMAT B00, B01, B02, B03, B04, B05, B06, B07, B08, B09, B10, B11, B12, B13, B14, B15;
  85.     MPC_SAMPLE_FORMAT tmp;
  86.     A00 = Sample[ 0] + Sample[31];
  87.     A01 = Sample[ 1] + Sample[30];
  88.     A02 = Sample[ 2] + Sample[29];
  89.     A03 = Sample[ 3] + Sample[28];
  90.     A04 = Sample[ 4] + Sample[27];
  91.     A05 = Sample[ 5] + Sample[26];
  92.     A06 = Sample[ 6] + Sample[25];
  93.     A07 = Sample[ 7] + Sample[24];
  94.     A08 = Sample[ 8] + Sample[23];
  95.     A09 = Sample[ 9] + Sample[22];
  96.     A10 = Sample[10] + Sample[21];
  97.     A11 = Sample[11] + Sample[20];
  98.     A12 = Sample[12] + Sample[19];
  99.     A13 = Sample[13] + Sample[18];
  100.     A14 = Sample[14] + Sample[17];
  101.     A15 = Sample[15] + Sample[16];
  102.     B00 = A00 + A15;
  103.     B01 = A01 + A14;
  104.     B02 = A02 + A13;
  105.     B03 = A03 + A12;
  106.     B04 = A04 + A11;
  107.     B05 = A05 + A10;
  108.     B06 = A06 + A09;
  109.     B07 = A07 + A08;;
  110.     B08 = MPC_SCALE_CONST((A00 - A15) , 0.5024192929f , 31);
  111.     B09 = MPC_SCALE_CONST((A01 - A14) , 0.5224986076f , 31);
  112.     B10 = MPC_SCALE_CONST((A02 - A13) , 0.5669440627f , 31);
  113.     B11 = MPC_SCALE_CONST((A03 - A12) , 0.6468217969f , 31);
  114.     B12 = MPC_SCALE_CONST((A04 - A11) , 0.7881546021f , 31);
  115.     B13 = MPC_SCALE_CONST((A05 - A10) , 1.0606776476f , 30);
  116.     B14 = MPC_SCALE_CONST((A06 - A09) , 1.7224471569f , 30);
  117.     B15 = MPC_SCALE_CONST((A07 - A08) , 5.1011486053f , 28);
  118.     A00 =  B00 + B07;
  119.     A01 =  B01 + B06;
  120.     A02 =  B02 + B05;
  121.     A03 =  B03 + B04;
  122.     A04 = MPC_SCALE_CONST((B00 - B07) , 0.5097956061f , 31);
  123.     A05 = MPC_SCALE_CONST((B01 - B06) , 0.6013448834f , 31);
  124.     A06 = MPC_SCALE_CONST((B02 - B05) , 0.8999761939f , 31);
  125.     A07 = MPC_SCALE_CONST((B03 - B04) , 2.5629155636f , 29);
  126.     A08 =  B08 + B15;
  127.     A09 =  B09 + B14;
  128.     A10 =  B10 + B13;
  129.     A11 =  B11 + B12;
  130.     A12 = MPC_SCALE_CONST((B08 - B15) , 0.5097956061f , 31);
  131.     A13 = MPC_SCALE_CONST((B09 - B14) , 0.6013448834f , 31);
  132.     A14 = MPC_SCALE_CONST((B10 - B13) , 0.8999761939f , 31);
  133.     A15 = MPC_SCALE_CONST((B11 - B12) , 2.5629155636f , 29);
  134.     B00 =  A00 + A03;
  135.     B01 =  A01 + A02;
  136.     B02 = MPC_MULTIPLY_FRACT_CONST_FIX((A00 - A03) , 0.5411961079f , 1);
  137.     B03 = MPC_MULTIPLY_FRACT_CONST_FIX((A01 - A02) , 1.3065630198f , 2);
  138.     B04 =  A04 + A07;
  139.     B05 =  A05 + A06;
  140.     B06 = MPC_MULTIPLY_FRACT_CONST_FIX((A04 - A07) , 0.5411961079f , 1);
  141.     B07 = MPC_MULTIPLY_FRACT_CONST_FIX((A05 - A06) , 1.3065630198f , 2);
  142.     B08 =  A08 + A11;
  143.     B09 =  A09 + A10;
  144.     B10 = MPC_MULTIPLY_FRACT_CONST_FIX((A08 - A11) , 0.5411961079f , 1);
  145.     B11 = MPC_MULTIPLY_FRACT_CONST_FIX((A09 - A10) , 1.3065630198f , 2);
  146.     B12 =  A12 + A15;
  147.     B13 =  A13 + A14;
  148.     B14 = MPC_MULTIPLY_FRACT_CONST_FIX((A12 - A15) , 0.5411961079f , 1);
  149.     B15 = MPC_MULTIPLY_FRACT_CONST_FIX((A13 - A14) , 1.3065630198f , 2);
  150.     A00 =  B00 + B01;
  151.     A01 = MPC_MULTIPLY_FRACT_CONST_FIX((B00 - B01) , 0.7071067691f , 1);
  152.     A02 =  B02 + B03;
  153.     A03 = MPC_MULTIPLY_FRACT_CONST_FIX((B02 - B03) , 0.7071067691f , 1);
  154.     A04 =  B04 + B05;
  155.     A05 = MPC_MULTIPLY_FRACT_CONST_FIX((B04 - B05) , 0.7071067691f , 1);
  156.     A06 =  B06 + B07;
  157.     A07 = MPC_MULTIPLY_FRACT_CONST_FIX((B06 - B07) , 0.7071067691f , 1);
  158.     A08 =  B08 + B09;
  159.     A09 = MPC_MULTIPLY_FRACT_CONST_FIX((B08 - B09) , 0.7071067691f , 1);
  160.     A10 =  B10 + B11;
  161.     A11 = MPC_MULTIPLY_FRACT_CONST_FIX((B10 - B11) , 0.7071067691f , 1);
  162.     A12 =  B12 + B13;
  163.     A13 = MPC_MULTIPLY_FRACT_CONST_FIX((B12 - B13) , 0.7071067691f , 1);
  164.     A14 =  B14 + B15;
  165.     A15 = MPC_MULTIPLY_FRACT_CONST_FIX((B14 - B15) , 0.7071067691f , 1);
  166.     V[48] = -A00;
  167.     V[ 0] =  A01;
  168.     V[40] = -A02 - (V[ 8] = A03);
  169.     V[36] = -((V[ 4] = A05 + (V[12] = A07)) + A06);
  170.     V[44] = - A04 - A06 - A07;
  171.     V[ 6] = (V[10] = A11 + (V[14] = A15)) + A13;
  172.     V[38] = (V[34] = -(V[ 2] = A09 + A13 + A15) - A14) + A09 - A10 - A11;
  173.     V[46] = (tmp = -(A12 + A14 + A15)) - A08;
  174.     V[42] = tmp - A10 - A11;
  175.     A00 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 0] - Sample[31]) , 0.5006030202f ,     MPC_FIXED_POINT_SYNTH_FIX);
  176.     A01 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 1] - Sample[30]) , 0.5054709315f ,     MPC_FIXED_POINT_SYNTH_FIX);
  177.     A02 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 2] - Sample[29]) , 0.5154473186f ,     MPC_FIXED_POINT_SYNTH_FIX);
  178.     A03 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 3] - Sample[28]) , 0.5310425758f ,     MPC_FIXED_POINT_SYNTH_FIX);
  179.     A04 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 4] - Sample[27]) , 0.5531039238f ,     MPC_FIXED_POINT_SYNTH_FIX);
  180.     A05 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 5] - Sample[26]) , 0.5829349756f ,     MPC_FIXED_POINT_SYNTH_FIX);
  181.     A06 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 6] - Sample[25]) , 0.6225041151f ,     MPC_FIXED_POINT_SYNTH_FIX);
  182.     A07 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 7] - Sample[24]) , 0.6748083234f ,     MPC_FIXED_POINT_SYNTH_FIX);
  183.     A08 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 8] - Sample[23]) , 0.7445362806f ,     MPC_FIXED_POINT_SYNTH_FIX);
  184.     A09 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[ 9] - Sample[22]) , 0.8393496275f ,     MPC_FIXED_POINT_SYNTH_FIX);
  185.     A10 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[10] - Sample[21]) , 0.9725682139f ,     MPC_FIXED_POINT_SYNTH_FIX);
  186. #if MPC_FIXED_POINT_SYNTH_FIX>=2
  187.     A11 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[11] - Sample[20]) , 1.1694399118f ,     MPC_FIXED_POINT_SYNTH_FIX);
  188.     A12 = MPC_MULTIPLY_FRACT_CONST_SHR((Sample[12] - Sample[19]) , 1.4841645956f ,     MPC_FIXED_POINT_SYNTH_FIX);
  189. #else
  190.     A11 = MPC_SCALE_CONST_SHR         ((Sample[11] - Sample[20]) , 1.1694399118f , 30, MPC_FIXED_POINT_SYNTH_FIX);
  191.     A12 = MPC_SCALE_CONST_SHR         ((Sample[12] - Sample[19]) , 1.4841645956f , 30, MPC_FIXED_POINT_SYNTH_FIX);
  192. #endif
  193.     A13 = MPC_SCALE_CONST_SHR         ((Sample[13] - Sample[18]) , 2.0577809811f , 29, MPC_FIXED_POINT_SYNTH_FIX);
  194.     A14 = MPC_SCALE_CONST_SHR         ((Sample[14] - Sample[17]) , 3.4076085091f , 29, MPC_FIXED_POINT_SYNTH_FIX);
  195.     A15 = MPC_SCALE_CONST_SHR         ((Sample[15] - Sample[16]) , 10.1900081635f, 27 ,MPC_FIXED_POINT_SYNTH_FIX);
  196.     B00 =  A00 + A15;
  197.     B01 =  A01 + A14;
  198.     B02 =  A02 + A13;
  199.     B03 =  A03 + A12;
  200.     B04 =  A04 + A11;
  201.     B05 =  A05 + A10;
  202.     B06 =  A06 + A09;
  203.     B07 =  A07 + A08;
  204.     B08 = MPC_SCALE_CONST((A00 - A15) , 0.5024192929f , 31);
  205.     B09 = MPC_SCALE_CONST((A01 - A14) , 0.5224986076f , 31);
  206.     B10 = MPC_SCALE_CONST((A02 - A13) , 0.5669440627f , 31);
  207.     B11 = MPC_SCALE_CONST((A03 - A12) , 0.6468217969f , 31);
  208.     B12 = MPC_SCALE_CONST((A04 - A11) , 0.7881546021f , 31);
  209.     B13 = MPC_SCALE_CONST((A05 - A10) , 1.0606776476f , 30);
  210.     B14 = MPC_SCALE_CONST((A06 - A09) , 1.7224471569f , 30);
  211.     B15 = MPC_SCALE_CONST((A07 - A08) , 5.1011486053f , 28);
  212.     A00 =  B00 + B07;
  213.     A01 =  B01 + B06;
  214.     A02 =  B02 + B05;
  215.     A03 =  B03 + B04;
  216.     A04 = MPC_SCALE_CONST((B00 - B07) , 0.5097956061f , 31);
  217.     A05 = MPC_SCALE_CONST((B01 - B06) , 0.6013448834f , 31);
  218.     A06 = MPC_SCALE_CONST((B02 - B05) , 0.8999761939f , 31);
  219.     A07 = MPC_SCALE_CONST((B03 - B04) , 2.5629155636f , 29);
  220.     A08 =  B08 + B15;
  221.     A09 =  B09 + B14;
  222.     A10 =  B10 + B13;
  223.     A11 =  B11 + B12;
  224.     A12 = MPC_SCALE_CONST((B08 - B15) , 0.5097956061f , 31);
  225.     A13 = MPC_SCALE_CONST((B09 - B14) , 0.6013448834f , 31);
  226.     A14 = MPC_SCALE_CONST((B10 - B13) , 0.8999761939f , 31);
  227.     A15 = MPC_SCALE_CONST((B11 - B12) , 2.5629155636f , 29);
  228.     B00 =  A00 + A03;
  229.     B01 =  A01 + A02;
  230.     B02 = MPC_SCALE_CONST((A00 - A03) , 0.5411961079f , 31);
  231.     B03 = MPC_SCALE_CONST((A01 - A02) , 1.3065630198f , 30);
  232.     B04 =  A04 + A07;
  233.     B05 =  A05 + A06;
  234.     B06 = MPC_SCALE_CONST((A04 - A07) , 0.5411961079f , 31);
  235.     B07 = MPC_SCALE_CONST((A05 - A06) , 1.3065630198f , 30);
  236.     B08 =  A08 + A11;
  237.     B09 =  A09 + A10;
  238.     B10 = MPC_SCALE_CONST((A08 - A11) , 0.5411961079f , 31);
  239.     B11 = MPC_SCALE_CONST((A09 - A10) , 1.3065630198f , 30);
  240.     B12 =  A12 + A15;
  241.     B13 =  A13 + A14;
  242.     B14 = MPC_SCALE_CONST((A12 - A15) , 0.5411961079f , 31);
  243.     B15 = MPC_SCALE_CONST((A13 - A14) , 1.3065630198f , 30);
  244.     A00 = MPC_SHL(B00 + B01, MPC_FIXED_POINT_SYNTH_FIX);
  245.     A01 = MPC_SCALE_CONST_SHL((B00 - B01) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  246.     A02 = MPC_SHL(B02 + B03, MPC_FIXED_POINT_SYNTH_FIX);
  247.     A03 = MPC_SCALE_CONST_SHL((B02 - B03) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  248.     A04 = MPC_SHL(B04 + B05, MPC_FIXED_POINT_SYNTH_FIX);
  249.     A05 = MPC_SCALE_CONST_SHL((B04 - B05) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  250.     A06 = MPC_SHL(B06 + B07, MPC_FIXED_POINT_SYNTH_FIX);
  251.     A07 = MPC_SCALE_CONST_SHL((B06 - B07) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  252.     A08 = MPC_SHL(B08 + B09, MPC_FIXED_POINT_SYNTH_FIX);
  253.     A09 = MPC_SCALE_CONST_SHL((B08 - B09) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  254.     A10 = MPC_SHL(B10 + B11, MPC_FIXED_POINT_SYNTH_FIX);
  255.     A11 = MPC_SCALE_CONST_SHL((B10 - B11) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  256.     A12 = MPC_SHL(B12 + B13, MPC_FIXED_POINT_SYNTH_FIX);
  257.     A13 = MPC_SCALE_CONST_SHL((B12 - B13) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  258.     A14 = MPC_SHL(B14 + B15, MPC_FIXED_POINT_SYNTH_FIX);
  259.     A15 = MPC_SCALE_CONST_SHL((B14 - B15) , 0.7071067691f , 31, MPC_FIXED_POINT_SYNTH_FIX);
  260.     // mehrfach verwendete Ausdr點ke: A04+A06+A07, A09+A13+A15
  261.     V[ 5] = (V[11] = (V[13] = A07 + (V[15] = A15)) + A11) + A05 + A13;
  262.     V[ 7] = (V[ 9] = A03 + A11 + A15) + A13;
  263.     V[33] = -(V[ 1] = A01 + A09 + A13 + A15) - A14;
  264.     V[35] = -(V[ 3] = A05 + A07 + A09 + A13 + A15) - A06 - A14;
  265.     V[37] = (tmp = -(A10 + A11 + A13 + A14 + A15)) - A05 - A06 - A07;
  266.     V[39] = tmp - A02 - A03;                      // abh鋘gig vom Befehl dr黚er
  267.     V[41] = (tmp += A13 - A12) - A02 - A03;       // abh鋘gig vom Befehl 2 dr黚er
  268.     V[43] = tmp - A04 - A06 - A07;                // abh鋘gig von Befehlen 1 und 3 dr黚er
  269.     V[47] = (tmp = -(A08 + A12 + A14 + A15)) - A00;
  270.     V[45] = tmp - A04 - A06 - A07;                // abh鋘gig vom Befehl dr黚er
  271.     V[32] = -V[ 0];
  272.     V[31] = -V[ 1];
  273.     V[30] = -V[ 2];
  274.     V[29] = -V[ 3];
  275.     V[28] = -V[ 4];
  276.     V[27] = -V[ 5];
  277.     V[26] = -V[ 6];
  278.     V[25] = -V[ 7];
  279.     V[24] = -V[ 8];
  280.     V[23] = -V[ 9];
  281.     V[22] = -V[10];
  282.     V[21] = -V[11];
  283.     V[20] = -V[12];
  284.     V[19] = -V[13];
  285.     V[18] = -V[14];
  286.     V[17] = -V[15];
  287.     V[63] =  V[33];
  288.     V[62] =  V[34];
  289.     V[61] =  V[35];
  290.     V[60] =  V[36];
  291.     V[59] =  V[37];
  292.     V[58] =  V[38];
  293.     V[57] =  V[39];
  294.     V[56] =  V[40];
  295.     V[55] =  V[41];
  296.     V[54] =  V[42];
  297.     V[53] =  V[43];
  298.     V[52] =  V[44];
  299.     V[51] =  V[45];
  300.     V[50] =  V[46];
  301.     V[49] =  V[47];
  302. }
  303. static void Synthese_Filter_float_internal(MPC_SAMPLE_FORMAT * OutData,MPC_SAMPLE_FORMAT * V,const MPC_SAMPLE_FORMAT * Y)
  304. {
  305.     mpc_uint32_t n;
  306.     for ( n = 0; n < 36; n++, Y += 32 ) {
  307.         V -= 64;
  308.         Calculate_New_V ( Y, V );
  309.         {
  310.             MPC_SAMPLE_FORMAT * Data = OutData;
  311.             const MPC_SAMPLE_FORMAT *  D = (const MPC_SAMPLE_FORMAT *) &Di_opt;
  312.             mpc_int32_t           k;
  313.             //mpc_int32_t           tmp;
  314.             
  315.             
  316.             for ( k = 0; k < 32; k++, D += 16, V++ ) {
  317.                 *Data = MPC_SHL(
  318.                     MPC_MULTIPLY_FRACT(V[  0],D[ 0]) + MPC_MULTIPLY_FRACT(V[ 96],D[ 1]) + MPC_MULTIPLY_FRACT(V[128],D[ 2]) + MPC_MULTIPLY_FRACT(V[224],D[ 3])
  319.                     + MPC_MULTIPLY_FRACT(V[256],D[ 4]) + MPC_MULTIPLY_FRACT(V[352],D[ 5]) + MPC_MULTIPLY_FRACT(V[384],D[ 6]) + MPC_MULTIPLY_FRACT(V[480],D[ 7])
  320.                     + MPC_MULTIPLY_FRACT(V[512],D[ 8]) + MPC_MULTIPLY_FRACT(V[608],D[ 9]) + MPC_MULTIPLY_FRACT(V[640],D[10]) + MPC_MULTIPLY_FRACT(V[736],D[11])
  321.                     + MPC_MULTIPLY_FRACT(V[768],D[12]) + MPC_MULTIPLY_FRACT(V[864],D[13]) + MPC_MULTIPLY_FRACT(V[896],D[14]) + MPC_MULTIPLY_FRACT(V[992],D[15])
  322.                     , 2);
  323.                 
  324.                 Data += 2;
  325.             }
  326.             V -= 32;//bleh
  327.             OutData+=64;
  328.         }
  329.     }
  330. }
  331. void
  332. mpc_decoder_synthese_filter_float(mpc_decoder *d, MPC_SAMPLE_FORMAT* OutData) 
  333. {
  334.     /********* left channel ********/
  335.     memmove(d->V_L + MPC_V_MEM, d->V_L, 960 * sizeof(MPC_SAMPLE_FORMAT) );
  336.     Synthese_Filter_float_internal(
  337.         OutData,
  338.         (MPC_SAMPLE_FORMAT *)(d->V_L + MPC_V_MEM),
  339.         (MPC_SAMPLE_FORMAT *)(d->Y_L [0]));
  340.     /******** right channel ********/
  341.     memmove(d->V_R + MPC_V_MEM, d->V_R, 960 * sizeof(MPC_SAMPLE_FORMAT) );
  342.     Synthese_Filter_float_internal(
  343.         OutData + 1,
  344.         (MPC_SAMPLE_FORMAT *)(d->V_R + MPC_V_MEM),
  345.         (MPC_SAMPLE_FORMAT *)(d->Y_R [0]));
  346. }
  347. /*******************************************/
  348. /*                                         */
  349. /*            dithered synthesis           */
  350. /*                                         */
  351. /*******************************************/
  352. static const unsigned char    Parity [256] = {  // parity
  353.     0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0,1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,
  354.     1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0,
  355.     1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0,
  356.     0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0,1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,
  357.     1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0,
  358.     0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0,1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,
  359.     0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0,1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,
  360.     1,0,0,1,0,1,1,0,0,1,1,0,1,0,0,1,0,1,1,0,1,0,0,1,1,0,0,1,0,1,1,0
  361. };
  362. /*
  363.  *  This is a simple random number generator with good quality for audio purposes.
  364.  *  It consists of two polycounters with opposite rotation direction and different
  365.  *  periods. The periods are coprime, so the total period is the product of both.
  366.  *
  367.  *     -------------------------------------------------------------------------------------------------
  368.  * +-> |31:30:29:28:27:26:25:24:23:22:21:20:19:18:17:16:15:14:13:12:11:10: 9: 8: 7: 6: 5: 4: 3: 2: 1: 0|
  369.  * |   -------------------------------------------------------------------------------------------------
  370.  * |                                                                          |  |  |  |     |        |
  371.  * |                                                                          +--+--+--+-XOR-+--------+
  372.  * |                                                                                      |
  373.  * +--------------------------------------------------------------------------------------+
  374.  *
  375.  *     -------------------------------------------------------------------------------------------------
  376.  *     |31:30:29:28:27:26:25:24:23:22:21:20:19:18:17:16:15:14:13:12:11:10: 9: 8: 7: 6: 5: 4: 3: 2: 1: 0| <-+
  377.  *     -------------------------------------------------------------------------------------------------   |
  378.  *       |  |           |  |                                                                               |
  379.  *       +--+----XOR----+--+                                                                               |
  380.  *                |                                                                                        |
  381.  *                +----------------------------------------------------------------------------------------+
  382.  *
  383.  *
  384.  *  The first has an period of 3*5*17*257*65537, the second of 7*47*73*178481,
  385.  *  which gives a period of 18.410.713.077.675.721.215. The result is the
  386.  *  XORed values of both generators.
  387.  */
  388. mpc_uint32_t
  389. random_int(mpc_decoder *d) 
  390. {
  391. #if 1
  392.     mpc_uint32_t  t1, t2, t3, t4;
  393.     t3   = t1 = d->__r1;   t4   = t2 = d->__r2;  // Parity calculation is done via table lookup, this is also available
  394.     t1  &= 0xF5;        t2 >>= 25;               // on CPUs without parity, can be implemented in C and avoid unpredictable
  395.     t1   = Parity [t1]; t2  &= 0x63;             // jumps and slow rotate through the carry flag operations.
  396.     t1 <<= 31;          t2   = Parity [t2];
  397.     return (d->__r1 = (t3 >> 1) | t1 ) ^ (d->__r2 = (t4 + t4) | t2 );
  398. #else
  399.     return (d->__r1 = (d->__r1 >> 1) | ((mpc_uint32_t)Parity [d->__r1 & 0xF5] << 31) ) ^
  400.         (d->__r2 = (d->__r2 << 1) |  (mpc_uint32_t)Parity [(d->__r2 >> 25) & 0x63] );
  401. #endif
  402. }