Blame libcelt/vq.h

Packit 664db3
/* (C) 2007-2008 Jean-Marc Valin, CSIRO
Packit 664db3
*/
Packit 664db3
/**
Packit 664db3
   @file vq.h
Packit 664db3
   @brief Vector quantisation of the residual
Packit 664db3
 */
Packit 664db3
/*
Packit 664db3
   Redistribution and use in source and binary forms, with or without
Packit 664db3
   modification, are permitted provided that the following conditions
Packit 664db3
   are met:
Packit 664db3
   
Packit 664db3
   - Redistributions of source code must retain the above copyright
Packit 664db3
   notice, this list of conditions and the following disclaimer.
Packit 664db3
   
Packit 664db3
   - Redistributions in binary form must reproduce the above copyright
Packit 664db3
   notice, this list of conditions and the following disclaimer in the
Packit 664db3
   documentation and/or other materials provided with the distribution.
Packit 664db3
   
Packit 664db3
   - Neither the name of the Xiph.org Foundation nor the names of its
Packit 664db3
   contributors may be used to endorse or promote products derived from
Packit 664db3
   this software without specific prior written permission.
Packit 664db3
   
Packit 664db3
   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 664db3
   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 664db3
   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 664db3
   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
Packit 664db3
   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
Packit 664db3
   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
Packit 664db3
   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
Packit 664db3
   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
Packit 664db3
   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
Packit 664db3
   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
Packit 664db3
   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 664db3
*/
Packit 664db3
Packit 664db3
#ifndef VQ_H
Packit 664db3
#define VQ_H
Packit 664db3
Packit 664db3
#include "entenc.h"
Packit 664db3
#include "entdec.h"
Packit 664db3
#include "modes.h"
Packit 664db3
Packit 664db3
/** Algebraic pulse-vector quantiser. The signal x is replaced by the sum of 
Packit 664db3
  * the pitch and a combination of pulses such that its norm is still equal 
Packit 664db3
  * to 1. This is the function that will typically require the most CPU. 
Packit 664db3
 * @param x Residual signal to quantise/encode (returns quantised version)
Packit 664db3
 * @param W Perceptual weight to use when optimising (currently unused)
Packit 664db3
 * @param N Number of samples to encode
Packit 664db3
 * @param K Number of pulses to use
Packit 664db3
 * @param p Pitch vector (it is assumed that p+x is a unit vector)
Packit 664db3
 * @param enc Entropy encoder state
Packit 664db3
*/
Packit 664db3
void alg_quant(celt_norm_t *X, celt_mask_t *W, int N, int K, celt_norm_t *P, ec_enc *enc);
Packit 664db3
Packit 664db3
/** Algebraic pulse decoder
Packit 664db3
 * @param x Decoded normalised spectrum (returned)
Packit 664db3
 * @param N Number of samples to decode
Packit 664db3
 * @param K Number of pulses to use
Packit 664db3
 * @param p Pitch vector (automatically added to x)
Packit 664db3
 * @param dec Entropy decoder state
Packit 664db3
 */
Packit 664db3
void alg_unquant(celt_norm_t *X, int N, int K, celt_norm_t *P, ec_dec *dec);
Packit 664db3
Packit 664db3
void renormalise_vector(celt_norm_t *X, celt_word16_t value, int N, int stride);
Packit 664db3
Packit 664db3
/** Intra-frame predictor that matches a section of the current frame (at lower
Packit 664db3
 * frequencies) to encode the current band.
Packit 664db3
 * @param x Residual signal to quantise/encode (returns quantised version)
Packit 664db3
 * @param W Perceptual weight
Packit 664db3
 * @param N Number of samples to encode
Packit 664db3
 * @param K Number of pulses to use
Packit 664db3
 * @param Y Lower frequency spectrum to use, normalised to the same standard deviation
Packit 664db3
 * @param P Pitch vector (it is assumed that p+x is a unit vector)
Packit 664db3
 * @param B Stride (number of channels multiplied by the number of MDCTs per frame)
Packit 664db3
 * @param N0 Number of valid offsets
Packit 664db3
 */
Packit 664db3
void intra_fold(const CELTMode *m, celt_norm_t * restrict x, int N, int K, celt_norm_t *Y, celt_norm_t * restrict P, int N0, int B);
Packit 664db3
Packit 664db3
#endif /* VQ_H */