function x = daub8_transform_inverse ( n, y ) %*****************************************************************************80 % %% DAUB8_TRANSFORM_INVERSE inverts the DAUB8 transform of a vector. % % Licensing: % % This code is distributed under the GNU LGPL license. % % Modified: % % 30 July 2011 % % Author: % % John Burkardt % % Parameters: % % Input, integer N, the dimension of the vector. % N must be a power of 2 and at least 4. % % Input, real Y(N), the transformed vector. % % Output, real X(N), the original vector. % c = [ ... 0.2303778133088964; ... 0.7148465705529154; ... 0.6308807679298587; ... -0.0279837694168599; ... -0.1870348117190931; ... 0.0308413818355607; ... 0.0328830116668852; ... -0.0105974017850690 ]; p = 7; x(1:n,1) = y(1:n); m = 4; q = floor ( ( p - 1 ) / 2 ); while ( m <= n ) z(1:m,1) = 0.0; j = 1; mh = floor ( m / 2 ); for i = - q + 1 : mh - q for k = 0 : 2 : p - 1 i0 = i4_wrap ( i + k / 2, 1, mh ); i1 = i4_wrap ( i + mh + k / 2, mh + 1, m ); z(j,1) = z(j,1) + c(p-k) * x(i0) + c(k+2) * x(i1); z(j+1,1) = z(j+1,1) + c(p-k+1) * x(i0) - c(k+1) * x(i1); end j = j + 2; end x(1:m,1) = z(1:m); m = m * 2; end return end