BR112020001633A2 - métodos de codificação e decodificação, e aparelhos de codificação e decodificação para sinal estéreo - Google Patents

métodos de codificação e decodificação, e aparelhos de codificação e decodificação para sinal estéreo Download PDF

Info

Publication number
BR112020001633A2
BR112020001633A2 BR112020001633-0A BR112020001633A BR112020001633A2 BR 112020001633 A2 BR112020001633 A2 BR 112020001633A2 BR 112020001633 A BR112020001633 A BR 112020001633A BR 112020001633 A2 BR112020001633 A2 BR 112020001633A2
Authority
BR
Brazil
Prior art keywords
current frame
channel signal
decoding
channels
time difference
Prior art date
Application number
BR112020001633-0A
Other languages
English (en)
Inventor
Eyal Shlomot
Haiting Li
Bin Wang
Original Assignee
Huawei Technologies Co., Ltd.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Huawei Technologies Co., Ltd. filed Critical Huawei Technologies Co., Ltd.
Publication of BR112020001633A2 publication Critical patent/BR112020001633A2/pt

Links

Classifications

    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10LSPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
    • G10L19/00Speech or audio signals analysis-synthesis techniques for redundancy reduction, e.g. in vocoders; Coding or decoding of speech or audio signals, using source filter models or psychoacoustic analysis
    • G10L19/008Multichannel audio signal coding or decoding using interchannel correlation to reduce redundancy, e.g. joint-stereo, intensity-coding or matrixing
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10LSPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
    • G10L19/00Speech or audio signals analysis-synthesis techniques for redundancy reduction, e.g. in vocoders; Coding or decoding of speech or audio signals, using source filter models or psychoacoustic analysis
    • G10L19/04Speech or audio signals analysis-synthesis techniques for redundancy reduction, e.g. in vocoders; Coding or decoding of speech or audio signals, using source filter models or psychoacoustic analysis using predictive techniques
    • G10L19/16Vocoder architecture
    • G10L19/18Vocoders using multiple modes
    • G10L19/20Vocoders using multiple modes using sound class specific coding, hybrid encoders or object based coding
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10LSPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
    • G10L19/00Speech or audio signals analysis-synthesis techniques for redundancy reduction, e.g. in vocoders; Coding or decoding of speech or audio signals, using source filter models or psychoacoustic analysis
    • G10L19/04Speech or audio signals analysis-synthesis techniques for redundancy reduction, e.g. in vocoders; Coding or decoding of speech or audio signals, using source filter models or psychoacoustic analysis using predictive techniques
    • G10L19/16Vocoder architecture
    • G10L19/18Vocoders using multiple modes
    • G10L19/24Variable rate codecs, e.g. for generating different qualities using a scalable representation such as hierarchical encoding or layered encoding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04SSTEREOPHONIC SYSTEMS 
    • H04S3/00Systems employing more than two channels, e.g. quadraphonic
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04SSTEREOPHONIC SYSTEMS 
    • H04S3/00Systems employing more than two channels, e.g. quadraphonic
    • H04S3/008Systems employing more than two channels, e.g. quadraphonic in which the audio signals are in digital form, i.e. employing more than two discrete digital channels
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04SSTEREOPHONIC SYSTEMS 
    • H04S2420/00Techniques used stereophonic systems covered by H04S but not provided for in its groups
    • H04S2420/03Application of parametric coding in stereophonic audio systems

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Acoustics & Sound (AREA)
  • Signal Processing (AREA)
  • Multimedia (AREA)
  • Computational Linguistics (AREA)
  • Health & Medical Sciences (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Human Computer Interaction (AREA)
  • Mathematical Physics (AREA)
  • Quality & Reliability (AREA)
  • Stereophonic System (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Stereo-Broadcasting Methods (AREA)
  • Reduction Or Emphasis Of Bandwidth Of Signals (AREA)

Abstract

Este pedido de patente fornece um método de codificação, um método de decodificação, um aparelho de codificação e um aparelho de decodificação para um sinal estéreo. O método de codificação para o sinal estéreo inclui: determinar uma diferença de tempo entre canais em um quadro atual; executar processamento de interpolação baseado na diferença de tempo entre canais no quadro corrente e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual; executar alinhamento de atraso em um sinal estéreo no quadro atual baseado na diferença de tempo entre canais em um quadro atual, para obter um sinal estéreo após o alinhamento de atraso no quadro atual; executar processamento de mixagem descendente no domínio do tempo no sinal estéreo após o alinhamento de atraso no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário no quadro atual; quantizar a diferença de tempo entre canais após o processamento de interpolação no quadro atual, e gravar uma diferença de tempo entre canais quantizada em um fluxo de bits; e quantizar o sinal de canal principal e o sinal de canal secundário no quadro atual, e gravar um sinal de canal principal quantizado e um sinal de canal secundário quantizado em um fluxo de bits. De acordo com este pedido de patente, um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais em um sinal de estéreo original pode ser reduzido.

Description

MÉTODOS DE CODIFICAÇÃO E DECODIFICAÇÃO, E APARELHOS DE CODIFICAÇÃO E DECODIFICAÇÃO PARA SINAL ESTÉREO
[001] Este pedido reivindica prioridade para o Pedido Chinês No. 201710614326.7, depositado na Repartição Chinesa de Patentes em 25 de julho de 2017 e intitulado "ENCODING AND DECODING METHODS, AND ENCODING AND DECODING APPARATUSES FOR STEREO SIGNAL", que é incorporado neste documento por referência.
CAMPO TÉCNICO
[002] Este pedido refere-se ao campo de tecnologias de codificação e decodificação de sinais de áudio e, mais especificamente, a métodos de codificação e decodificação, e aparelhos de codificação e decodificação para um sinal estéreo.
FUNDAMENTOS
[003] Uma tecnologia paramétrica de codificação e decodificação de estéreo, uma tecnologia no domínio do tempo de codificação e decodificação de estéreo, e similares podem ser usadas para codificar um sinal de estéreo. Codificação e decodificação de sinal de estéreo mediante utilização de tecnologia no domínio do tempo de codificação e decodificação de estéreo geralmente inclui os seguintes processos:
[004] Um processo de codificação: estimar uma diferença de tempo entre canais do sinal estéreo; executar alinhamento de atraso no sinal estéreo baseado na diferença de tempo entre canais; executar, baseado no parâmetro de processamento de mixagem descendente no domínio do tempo, processamento de mixagem descendente no domínio do tempo em um sinal que é obtido após o alinhamento de atraso, para obter um sinal de canal principal e um sinal de canal secundário; e codificar a diferença de tempo entre canais, o parâmetro de processamento de mixagem descendente no domínio do tempo, o sinal de canal principal e o sinal de canal secundário, para obter um fluxo de bits codificado.
[005] Um processo de decodificação: decodificar o fluxo de bits para obter um sinal de canal principal, um sinal de canal secundário, um parâmetro de processamento de mixagem descendente no domínio do tempo, e uma diferença de tempo entre canais; executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário baseado no parâmetro de processamento de mixagem descendente no domínio do tempo, para obter um sinal do canal esquerdo —“reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo; e ajustar, baseado na diferença de tempo entre canais, um atraso do sinal do canal esquerdo reconstruído e do sinal do canal direito reconstruído que são obtidos após oO processamento de mixagem ascendente no domínio do tempo para obter um sinal estéreo decodificado.
[006] Nos processos de codificação e decodificação do sinal estéreo “mediante utilização da tecnologia de codificação de estéreo no domínio do tempo, embora a diferença de tempo entre canais seja considerada, como existem atrasos de codificação e decodificação nos processos de codificação e decodificação do sinal de canal principal e do sinal de canal secundário, existe um desvio entre a diferença de tempo entre canais do sinal estéreo que é finalmente emitido a partir do terminal de decodificação e a diferença de tempo entre canais do sinal estéreo original, o que afeta uma imagem de som estéreo da saída de sinal estéreo por decodificação.
SUMÁRIO
[007] Este pedido fornece métodos de codificação e decodificação, e aparelhos de codificação e decodificação para um sinal estéreo, para reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original.
[008] De acordo com um primeiro aspecto, é fornecido um método de codificação para um sinal estéreo. O método de codificação inclui: determinar uma diferença de tempo entre canais em um quadro atual; executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; executar alinhamento de atraso em um sinal estéreo no quadro atual baseado na diferença de tempo entre canais no quadro atual, para obter um sinal estéreo após o alinhamento de atraso no quadro atual; executar processamento de mixagem descendente no domínio do tempo no sinal estéreo após o alinhamento de atraso no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário no quadro atual; quantizar a diferença de tempo entre canais após o processamento de interpolação no quadro atual, e gravar uma diferença de tempo entre canais quantizada em um fluxo de bits; e quantizar o sinal de canal principal e o sinal de canal secundário no quadro atual, e gravar um sinal de canal principal quantizado e um sinal de canal secundário quantizado no fluxo de bits.
[009] Ao executar processamento de interpolação na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, e codificação e em seguida gravação da diferença de tempo entre canais após o processo de interpolação no quadro atual em um fluxo de bits, uma diferença de tempo entre canais no quadro atual, que é obtida por decodificação, por um terminal de decodificação, de um fluxo de bits recebido, pode combinar o fluxo de bits que inclui o sinal de canal principal e o sinal de canal secundário no quadro atual, de modo que o terminal de decodificação possa executar decodificação baseada na diferença de tempo entre canais no quadro atual que corresponda ao fluxo de bits que inclui o sinal de canal principal e o sinal de canal secundário no quadro atual. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtida por decodificação é melhorada.
[0010] Especificamente, quando o terminal de codificação codifica o sinal de canal principal e o sinal de canal secundário que são obtidos após o processamento de mixagem descendente, e quando o terminal de decodificação decodifica o fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário, existem atrasos de codificação e decodificação.
Contudo, quando o terminal de codificação codifica a diferença de tempo entre canais, e quando o terminal de decodificação decodifica o fluxo de bits para obter uma diferença de tempo entre canais, os mesmos atrasos de codificação e decodificação não existem, e um codec de áudio executa processamento baseado nos quadros.
Portanto, existe um atraso entre um sinal de canal principal e um sinal de canal secundário no quadro atual que são obtidos por decodificação, pelo terminal de decodificação, de um fluxo de bits no quadro atual e uma diferença de tempo entre canais no quadro atual que é obtida por decodificação do fluxo de bits no quadro atual.
Neste caso, se o terminal de decodificação ainda usar a diferença de tempo entre canais no quadro atual para ajustar um atraso de um sinal do canal esquerdo reconstruído e de um sinal do canal direito reconstruído no quadro atual que são obtidos após subsequente processamento de mixagem ascendente no domínio do tempo ser executada no sinal de canal principal e no sinal de canal secundário no quadro atual que são obtidos por decodificação do fluxo de bits, existe um desvio relativamente grande entre a diferença de tempo entre canais do sinal estéreo finalmente obtido e a diferença de tempo entre canais do sinal estéreo original.
Contudo, o terminal de codificação executa processamento de interpolação para ajustar a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual para obter a diferença de tempo entre canais após o processamento de interpolação no quadro atual, codifica a diferença de tempo entre canais após o processamento de interpolação, e transmite a diferença de tempo entre canais codificada junto com um fluxo de bits que inclui o sinal de canal principal e um sinal de canal secundário que são obtidos por codificação do quadro atual ao terminal de decodificação, de modo que a diferença de tempo entre canais no quadro atual obtido por decodificação, pelo terminal de decodificação, do fluxo de bits pode corresponder ao sinal do canal esquerdo reconstruído e ao sinal do canal direito reconstruído no quadro atual que são obtidos pelo terminal de decodificação. Portanto, o desvio entre a diferença de tempo entre canais do sinal estéreo finalmente obtido e a diferença de tempo entre canais do sinal estéreo original é reduzido pela execução de ajuste de atraso.
[0011] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com a fórmula A=aeB+(1- a)eC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação e O<a<l.
[0012] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda a uma diferença de tempo entre canais obtida por decodificação atualmente tanto quanto possível.
[0013] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, pelo terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, pelo terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[0014] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S)/N, onde S é o atraso de codificação e decodificação e Né o comprimento de quadro do quadro atual.
[0015] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, o primeiro coeficiente de interpolação a é pré-armazenado.
[0016] O pré-armazenamento do primeiro coeficiente de interpolação a pode reduzir a complexidade de cálculo de um processo de codificação e melhorar a eficiência de codificação.
[0017] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculado de acordo com uma fórmula A=(1-B)eB+fBeC; onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, Bé a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, BP é um segundo coeficiente de interpolação e O<fB<1.
[0018] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda a uma diferença de tempo entre canais obtida por decodificação atualmente tanto quanto possível.
[0019] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, o segundo coeficiente de interpolação À é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, pelo terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[0020] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, o segundo coeficiente de interpolação À satisfaz uma fórmula B=S/N, onde S é o atraso de codificação e decodificação e N é o comprimento de quadro do quadro atual.
[0021] Com referência ao primeiro aspecto, em algumas implementações do primeiro aspecto, o segundo coeficiente de interpolação À é pré-armazenado.
[0022] O pré-armazenamento do segundo coeficiente de interpolação À pode reduzir a complexidade de cálculo de um processo de codificação e melhorar a eficiência de codificação.
[0023] De acordo com um segundo aspecto, é fornecido um método de decodificação para um sinal de múltiplos canais. O método inclui: decodificar um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário em um quadro atual e uma diferença de tempo entre canais no quadro atual; executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário no quadro atual, para obter um sinal do canal esquerdo reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo; executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; e ajustar um atraso do sinal do canal esquerdo reconstruído e do sinal do canal direito reconstruído baseado na diferença de tempo entre canais após o processamento de interpolação no quadro atual.
[0024] Ao executar processamento de interpolação na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, a diferença de tempo entre canais após o processamento de interpolação no quadro atual pode corresponder ao sinal de canal principal e ao sinal de canal secundário no quadro atual que são obtidos por decodificação. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtida por decodificação é melhorada.
[0025] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculado de acordo com uma fórmula A=aeB+ (1-a)eC; onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação e O<a<1l.
[0026] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda a uma diferença de tempo entre canais obtida por decodificação atualmente tanto quanto possível.
[0027] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[0028] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S)/N, onde S é o atraso de codificação e decodificação e Né o comprimento de quadro do quadro atual.
[0029] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, o primeiro coeficiente de interpolação a é pré-armazenado.
[0030] O pré-armazenamento do primeiro coeficiente de interpolação a pode reduzir a complexidade de cálculo de um processo de decodificação e melhorar a eficiência da decodificação.
[0031] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, a diferença de tempo entre canais após o processamento de interpolação no quadro atual ser calculado de acordo com uma fórmula A=(1-B)eB+fBeC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, Bé a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, À é um primeiro coeficiente de interpolação e O<fB<1l.
[0032] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda a uma diferença de tempo entre canais obtida por decodificação atualmente tanto quanto possível.
[0033] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, o segundo coeficiente de interpolação À é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[0034] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, o segundo coeficiente de interpolação À satisfazer uma fórmula B=S/N, onde S é o atraso de codificação e decodificação e N é o comprimento de quadro do quadro atual.
[0035] Com referência ao segundo aspecto, em algumas implementações do segundo aspecto, o segundo coeficiente de interpolação À é pré-armazenado.
[0036] O pré-armazenamento do segundo coeficiente de interpolação a pode reduzir a complexidade de cálculo de um processo de decodificação e melhorar a eficiência de decodificação.
[0037] De acordo com um terceiro aspecto, é fornecido um aparelho de codificação. O aparelho de codificação inclui um módulo configurado para executar o primeiro aspecto ou diversas implementações do primeiro aspecto.
[0038] De acordo com um quarto aspecto, é fornecido um aparelho de decodificação. O aparelho de decodificação inclui um módulo configurado para executar o segundo aspecto ou diversas implementações do segundo aspecto.
[0039] De acordo com um quinto aspecto, é fornecido um aparelho de codificação. O aparelho de codificação inclui um meio de armazenamento e uma unidade central de processamento, onde o meio de armazenamento pode ser um meio de armazenamento não volátil e armazenar um programa executável por computador, e a unidade central de processamento estar conectada ao meio de armazenamento não volátil e executar o programa executável em computador para implementar o método no primeiro aspecto ou diversas implementações do primeiro aspecto.
[0040] De acordo com um sexto aspecto, é fornecido um aparelho de decodificação. O aparelho de decodificação inclui um meio de armazenamento e uma unidade central de processamento, onde o meio de armazenamento pode ser um meio de armazenamento não volátil e armazenar um programa executável por computador, e a unidade central de processamento estar conectada ao meio de armazenamento não volátil e executar o programa executável em computador para implementar o método no segundo aspecto ou diversas implementações do segundo aspecto.
[0041] De acordo com um sétimo aspecto, é fornecido um meio de armazenamento legível por computador. O meio de armazenamento legível por computador armazena código de programa para ser executado por um dispositivo, e o código de programa inclui uma instrução usada para executar o método no primeiro aspecto ou diversas implementações do primeiro aspecto.
[0042] De acordo com um oitavo aspecto, é fornecido um meio de armazenamento legível por computador. O meio de armazenamento legível por computador armazena código de programa para ser executado por um dispositivo, e o código de programa inclui uma instrução usada para executar o método no segundo aspecto ou diversas implementações do segundo aspecto.
DESCRIÇÃO RESUMIDA DOS DESENHOS
[0043] A FIG. 1 é um fluxograma esquemático de um método de codificação estéreo existente no domínio do tempo;
a FIG. 2 é um fluxograma esquemático de um método de decodificação estéreo existente no domínio do tempo;
a FIG. 3 é um diagrama esquemático de um desvio de atraso entre um sinal estéreo obtido por decodificação mediante utilização de uma tecnologia de codificação e decodificação estéreo existente no domínio do tempo e um sinal estéreo original;
a FIG. 4 é um fluxograma esquemático de um método de codificação para um sinal estéreo de acordo com uma modalidade deste pedido;
a FIG. 5 é um diagrama esquemático de um desvio de atraso entre um sinal estéreo obtido pela decodificação de um fluxo de bits que é obtido mediante utilização de um método de codificação para um sinal estéreo e um sinal estéreo original de acordo com uma modalidade deste pedido;
a FIG. 6 é um fluxograma esquemático de um método de codificação para um sinal estéreo de acordo com uma modalidade deste pedido;
a FIG. 7 é um fluxograma esquemático de um método de decodificação para um sinal estéreo de acordo com uma modalidade deste pedido;
a FIG. 8 é um fluxograma esquemático de um método de decodificação para um sinal estéreo de acordo com uma modalidade deste pedido;
a FIG. 9 é um diagrama de blocos esquemático de um aparelho de codificação de acordo com uma modalidade deste pedido;
a FIG. 10 é um diagrama de blocos esquemático de um aparelho de decodificação de acordo com uma modalidade deste pedido;
a FIG. 11 é um diagrama de blocos esquemático de um aparelho de codificação de acordo com uma modalidade deste pedido; a FIG. 12 é um diagrama de blocos esquemático de um aparelho de decodificação para um sinal estéreo de acordo com uma modalidade deste pedido; a FIG. 13 é um diagrama esquemático de um dispositivo terminal de acordo com uma modalidade deste pedido; a FIG. 14 é um diagrama esquemático de um dispositivo de rede de acordo com uma modalidade deste pedido; a FIG. 15 é um diagrama esquemático de um dispositivo de rede de acordo com uma modalidade deste pedido; a FIG. 16 é um diagrama esquemático de um dispositivo terminal de acordo com uma modalidade deste pedido; a FIG. 17 é um diagrama esquemático de um dispositivo de rede de acordo com uma modalidade deste pedido; e a FIG. 18 é um diagrama esquemático de um dispositivo de rede de acordo com uma modalidade deste pedido.
DESCRIÇÃO DE MODALIDADES
[0044] A seguir são descritas as soluções técnicas neste pedido com referência aos desenhos anexos.
[0045] Para melhor a compreensão dos métodos de codificação e decodificação nas modalidades deste pedido, a seguir são primeiro descritos em detalhe processos de métodos de codificação e decodificação existentes no domínio do tempo com referência à FIG.1 e à FIG. 2.
[0046] A FIG. 1 é um fluxograma esquemático do método de codificação estéreo existente no domínio do tempo. O método de codificação 100 inclui especificamente as etapas a seguir.
[0047] 110. Um terminal de codificação estima uma diferença de tempo entre canais de um sinal estéreo, para obter a diferença de tempo entre canais do sinal estéreo.
[0048] O sinal estéreo inclui um sinal do canal esquerdo e um sinal do canal direito. A diferença de tempo entre canais do sinal estéreo é uma diferença de tempo entre o sinal do canal esquerdo e o sinal do canal direito.
[0049] 120. Executar alinhamento de atraso no sinal do canal esquerdo e no sinal do canal direito baseado na diferença de tempo estimada entre canais.
[0050] 130. Codificar a diferença de tempo entre canais do sinal estéreo, para obter um índice de codificação da diferença de tempo entre canais, e gravar o índice de codificação em um fluxo de bits estéreo codificado.
[0051] 140. Determinar um fator de escala de combinação de canais, codificar o fator de escala de combinação de canais para obter um índice de codificação do fator de escala de combinação de canais, e gravar oO índice codificado no fluxo de bits estéreo codificado.
[0052] 150. Executar, baseado no fator de escala de combinação de canais, processamento de mixagem descendente no domínio do tempo em um sinal do canal esquerdo e um sinal do canal direito que são obtidos após o alinhamento de atraso.
[0053] 160. Codificar separadamente um sinal de canal principal e um sinal de canal secundário que são obtidos após o processamento de mixagem descendente, para obter fluxos de bits do sinal de canal principal e do sinal de canal secundário, e gravar os fluxos de bits no fluxo de bits estéreo codificado.
[0054] A FIG. 2 é um fluxograma esquemático do método de decodificação estéreo no domínio do tempo. O método de decodificação 200 inclui especificamente as etapas a seguir.
[0055] 210. Decodificar um fluxo de bits recebido para obter um sinal de canal principal e um sinal de canal secundário.
[0056] A etapa 210 é equivalente a executar separadamente decodificação de sinal de canal principal e decodificação de sinal de canal secundário para obter o sinal de canal principal e o sinal de canal secundário.
[0057] 220. Decodificar o fluxo de bits recebido para obter um fator de escala de combinação de canais.
[0058] 230. Executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário baseado no fator de escala de combinação de canais, para obter um sinal do canal esquerdo reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo.
[0059] 240. Decodificar o fluxo de bits recebido para obter uma diferença de tempo entre canais.
[0060] 250. Ajustar, baseado na diferença de tempo entre canais, um atraso do sinal do canal esquerdo reconstruído e do sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo, para obter um sinal estéreo decodificado.
[0061] Nos métodos de codificação e decodificação estéreo existentes no domínio do tempo, um atraso de codificação adicional (este atraso pode ser especificamente um tempo necessário para codificação do sinal de canal principal e do sinal de canal secundário) e um atraso de decodificação (este atraso pode ser especificamente um tempo necessário para decodificação do sinal de canal principal e do sinal de canal secundário) são introduzidos nos processos de codificação (especificamente mostrado na etapa 160) e decodificação (especificamente mostrado na etapa 210) do sinal de canal principal e do sinal de canal secundário. Contudo, não existe o mesmo atraso de codificação e o mesmo atraso de decodificação nos processos de codificação e decodificação da diferença de tempo entre canais. Portanto, existe um desvio entre a diferença de tempo entre canais do sinal estéreo que é finalmente obtido por decodificação e a diferença de tempo entre canais do sinal estéreo original, e então existe um atraso entre um sinal no sinal estéreo obtido por decodificação e o mesmo sinal no sinal estéreo original, o que afeta a precisão de uma imagem de som estéreo do sinal estéreo obtido pela decodificação.
[0062] Especificamente, nos processos de codificação e decodificação da diferença de tempo entre canais, não existe atraso de codificação e atraso de decodificação que sejam os mesmos que aqueles no processo de codificação e decodificação do sinal de canal principal e do sinal de canal secundário. Portanto, um sinal de canal principal e um sinal de canal secundário que são obtidos por decodificação atualmente pelo terminal de decodificação não correspondem a uma diferença de tempo entre canais obtida pela decodificação atualmente.
[0063] A FIG. 3 mostra um atraso entre um sinal em um sinal estéreo obtido por decodificação mediante utilização de uma tecnologia de codificação e decodificação estéreo existente no domínio do tempo e o mesmo sinal em um sinal estéreo original. Como mostrado na FIG. 3, quando um valor de uma diferença de tempo entre canais entre sinais estéreo em diferentes quadros muda enormemente (como mostrado por uma área em um quadro retangular na FIG. 3) ocorre um atraso óbvio entre o sinal no sinal estéreo que é finalmente obtido pela decodificação por um terminal de decodificação e o mesmo sinal no sinal estéreo original (o sinal no sinal estéreo que é finalmente obtido pela decodificação obviamente fica atrás do mesmo sinal no sinal estéreo original). Contudo, quando o valor da diferença de tempo entre canais entre os sinais estéreo em diferentes quadros não muda obviamente (como mostrado por uma área fora do quadro retangular na FIG. 3), o atraso entre o sinal no sinal estéreo que é finalmente obtido pela decodificação pelo terminal de decodificação e o mesmo sinal no sinal estéreo original não é óbvio.
[0064] Portanto, este pedido fornece um novo método de codificação para um sinal de canal estéreo. De acordo com o método de codificação, processamento de interpolação é executado em uma diferença de tempo entre canais em um quadro atual e uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual é codificada e então transmitida a um terminal de decodificação. Contudo, alinhamento de atraso é ainda executado mediante utilização da diferença de tempo entre canais no quadro atual. Em comparação com o estado da técnica, a diferença de tempo entre canais no quadro atual obtido neste pedido corresponde melhor a um sinal de canal principal e a um sinal de canal secundário que são obtidos após codificação e decodificação, e tem um grau relativamente grande de correspondência com um sinal estéreo correspondente. Isto reduz um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido pela decodificação por um terminal de decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, um efeito do sinal estéreo que é finalmente obtido por decodificação pelo terminal de decodificação pode ser melhorado.
[0065] Deve ser entendido que o sinal estéreo neste pedido pode ser um sinal estéreo original, um sinal estéreo que inclui dois sinais que são incluídos em um sinal de múltiplos canais, ou um sinal estéreo que inclui dois sinais que são gerados em conjunto por uma pluralidade de sinais incluídos em um sinal de múltiplos canais. O método de codificação para um sinal estéreo pode também ser um método de codificação para um sinal estéreo que é usado em um método de codificação de múltiplos canais. O método de decodificação para um sinal estéreo pode também ser um método de decodificação para um sinal estéreo que é usado em um método de decodificação de múltiplos canais.
[0066] A FIG. 4 é um fluxograma esquemático de um método de codificação para um sinal estéreo de acordo com uma modalidade deste pedido. O método 400 pode ser executado por um terminal de codificação, e o terminal de codificação pode ser um codificador ou um dispositivo que tenha uma função de codificação de um sinal estéreo. O método 400 inclui especificamente as etapas a seguir.
[0067] 410. Determinar uma diferença de tempo entre canais em um quadro atual.
[0068] Deve ser entendido que um sinal estéreo processado aqui pode incluir um sinal do canal esquerdo e um sinal do canal direito, e a diferença de tempo entre canais no quadro atual pode ser obtido pela estimativa de um atraso do sinal do canal esquerdo e do sinal do canal direito. Uma diferença de tempo entre canais em um quadro anterior ao quadro atual pode ser obtida pela estimativa de um atraso de um sinal do canal esquerdo e de um sinal do canal direito em um processo de codificação de um sinal estéreo no quadro anterior. Por exemplo, um coeficiente de correlação cruzada de um canal esquerdo e de um canal direito é calculado baseado no sinal do canal esquerdo e no sinal do canal direito no quadro atual, e em seguida um valor de índice correspondente a um valor máximo do coeficiente de correlação cruzada é usado como a diferença de tempo entre canais no quadro atual.
[0069] Especificamente, a estimação de atraso pode ser executada em um modo descrito no exemplo 1 ao exemplo 3, para obter a diferença de tempo entre canais no quadro atual.
[0070] Exemplo 1: em uma taxa de amostragem atual, um valor máximo e um valor mínimo da diferença de tempo entre canais são respectivamente Tnax & Tminy Onde Tmax E Tmin São números reais predefinidos, e Tnmax>Tmin. Neste caso, um valor máximo do coeficiente de correlação cruzada dos canais esquerdo e direito, cujo valor de índice está entre o valor máximo e o valor mínimo da diferença de tempo entre canais, pode ser pesquisado. Finalmente, um valor de índice correspondente ao valor máximo pesquisado do coeficiente de correlação cruzada dos canais esquerdo e direito é determinado como a diferença de tempo entre canais no quadro atual. Especificamente, valores de Tmax € Tmin podem ser 40 e —-40 respectivamente. Deste modo, o valor máximo do coeficiente de correlação cruzada dos canais esquerdo e direito pode ser pesquisado em uma faixa de -40<i<40, e em seguida um valor de índice correspondente ao valor máximo do coeficiente de correlação cruzada é usado como a diferença de tempo entre canais no quadro atual.
[0071] Exemplo 2: em uma taxa de amostragem atual, um valor máximo e um valor mínimo da diferença de tempo entre canais são respectivamente Tnax & Tminy Onde Tmax E Tmin São números reais predefinidos, e Tmax>Tmin. Uma função de correlação cruzada dos canais esquerdo e direito é calculada baseada no sinal do canal esquerdo e no sinal do canal direito no quadro atual. Além disso, processamento de suavização é executado na função de correlação cruzada calculada dos canais esquerdo e direito no quadro atual baseado em uma função de correlação cruzada dos canais esquerdo e direito em L quadros anteriores (L é um número inteiro maior que ou igual a 1), para obter uma função de correlação cruzada suavizada dos canais esquerdo e direito. Em seguida, um valor máximo de um coeficiente de correlação cruzada dos canais esquerdo e direito após o processamento de suavização é pesquisado em uma faixa de Tmin<i<Tmax, E UM Valor de índice i correspondente ao valor máximo é usado como a diferença de tempo entre canais no quadro atual.
[0072] Exemplo 3:
após a diferença de tempo entre canais no quadro atual ser estimada de acordo com o método no exemplo 1 ou no exemplo 2, processamento de suavização entre quadros é executado em uma diferença de tempo entre canais em M quadros anteriores (M é um número inteiro maior que ou igual a 1) do quadro atual e a diferença de tempo estimada entre canais no quadro atual, e uma diferença de tempo entre canais obtida após o processamento de suavização é usada como a diferença de tempo entre canais no quadro atual.
[0073] Deve ser entendido que, antes de estimar o atraso do sinal do canal esquerdo e do sinal do canal direito (o sinal do canal esquerdo e o sinal do canal direito neste documento são sinais no domínio do tempo) para obter a diferença de tempo entre canais no quadro atual, pré- processamento no domínio do tempo pode ser ainda executado no sinal do canal esquerdo e no sinal do canal direito no quadro atual. Especificamente, processamento de filtragem passa-alta pode ser executado no sinal do canal esquerdo e no sinal do canal direito no quadro atual para obter um sinal do canal esquerdo pré-processado e um sinal do canal direito pré-processado no quadro atual. Além disso, o pré- processamento no domínio do tempo neste documento pode alternativamente ser outro processamento além do processamento de filtragem passa-alta. Por exemplo, é executado processamento pré-ênfase.
[0074] 420. Executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual.
[0075] Deve ser entendido que a diferença de tempo entre canais no quadro atual pode ser uma diferença de tempo entre o sinal do canal esquerdo no quadro atual e o sinal do canal direito no quadro atual, e a diferença de tempo entre canais no quadro anterior ao quadro atual pode ser uma diferença de tempo entre um sinal do canal esquerdo no quadro anterior ao quadro atual e um sinal do canal direito no quadro anterior ao quadro atual.
[0076] Deve ser entendido que a execução de processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual é equivalente a executar processamento de média ponderada na diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual. Deste modo, a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual está entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual.
[0077] Pode haver pluralidade de modos específicos de executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual. Por exemplo, o processamento de interpolação pode ser executado no modo 1 e no modo 2 seguintes.
[0078] Modo 1: a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula (1).
A=aeB+ (1-0) eC (1)
[0079] Na fórmula (1), A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação, eaé un número real que satisfaz O<a<l.
[0080] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula A=aeB+(1-a)eC, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda, tanto quanto possível, a uma diferença de tempo entre canais de um sinal estéreo original que não é codificado e decodificado.
[0081] Especificamente, considerando-se que o quadro atual é um quadro de ordem i, o quadro anterior ao quadro atual é um quadro de ordem (i-l1). Neste caso, uma diferença de tempo entre canais no quadro de ordem i pode ser determinado de acordo com a fórmula (2).
d int(i) = a-d(i)+(1-0) -d(i-1) (2)
[0082] Na fórmula (2), d int(i) é uma diferença de tempo entre canais após o processamento de interpolação no quadro de ordem i, d(i) é a diferença de tempo entre canais no quadro atual, d(i-l1) é uma diferença de tempo entre canais no quadro de ordem (i-1), e a tem o mesmo significado que a na fórmula (1) e é também um primeiro coeficiente de interpolação.
[0083] O primeiro coeficiente de interpolação pode ser diretamente definido pelo pessoal técnico. Por exemplo, o primeiro coeficiente de interpolação a pode ser diretamente definido como 0,4 ou 0,6.
[0084] Além disso, o primeiro coeficiente de interpolação à pode também ser determinado baseado em um comprimento de quadro do quadro atual e um atraso de codificação e decodificação. O atraso de codificação e decodificação neste documento pode incluir um atraso de codificação em um processo de codificação, pelo terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, pelo terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e de um sinal de canal secundário. Além disso, o atraso de codificação e decodificação aqui pode ser uma soma do atraso de codificação e do atraso de decodificação. O atraso de codificação e decodificação pode ser determinado após um algoritmo de codificação e decodificação usado por um codec ser determinado. Portanto, o atraso de codificação e decodificação é um parâmetro conhecido para um codificador ou um decodificador.
[0085] Opcionalmente, o primeiro coeficiente de interpolação a pode ser especificamente inversamente proporcional ao atraso de codificação e decodificação, e ser diretamente proporcional ao comprimento de quadro do quadro atual. Em outras palavras, o primeiro coeficiente de interpolação a diminui à medida que o atraso de codificação e decodificação aumenta, e aumenta à medida que o comprimento de quadro do quadro atual aumenta.
[0086] Opcionalmente, o primeiro coeficiente de interpolação a pode ser determinado de acordo com uma fórmula (3).
a=(N-S) /N (3)
[0087] Na fórmula (3), N é o comprimento de quadro do quadro atual e S é o a atraso de codificação e decodificação.
[0088] Quando N=320 e S=192, o seguinte pode ser obtido de acordo com a fórmula (3): a=(N-S) /N= (320-192) /320=0,4 (4)
[0089] Finalmente, pode ser obtido que o primeiro coeficiente de interpolação a é 0,4.
[0090] Alternativamente, o primeiro coeficiente de interpolação a é pré-armazenado. Como o atraso de codificação e decodificação e o comprimento do quadro podem ser conhecidos "antecipadamente, o correspondente primeiro coeficiente de interpolação a pode também ser determinado e armazenado antecipadamente baseado no atraso de codificação e decodificação e no comprimento de quadro. Especificamente, o primeiro coeficiente de interpolação a pode ser pré- armazenado no terminal de codificação. Deste modo, quando executando processamento de interpolação, o terminal de codificação pode executar diretamente o processamento de interpolação baseado no primeiro coeficiente de interpolação a pré-armazenado sem calcular um valor do primeiro coeficiente de interpolação àQa. Isto pode reduzir a complexidade de cálculo de um processo de codificação e melhorar a eficiência de codificação.
[0091] Modo 2: a diferença de tempo entre canais no quadro atual é calculada de acordo com uma fórmula (5).
A=(1-B) eB+fBeC (5)
[0092] Na fórmula (5), A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, B é um segundo coeficiente de interpolação, e é um número real que satisfaz O<fB<1l.
[0093] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula A=(1-B)eB+fbeC, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda, tanto quanto possível, a uma diferença de tempo entre canais de um sinal estéreo original que não é codificado e decodificado.
[0094] Especificamente, considerando-se que o quadro atual é um quadro de ordem i, o quadro anterior ao quadro atual é um quadro de ordem (i-l1). Neste caso, uma diferença de tempo entre canais no quadro de ordem i pode ser determinado de acordo com a fórmula (6).
d int(i) = (1-fB) -d(i) +B-d(i-1) (6)
[0095] Na fórmula (6), d int(i) é uma diferença de tempo entre canais no quadro de ordem i, d(i) é a diferença de tempo entre canais no quadro atual, d(i-l1) é uma diferença de tempo entre canais no quadro de ordem (i-1), e fp tem o mesmo significado que BB na fórmula (5) e é também um segundo coeficiente de interpolação.
[0096] O coeficiente de interpolação precedente pode ser diretamente definido pelo pessoal técnico. Por exemplo, o segundo coeficiente de interpolação fBº pode ser diretamente definido para 0,6 ou 0,4.
[0097] Além disso, o segundo coeficiente de interpolação º pode também ser determinado baseado em um comprimento de quadro do quadro atual e um atraso de codificação e decodificação. O atraso de codificação e decodificação neste documento pode incluir um atraso de codificação em um processo de codificação, pelo terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, pelo terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e de um sinal de canal secundário. Além disso, o atraso de codificação e decodificação aqui pode ser uma soma do atraso de codificação e do atraso de decodificação.
[0098] Opcionalmente, o segundo coeficiente de interpolação RB pode ser especificamente diretamente proporcional ao atraso de codificação e decodificação. Além disso, o segundo coeficiente de interpolação BR pode ser especificamente inversamente proporcional ao comprimento de quadro do quadro atual.
[0099] Opcionalmente, o segundo coeficiente de interpolação À pode ser determinado de acordo com uma fórmula (7).
B=S/N (7)
[00100] Na fórmula (7), N é o comprimento de quadro do quadro atual e S é o atraso de codificação e decodificação.
[00101] Quando N=320 e S=192, o seguinte pode ser obtido de acordo com a fórmula (7): B=S/N = 192/320 = 0,6 (8)
[00102] Finalmente, pode ser obtido que o segundo coeficiente de interpolação f é 0,6.
[00103] Alternativamente, o segundo coeficiente de interpolação À é pré-armazenado. Como o atraso de codificação e decodificação e o comprimento do quadro podem ser conhecidos antecipadamente, o correspondente segundo coeficiente de interpolação À pode também ser determinado e armazenado antecipadamente baseado no atraso de codificação e decodificação e no comprimento de quadro. Especificamente, o segundo coeficiente de interpolação B pode ser pré- armazenado no terminal de codificação. Deste modo, quando executando processamento de interpolação, o terminal de codificação pode executar diretamente o processamento de interpolação baseado no segundo coeficiente de interpolação B pré-armazenado sem calcular um valor do segundo coeficiente de interpolação RB. Isto pode reduzir a complexidade de cálculo de um processo de codificação e melhorar a eficiência de codificação.
[00104] 430. Executar alinhamento de atraso em um sinal estéreo no quadro atual baseado na diferença de tempo entre canais no quadro atual, para obter um sinal estéreo após o alinhamento de atraso no quadro atual.
[00105] Quando alinhamento de atraso é executado no sinal do canal esquerdo e no sinal do canal direito no quadro atual, um ou dois do sinal do canal esquerdo e do sinal do canal direito podem ser comprimidos ou estendidos com base na diferença de tempo entre canais no quadro atual, de modo que não exista diferença de tempo entre canais entre um sinal do canal esquerdo e um sinal do canal direito após o alinhamento de atraso. O sinal do canal esquerdo e o sinal do canal direito após o alinhamento de atraso no quadro atual, que são obtidos após o alinhamento de atraso ser executado no sinal do canal esquerdo e no sinal do canal direito no quadro atual, são sinais estéreo após o alinhamento de atraso no quadro atual.
[00106] 440. Executar processamento de mixagem descendente no domínio do tempo no sinal estéreo após o alinhamento de atraso no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário no quadro atual.
[00107] Quando processamento de mixagem descendente no domínio do tempo é executado no sinal do canal esquerdo e no sinal do canal direito após o alinhamento de atraso, o sinal do canal esquerdo e o sinal do canal direito podem ser mixados descendentemente para um sinal de canal intermediário (Mid channel) e um sinal de canal lateral (Side channel). O sinal de canal intermediário pode indicar informação correlata entre o canal esquerdo e o canal direito, e o sinal de canal lateral pode indicar informação de diferença entre o canal esquerdo e o canal direito.
[00108] Considerando-se que L representa o sinal do canal esquerdo e R representa o sinal do canal direito, o sinal do canal intermediário é 0,5x(L+R) e o sinal de canal lateral é 0,5x(L-R).
[00109] Além disso, quando processamento de mixagem descendente no domínio do tempo é executado no sinal do canal esquerdo e no sinal do canal direito após o alinhamento de atraso, para controlar uma razão do sinal do canal esquerdo e do sinal do canal direito no processamento de mixagem descendente, pode ser calculado um fator de escala de combinação de canais, e então ser executado processamento de mixagem descendente no domínio do tempo no sinal do canal esquerdo e no sinal do canal direito para o fator de escala de combinação de canais, para obter um sinal de canal principal e um sinal de canal secundário.
[00110] Existe uma pluralidade de métodos para calcular o fator de escala de combinação de canais. Por exemplo, um fator de escala de combinação de canais no quadro atual pode ser calculado baseado na energia de quadro do canal esquerdo e do canal direito. Um processo específico é como segue: (1). Calcular energia de quadro do sinal do canal esquerdo e do sinal do canal direito baseada no sinal do canal esquerdo e no sinal do canal direito após o alinhamento de atraso no quadro atual.
[00111] A energia de quadro rms L do canal esquerdo no quadro atual satisfaz:
1 Ne ms L=e—Nx(N*x() (9) Ns
[00112] A energia de quadro rms L do canal direito no quadro atual satisfaz: ms RL SO) (10) No
[00113] x'1(n) é o sinal do canal esquerdo após o alinhamento de atraso no quadro atual, x'x(n) é o sinal do canal direito após o alinhamento de atraso no quadro atual, n é um número de pontos de amostragem e n=0, 1, ..., N-1l.
[00114] (2). Calcular o fator de escala de combinação de canais no quadro atual baseado na energia de quadro do canal esquerdo e do canal direito.
[00115] A razão do fator de escala de combinação de canais razão no quadro atual satisfaz: razão a, (11) rms L+rms R
[00116] Portanto, o fator de escala de combinação de canais é calculado baseado na energia de quadro do sinal do canal esquerdo e do sinal do canal direito.
[00117] Após a razão do fator de escala de combinação de canais ser obtido, pode ser executado processamento de mixagem descendente no domínio do tempo baseado na razão do fator de escala de combinação de canais. Por exemplo, o sinal de canal principal e o sinal de canal secundário após o processamento de mixagem descendente no domínio do tempo pode ser determinado de acordo com a fórmula (12).
[al E + x (n) (12) X(n)) li-razão — razão [ão
[00118] Y(n) é o sinal de canal principal no quadro atual, X(n) é o sinal de canal secundário no quadro atual, x'1(n) é o sinal do canal esquerdo após o alinhamento de atraso no quadro atual, x'"r(n) é o sinal do canal direito após o alinhamento de atraso no quadro atual, n é o número de pontos de amostragem, n=0, 1, ..., N-1, Né o comprimento de quadro e razão é o fator de escala de combinação de canais.
[00119] (3) . Quantizar o fator de escala de combinação de canais e gravar um fator de escala de combinação de canais quantizado em um fluxo de bits.
[00120] 450. Quantizar a diferença de tempo entre canais após o processamento de interpolação no quadro atual e gravar uma diferença de tempo entre canais quantizada em um fluxo de bits.
[00121] Especificamente, em um processo de quantização da diferença de tempo entre canais após o processamento de interpolação no quadro atual, qualquer algoritmo de quantização no estado da técnica pode ser usado para quantizar a diferença de tempo entre canais após o processamento de interpolação no quadro atual, para obter um índice de quantização. Em seguida o índice de quantização é codificado e então gravado em um fluxo de bits.
[00122] 460. Quantizar o sinal de canal principal e o sinal de canal secundário no quadro atual, e gravar um sinal de canal principal quantizado e um sinal de canal secundário quantizado no fluxo de bits.
[00123] Opcionalmente, um método de codificação e decodificação de sinal monofônico pode ser usado para codificar o sinal de canal principal e o sinal de canal secundário que são obtidos após o processamento de mixagem descendente. Especificamente, bits de codificação de um canal principal e de um canal secundário podem ser alocados baseados em informação de parâmetro obtido em um processo de codificação de um sinal de canal principal no quadro anterior e/ou de um sinal de canal secundário no quadro anterior e no número total de bits de codificação do sinal de canal principal e do sinal de canal secundário. Então, o sinal de canal principal e o sinal de canal secundário são codificados separadamente com base em um resultado de alocação de bits, para obter um índice de codificação de codificação do canal principal e um índice de codificação de codificação do canal secundário.
[00124] Deve ser entendido que o fluxo de bits obtido após a etapa 460 inclui um fluxo de bits que é obtido após a diferença de tempo entre canais após o processamento de interpolação no quadro atual ser quantizado e um fluxo de bits que é obtido após o sinal de canal principal e o sinal de canal secundário serem quantizados.
[00125] Opcionalmente, no método 400, o fator de escala de combinação de canais que é usado quando processamento de mixagem descendente no domínio do tempo é executado na etapa 440 pode ser quantizado, para obter um fluxo de bits correspondente.
[00126] Portanto, o fluxo de bits finalmente obtido no método 400 pode incluir o fluxo de bits que é obtido após a diferença de tempo entre canais após o processamento de interpolação no quadro atual ser quantizado, o fluxo de bits que é obtido após o sinal de canal principal e o sinal de canal secundário no quadro atual serem quantizados, e o fluxo de bits que é obtido após o fator de escala de combinação de canais ser quantizado.
[00127] Neste pedido, a diferença de tempo entre canais no quadro atual é usada no terminal de codificação para executar alinhamento de atraso, para obter o sinal de canal principal e o sinal de canal secundário. Contudo, processamento de interpolação é executado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, de modo que a diferença de tempo entre canais no quadro atual que é obtida após o processamento de interpolação possa corresponder ao sinal de canal principal e ao sinal de canal secundário que são obtidos por codificação e decodificação. A diferença de tempo entre canais após o processamento de interpolação é codificada e então transmitida ao terminal de decodificação, de modo que o terminal de decodificação possa executar decodificação baseada na diferença de tempo entre canais no quadro atual que corresponda ao sinal de canal principal e ao sinal de canal secundário que são obtidos por decodificação. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtida por decodificação é melhorada.
[00128] Deve ser entendido que o fluxo de bits finalmente obtido no método 400 pode ser transmitido ao terminal de decodificação, e o terminal de decodificação pode decodificar o fluxo de bits recebido para obter o sinal de canal principal e o sinal de canal secundário no quadro atual e a diferença de tempo entre canais no quadro atual, e ajustar, baseado na diferença de tempo entre canais no quadro atual, um atraso de um sinal do canal esquerdo reconstruído e de um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo, para obter um sinal estéreo decodificado. Um processo específico executado pelo terminal de decodificação pode ser o mesmo que o processo do método de decodificação de estéreo no domínio do tempo no estado da técnica mostrado na FIG. 2.
[00129] O terminal de decodificação decodifica o fluxo de bits gerado no método 400, e uma diferença entre um sinal no sinal estéreo finalmente obtido e o mesmo sinal no sinal estéreo original pode ser mostrado na FIG. 5. Por comparação da FIG. 5 e da FIG. 3, pode ser verificado que, em comparação com a FIG. 3, na FIG. 5, um atraso entre o sinal no sinal estéreo que é finalmente obtido por decodificação e o mesmo sinal no sinal estéreo original se torna muito pequeno. Particularmente, quando o valor da diferença de tempo entre canais muda enormemente (como mostrado por uma área em um quadro retangular na FIG. 5), um atraso entre o sinal no sinal de canal que é finalmente obtido pelo terminal de decodificação e o mesmo sinal no sinal de canal original é também muito pequeno. Em outras palavras, de acordo com o método de codificação para um sinal estéreo nesta modalidade deste pedido, um desvio entre a diferença de tempo entre canais do sinal estéreo que é finalmente obtido por decodificação e a diferença de tempo entre sinais no sinal estéreo original pode ser reduzida.
[00130] Deve ser entendido que processamento de mixagem descendente pode ser ainda implementado neste documento de outro modo, para obter o sinal de canal principal e o sinal de canal secundário.
[00131] Um processo detalhado do método de codificação para um sinal estéreo nas modalidades deste pedido é descrito abaixo com referência à FIG. 6.
[00132] A FIG. 6 é um fluxograma esquemático de um método de codificação para um sinal estéreo de acordo com uma modalidade deste pedido. O método 600 pode ser executado por um terminal de codificação, e o terminal de codificação pode ser um codificador ou um dispositivo que tenha uma função de codificação de um sinal de canal. O método 600 inclui especificamente as etapas a seguir.
[00133] 610. Executar pré-processamento no domínio do tempo em um sinal estéreo, para obter um sinal do canal esquerdo e um sinal do canal direito após o pré- processamento.
[00134] Especificamente, o pré-processamento no domínio do tempo no sinal estéreo pode ser implementado mediante utilização de filtragem passa-alta, processamento de pré-ênfase, ou similar.
[00135] 620. Executar estimação de atraso baseada no sinal do canal esquerdo e no sinal do canal direito após o pré-processamento no quadro atual, para obter uma diferença de tempo estimada entre canais no quadro atual.
[00136] A diferença de tempo estimada entre canais no quadro atual é equivalente à diferença de tempo entre canais no quadro atual no método 400.
[00137] 630. Executar alinhamento de atraso no sinal do canal esquerdo e no sinal do canal direito baseado na diferença de tempo estimada entre canais no quadro atual, para obter um sinal estéreo após o alinhamento de atraso.
[00138] 640. Executar processamento de interpolação na diferença de tempo estimada entre canais.
[00139] Uma diferença de tempo entre canais após o processamento de interpolação é equivalente à diferença de tempo entre canais após o processamento de interpolação no quadro atual na descrição precedente.
[00140] 650. Quantizar a diferença de tempo entre canais após o processamento de interpolação.
[00141] 660. Determinar um fator de escala de combinação de canais baseado no sinal estéreo após o alinhamento de atraso, e quantizar o fator de escala de combinação de canais.
[00142] 670. Executar, com base no fator de escala de combinação de canais, processamento de mixagem descendente no domínio do tempo em um sinal do canal esquerdo e um sinal do canal direito que são obtidos após o alinhamento de atraso, para obter um sinal de canal principal e um sinal de canal secundário.
[00143] 680. Codificar, mediante utilização de um método de codificação e decodificação de sinal monofônico, o sinal de canal principal e o sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo.
[00144] A seguir descreve-se em detalhe o método de codificação para um sinal estéreo nas modalidades deste pedido com referência às FIGS. 4 a 6. Deve ser entendido que um método de codificação correspondente ao método de codificação de um sinal estéreo nas modalidades descritas com referência às FIGS. 4 a 6 neste pedido pode ser um método de codificação existente para um sinal estéreo. Especificamente, o método de decodificação correspondente ao método de codificação para um sinal estéreo nas modalidades descritas com referência às FIGS. 4 a 6 neste pedido pode ser o método de decodificação 200 mostrado na FIG. 2.
[00145] A seguir descreve-se em detalhe o método de decodificação para um sinal estéreo nas modalidades deste pedido com referência às FIGS. 7 e 8. Deve ser entendido que um método de codificação correspondente ao método de decodificação para um sinal estéreo nas modalidades descritas com referência às FIGS. 7 e 8 neste pedido pode ser um método de codificação existente para um sinal estéreo, mas não pode ser o método de codificação para um sinal estéreo nas modalidades descritas com referência às FIGS. 4 a 6 neste pedido.
[00146] A FIG. 7 é um fluxograma esquemático de um método de decodificação para um sinal estéreo de acordo com uma modalidade deste pedido. O método 700 pode ser executado por um terminal de decodificação, e o terminal de decodificação pode ser um decodificador ou um dispositivo que tenha uma função de decodificação de um sinal estéreo. O método 700 inclui especificamente as etapas a seguir.
[00147] 710. Decodificar um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário em um quadro atual, e uma diferença de tempo entre canais no quadro atual.
[00148] Deve ser entendido que, na etapa 710, um método para decodificar o sinal de canal principal necessita corresponder a um método para codificar o sinal de canal principal por um terminal de codificação. Similarmente, um método para decodificar o sinal de canal secundário necessita corresponder a um método para codificar o sinal de canal secundário pelo terminal de codificação.
[00149] Opcionalmente, o fluxo de bits na etapa 710 pode ser um fluxo de bits recebido pelo terminal de decodificação.
[00150] Deve ser entendido que um sinal estéreo processado neste documento pode incluir um sinal do canal esquerdo e um sinal do canal direito, e a diferença de tempo entre canais no quadro atual pode ser obtido por estimação, pelo terminal de codificação, de um atraso do sinal do canal esquerdo e do sinal do canal direito, e em seguida a diferença de tempo entre canais no quadro atual ser quantizada antes de ser transmitida ao terminal de decodificação (a diferença de tempo entre canais no quadro atual pode ser especificamente determinada após o terminal de decodificação decodificar o fluxo de bits recebido). Por exemplo, o terminal de codificação calcula uma função de correlação cruzada de um canal esquerdo e de um canal direito baseada em um sinal do canal esquerdo e um sinal do canal direito no quadro atual, em seguida usa um valor de índice correspondente a um valor máximo da função de correlação cruzada como a diferença de tempo entre canais no quadro atual, quantiza e codifica a diferença de tempo entre canais no quadro atual, e transmite uma diferença de tempo entre canais quantizada ao terminal de decodificação. O terminal de decodificação decodifica o fluxo de bits recebido para determinar a diferença de tempo entre canais no quadro atual. Um modo específico no qual o terminal de codificação estima o atraso do sinal do canal esquerdo e do sinal do canal direito pode ser mostrado pelo exemplo 1 ao exemplo 3 na descrição precedente.
[00151] 720. Executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário no quadro atual, para obter um sinal do canal esquerdo reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo.
[00152] Especificamente, o processamento de mixagem ascendente no domínio do tempo pode ser executado, baseado em um fator de escala de combinação de canais, no sinal de canal principal e no sinal de canal secundário no quadro atual que são obtidos por decodificação, para obter o sinal do canal esquerdo reconstruído e o sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo (que podem também ser referidos como um sinal do canal esquerdo e um sinal do canal direito que são obtidos após o processamento de mixagem ascendente no domínio do tempo).
[00153] Deve ser entendido que o terminal de codificação e o terminal de decodificação podem usar muitos métodos para executar processamento de mixagem descendente no domínio do tempo e processamento de mixagem ascendente no domínio do tempo, respectivamente. Contudo, um método para executar processamento de mixagem ascendente no domínio do tempo pelo terminal de decodificação necessita corresponder a um método para executar processamento de mixagem descendente no domínio do tempo pelo terminal de codificação. Por exemplo, quando o terminal de codificação obtém o sinal de canal principal e o sinal de canal secundário de acordo com a fórmula (12), o terminal de decodificação pode primeiro obter o fator de escala de combinação de canais por decodificação do fluxo de bits recebido, e em seguida obter o sinal do canal esquerdo e o sinal do canal direito que são obtidos após o processamento de mixagem ascendente no domínio do tempo de acordo com uma fórmula (13). H à à. 1 “ razão = aa | e. EA) — razão +(L-razão) 1-razão — razão in) (13) Na fórmula (13), x'/1(n) é o sinal do canal esquerdo após o processamento de mixagem ascendente no domínio do tempo no quadro atual, x'r(n) é o sinal do canal direito após o processamento de mixagem ascendente no domínio do tempo no quadro atual, Y(n) é o sinal de canal principal no quadro atual que é obtido por decodificação, X(n) é o sinal de canal secundário no quadro atual que é obtido por decodificação, n é um número de pontos de amostragem, n=0, 1, ..., N-1, N é um comprimento de quadro e razão é o fator de escala de combinação de canais que é obtido por decodificação.
[00154] 730. Executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual.
[00155] Na etapa 730, a execução do processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais em um quadro anterior ao quadro atual é equivalente à execução do processamento médio ponderado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais em um quadro anterior ao quadro atual. Deste modo, a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual está entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais em um quadro anterior ao quadro atual.
[00156] Na etapa 730, o modo 3 e o modo 4 a seguir podem ser usados quando processamento de interpolação é executado baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual.
[00157] Modo 3: a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula (14).
A=aeB+ (1-a) eC (14)
[00158] Na fórmula (14), A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, Céa diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação, eaé un número real que satisfaz O<a<l.
[00159] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula A=aeB+(1-a)eC, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda, tanto quanto possível, a uma diferença de tempo entre canais de um sinal estéreo original que não é codificado e decodificado.
[00160] Considerando-se que o quadro atual seja um quadro de ordem i, o quadro anterior ao quadro atual é um quadro de ordem (i-l). Neste caso, a fórmula (14) pode ser transformada em uma fórmula (15).
d int(i) = a-d(i)+(1-0) -d(i-1) (15)
[00161] Na fórmula (15), d int(i) é uma diferença de tempo entre canais após o processamento de interpolação no quadro de ordem i, d(i) é a diferença de tempo entre canais no quadro atual, d(i-l1) é uma diferença de tempo entre canais no quadro de ordem (i-1).
[00162] O primeiro coeficiente de interpolação a nas fórmulas (14) e (15) pode ser diretamente definido pelo pessoal técnico (pode ser diretamente definido de acordo com experiência). Por exemplo, o primeiro coeficiente de interpolação à pode ser diretamente definido como 0,4 ou 0,6.
[00163] Opcionalmente, o coeficiente de interpolação a pode também ser determinado baseado em um comprimento de quadro do quadro atual e um atraso de codificação e decodificação. O atraso de codificação e decodificação neste documento pode incluir um atraso de codificação em um processo de codificação, pelo terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário. Além disso, o atraso de codificação e decodificação neste documento pode ser uma soma do atraso de codificação no terminal de codificação e do atraso de decodificação no terminal de decodificação.
[00164] Opcionalmente, o coeficiente de interpolação a pode ser especificamente inversamente proporcional ao atraso de codificação e decodificação, e o primeiro coeficiente de interpolação a ser diretamente proporcional ao comprimento de quadro do quadro atual. Em outras palavras, o primeiro coeficiente de interpolação a diminui à medida que o atraso de codificação e decodificação aumenta, e aumenta a medida que o comprimento de quadro do quadro atual aumenta.
[00165] Opcionalmente, o primeiro coeficiente de interpolação a pode ser determinado de acordo com uma fórmula (16).
a=(N-S)/N (16)
[00166] Na fórmula (16), Né o comprimento de quadro do quadro atual e S é o atraso de codificação e decodificação.
[00167] Considere-se que o comprimento de quadro do quadro atual seja 320 e o atraso de codificação e decodificação seja 192, em outras palavras N=320 e S=192. Neste caso, N e S são substituídos na fórmula (16) para obter:
a=(N-S) /N= (320-192) /320=0,4 (17)
[00168] Finalmente, pode ser obtido que o primeiro coeficiente de interpolação a é 0,4.
[00169] Opcionalmente, o primeiro coeficiente de interpolação a é pré-armazenado. Especificamente, o primeiro coeficiente de interpolação à pode ser pré-armazenado no terminal de decodificação. Deste modo, quando executando processamento de interpolação, o terminal de decodificação pode executar diretamente o processamento de interpolação baseado no primeiro coeficiente de interpolação a pré- armazenado sem calcular um valor do primeiro coeficiente de interpolação a. Isto pode reduzir a complexidade de cálculo de um processo de codificação e melhorar a eficiência de codificação.
[00170] Modo 4: a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula (18).
A=(1-B) eB+fBec (18)
[00171] Na fórmula (18), A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, Céa diferença de tempo entre canais no quadro anterior ao quadro atual, e À é um segundo coeficiente de interpolação, e é um número real que satisfaz O<fB<1.
[00172] A diferença de tempo entre canais pode ser ajustada mediante utilização da fórmula A=(1-B)eB+fbeC, de modo que a diferença de tempo entre canais finalmente obtida após o processamento de interpolação no quadro atual esteja entre a diferença de tempo entre canais no quadro atual e a diferença de tempo entre canais no quadro anterior ao quadro atual, e a diferença de tempo entre canais após o processamento de interpolação no quadro atual corresponda, tanto quanto possível, a uma diferença de tempo entre canais de um sinal estéreo original que não é codificado e decodificado.
[00173] Considerando-se que o quadro atual seja um quadro de ordem i, o quadro anterior ao quadro atual é um quadro de ordem (i-l). Neste caso, a fórmula (18) pode ser transformada na fórmula a seguir: d int(i) = (1-fB) -d(i) +B-d(i-1) (19)
[00174] Na fórmula (19), d int(i) é uma diferença de tempo entre canais após o processamento de interpolação no quadro de ordem i, d(i) é a diferença de tempo entre canais no quadro atual, d(i-l1) é uma diferença de tempo entre canais no quadro de ordem (i-1).
[00175] De modo similar à configuração do primeiro coeficiente de interpolação a, o segundo coeficiente de interpolação Bº pode também ser determinado diretamente pelo pessoal técnico (pode ser definido diretamente de acordo com a experiência). Por exemplo, o segundo coeficiente de interpolação º pode ser diretamente definido para 0,6 ou 0,4.
[00176] Opcionalmente, o segundo coeficiente de interpolação | pode também ser determinado baseado em um comprimento de quadro do quadro atual e um atraso de codificação e decodificação. O atraso de codificação e decodificação neste documento pode incluir um atraso de codificação em um processo de codificação, pelo terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário. Além disso, o atraso de codificação e decodificação neste documento pode ser uma soma do atraso de codificação e do atraso de decodificação no terminal de decodificação.
[00177] Opcionalmente, o segundo coeficiente de interpolação RB pode ser especificamente diretamente proporcional ao atraso de codificação e decodificação, e ser inversamente proporcional ao comprimento de quadro do quadro atual. Em outras palavras, o segundo coeficiente de interpolação À aumenta à medida que o atraso de codificação e decodificação aumenta, e diminui à medida que o comprimento de quadro do quadro atual aumenta.
[00178] Opcionalmente, o segundo coeficiente de interpolação À pode ser determinado de acordo com uma fórmula (20).
B=S/N (20)
[00179] Na fórmula (20), Né o comprimento de quadro do quadro atual e S é o atraso de codificação e decodificação.
[00180] Considere-se que N=320 e S=192. Neste caso, N=320 e S=192 são substituídos na fórmula (20) para obter: B=S/N=192/320=0,6 (21)
[00181] Finalmente, pode ser obtido que o segundo coeficiente de interpolação f é 0,6.
[00182] Opcionalmente, o segundo coeficiente de interpolação À é pré-armazenado. Especificamente, o segundo coeficiente de interpolação fê pode ser pré-armazenado no terminal de decodificação. Deste modo, quando executando processamento de interpolação, o terminal de decodificação pode executar diretamente o processamento de interpolação baseado no segundo coeficiente de interpolação | pré- armazenado sem calcular um valor do segundo coeficiente de interpolação À. Isto pode reduzir a complexidade de cálculo de um processo de decodificação e melhorar a eficiência de decodificação.
[00183] 740. Ajustar um atraso do sinal do canal esquerdo —“reconstruído e do sinal do canal direito reconstruído baseado na diferença de tempo entre canais no quadro atual.
[00184] Deve ser entendido que, opcionalmente, oO sinal do canal esquerdo reconstruído e o sinal do canal direito reconstruído que são obtidos após o ajuste de atraso são sinais estéreo decodificados.
[00185] Opcionalmente, após a etapa 740, o método pode ainda incluir obter os sinais estéreo decodificados baseado no sinal do canal esquerdo reconstruído e no sinal do canal direito reconstruído que são obtidos após o ajuste de atraso. Por exemplo, é executado processamento de ênfase no sinal do canal esquerdo reconstruído e no sinal do canal direito reconstruído que são obtidos após o ajuste de atraso, para obter os sinais estéreo decodificados. Para outro exemplo, é executado pós-processamento no sinal do canal esquerdo reconstruído e no sinal do canal direito reconstruído que são obtidos após o ajuste de atraso, para obter os sinais estéreo decodificados.
[00186] Neste pedido, ao executar processamento de interpolação na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, a diferença de tempo entre canais após o processamento .—. de interpolação no quadro atual pode corresponder ao sinal de canal principal e ao sinal de canal secundário que são obtidos por decodificação atualmente. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtido por decodificação é melhorada.
[00187] Especificamente, uma diferença entre um sinal no sinal estéreo finalmente obtido no método 700 e o mesmo sinal no sinal estéreo original pode ser mostrada na FIG. 5. Comparando a FIG. 5 e a FIG. 3, pode ser verificado que, na FIG. 5, um atraso entre o sinal no sinal estéreo que é finalmente obtido por decodificação e o mesmo sinal no sinal estéreo original se torna muito pequeno. Particularmente, quando o valor da diferença de tempo entre canais muda enormemente “(como mostrado por uma área em um quadro retangular na FIG. 5), um desvio de atraso entre o sinal de canal que é finalmente obtido pelo terminal de decodificação e o sinal de canal original é também muito pequeno. Em outras palavras, de acordo com o método de decodificação para um sinal estéreo nesta modalidade deste pedido, um desvio de atraso entre o sinal no sinal estéreo que é finalmente obtido por decodificação e o mesmo sinal no sinal estéreo original pode ser reduzido.
[00188] Deve ser entendido que o método de codificação do terminal de codificação correspondente ao método 700 pode ser um método de codificação estéreo existente no domínio do tempo. Por exemplo, o método de codificação estéreo no domínio do tempo correspondente ao método 700 pode ser o método 100 mostrado na FIG. 1.
[00189] Um processo detalhado do método de decodificação para um sinal estéreo nas modalidades deste pedido é descrito abaixo com referência à FIG. 8.
[00190] A FIG. 8 é um fluxograma esquemático de um método de decodificação para um sinal estéreo de acordo com uma modalidade deste pedido. O método 800 pode ser executado por um terminal de decodificação, e o terminal de decodificação pode ser um decodificador ou um dispositivo que tenha uma função de decodificação de um sinal de canal. O método 800 inclui especificamente as etapas a seguir.
[00191] 810. Decodificar um sinal de canal principal e um sinal de canal secundário respectivamente baseados em um fluxo de bits recebido.
[00192] Especificamente, um método de decodificação para decodificar o sinal de canal principal pelo terminal de decodificação corresponde a um método de codificação para codificar o sinal de canal principal por um terminal de codificação. Um método de decodificação para decodificar o sinal de canal secundário pelo terminal de decodificação corresponde a um método de codificação para codificar o sinal de canal secundário por um terminal de codificação.
[00193] 820. Decodificar o fluxo de bits recebido para obter um fator de escala de combinação de canais.
[00194] Especificamente, o fluxo de bits recebido pode ser decodificado para obter um índice de codificação do fator de escala de combinação de canais, e então o fator de escala de combinação de canais é obtido pela decodificação baseada no índice de codificação obtido do fator de escala de combinação de canais.
[00195] 830. Executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário baseado no fator de escala de combinação de canais, para obter um sinal do canal esquerdo reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo.
[00196] 840. Decodificar o fluxo de bits recebido para obter uma diferença de tempo entre canais em um quadro atual.
[00197] 850. Executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual que é obtido por decodificação de uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após oO processamento de interpolação no quadro atual.
[00198] 860. Ajustar, com base na diferença de tempo entre canais após o processamento de interpolação, um atraso do canal esquerdo reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo, para obter um sinal estéreo decodificado.
[00199] Deve ser entendido que, neste pedido, o processo de execução do processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual pode ser executado no terminal de codificação ou no terminal de decodificação. Após o processamento de interpolação ser executado no terminal de codificação baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior, o processamento de interpolação não necessita ser executado no terminal de decodificação, a diferença de tempo entre canais após o processamento de interpolação no quadro atual pode ser obtido diretamente baseado no fluxo de bits, e subsequente ajuste de atraso é executado baseado na diferença de tempo entre canais após o processamento de interpolação no quadro atual. Contudo, quando oO processamento de interpolação não é executado no terminal de codificação, o terminal de decodificação necessita executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior, e em seguida executar subsequente ajuste de atraso baseado na diferença de tempo entre canais após o processamento de interpolação no quadro atual que é obtido por meio do processamento de interpolação.
[00200] A seguir descrevem-se em detalhe os métodos de codificação e decodificação para um sinal estéreo nas modalidades deste pedido com referência às FIGS. 1 a 8. A seguir descrevem-se os aparelhos de codificação e decodificação para um sinal estéreo nas modalidades deste pedido com referência às FIGS. 9 a 12. Deve ser entendido que o aparelho de codificação nas FIGS. 9 a 12 é correspondente ao método de codificação para um sinal estéreo nas modalidades deste pedido, e que o aparelho de codificação pode executar o método de codificação para um sinal estéreo nas modalidades deste pedido. O aparelho de decodificação nas FIGS. 9 a 12 é correspondente ao método de decodificação para um sinal estéreo nas modalidades deste pedido, e o aparelho de decodificação pode executar o método de decodificação para um sinal estéreo nas modalidades deste pedido. Por uma questão de brevidade, descrições repetidas são adequadamente omitidas abaixo.
[00201] A FIG. 9 é um diagrama de blocos esquemático de um aparelho de codificação de acordo com uma modalidade deste pedido. O aparelho de codificação 900 mostrado na FIG. 9 inclui: um módulo de determinação 910, configurado para determinar uma diferença de tempo entre canais em um quadro atual; um módulo de interpolação 920, configurado para executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após oO processamento de interpolação no quadro atual; um módulo de alinhamento de atraso 930, configurado para executar alinhamento de atraso em um sinal estéreo no quadro atual baseado na diferença de tempo entre canais no quadro atual, para obter um sinal estéreo após o alinhamento de atraso no quadro atual; um módulo de mixagem descendente 940, configurado para executar processamento de mixagem descendente no domínio do tempo no sinal estéreo após o alinhamento de atraso no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário no quadro atual; e um módulo de codificação 950, configurado para quantizar a diferença de tempo entre canais após o processamento de interpolação no quadro atual, e gravar uma diferença de tempo entre canais quantizada em um fluxo de bits.
[00202] Oo módulo de codificação 950 é ainda configurado para quantizar o sinal de canal principal e o sinal de canal secundário no quadro atual, e gravar um sinal de canal principal quantizado e o sinal de canal secundário quantizado no fluxo de bits.
[00203] Neste pedido, a diferença de tempo entre canais no quadro atual é usada no aparelho de codificação para executar alinhamento de atraso, para obter o sinal de canal principal e o sinal de canal secundário. Contudo, processamento de interpolação é executado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, de modo que a diferença de tempo entre canais no quadro atual que é obtida após o processamento de interpolação possa corresponder ao sinal de canal principal e ao sinal de canal secundário que são obtidos por codificação e decodificação. A diferença de tempo entre canais após o processamento de interpolação é codificada e em seguida transmitida ao terminal de decodificação, de modo que o terminal de decodificação possa executar decodificação baseada na diferença de tempo entre canais no quadro atual que corresponda ao sinal de canal principal e ao sinal de canal secundário que são obtidos por decodificação. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtido por decodificação é melhorada.
[00204] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=aeB+ (1-0a)eC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, Bé a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação, e O<a<l.
[00205] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[00206] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S) /N, onde S é o atraso de codificação e decodificação e Né o comprimento de quadro do quadro atual.
[00207] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é pré-armazenado.
[00208] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=(1- B) eB+fBeC.
[00209] Na fórmula, A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, B é um segundo coeficiente de interpolação, e O<B<1.
[00210] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário
[00211] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À satisfaz uma fórmula B=S/N, onde S é o atraso de codificação e decodificação e N é o comprimento de quadro do quadro atual.
[00212] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é pré-armazenado.
[00213] A FIG. 10 é um diagrama de blocos esquemático de um aparelho de decodificação de acordo com uma modalidade deste pedido. O aparelho de decodificação 1000 mostrado na FIG. 10 inclui: um módulo de decodificação 1010, configurado para decodificar um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário em um quadro atual, e uma diferença de tempo entre canais no quadro atual; um módulo de mixagem ascendente 1020, configurado para executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário que são obtidos após o processamento de mixagem ascendente no domínio do tempo; um módulo de interpolação 1030, configurado para executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; e um módulo de ajuste de atraso 1040, configurado para ajustar, baseado na diferença de tempo entre canais após o processamento de interpolação no quadro atual, um atraso do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem ascendente no domínio do tempo.
[00214] Neste pedido, ao executar processamento de interpolação na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, a diferença de tempo entre canais após o processamento .—. de interpolação no quadro atual pode corresponder ao sinal de canal principal e ao sinal de canal secundário que são obtidos por decodificação atualmente. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtido por decodificação é melhorada.
[00215] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=aeB+ (1-0a)eC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, Bé a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação, e O<a<l.
[00216] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[00217] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S) /N, onde S é o atraso de codificação e decodificação e Né o comprimento de quadro do quadro atual.
[00218] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é pré-armazenado.
[00219] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=(1- B)eB+BeC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, BP é um segundo coeficiente de interpolação, e O<fB<1l.
[00220] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário
[00221] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À satisfaz uma fórmula B=S/N, onde S é o atraso de codificação e decodificação e N é o comprimento de quadro do quadro atual.
[00222] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é pré-armazenado.
[00223] A FIG. 11 é um diagrama de blocos esquemático de um aparelho de codificação de acordo com uma modalidade deste pedido. O aparelho de codificação 1100 mostrado na FIG. 11 inclui: uma memória 1110, configurada para armazenar um programa; e um processador 1120, configurado para executar o programa armazenado na memória 1110, onde quando o programa na memória 1110 é executado, o processador 1120 é especificamente configurado para: executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e em uma diferença de tempo entre canais no quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; executar alinhamento de atraso em um sinal estéreo no quadro atual baseado na diferença de tempo entre canais no quadro atual, para obter um sinal estéreo após o alinhamento de atraso no quadro atual; executar processamento de mixagem descendente no domínio do tempo no sinal estéreo após o alinhamento de atraso no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário no quadro atual; quantizar a diferença de tempo entre canais após o processamento de interpolação no quadro atual, e gravar uma diferença de tempo quantizada entre canais em um fluxo de bits; e quantizar o sinal de canal principal e o sinal de canal secundário no quadro atual, e gravar um sinal de canal principal quantizado e um sinal de canal secundário quantizado no fluxo de bits.
[00224] Neste pedido, a diferença de tempo entre canais no quadro atual é usada no aparelho de codificação para executar alinhamento de atraso, para obter o sinal de canal principal e o sinal de canal secundário. Contudo, processamento de interpolação é executado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, de modo que a diferença de tempo entre canais no quadro atual que é obtida após o processamento de interpolação possa corresponder ao sinal de canal principal e ao sinal de canal secundário que são obtidos por codificação e decodificação. A diferença de tempo entre canais após o processamento de interpolação é codificada e em seguida transmitida ao terminal de decodificação, de modo que o terminal de decodificação possa executar decodificação baseada na diferença de tempo entre canais no quadro atual que corresponda ao sinal de canal principal e ao sinal de canal secundário que são obtidos por decodificação. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtido por decodificação é melhorada.
[00225] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=aeB+ (1-0a)eC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, Bé a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação, e O<a<l.
[00226] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[00227] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S)/N, onde S é o atraso de codificação e decodificação e Né o comprimento de quadro do quadro atual.
[00228] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é pré-armazenado.
[00229] O primeiro coeficiente de interpolação a pode ser armazenado na memória 1110.
[00230] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=(1- B) eB+feC.
[00231] Na fórmula, A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, B é um segundo coeficiente de interpolação, e O<B<1.
[00232] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário
[00233] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À satisfaz uma fórmula B=S/N, onde S é o atraso de codificação e decodificação e N é o comprimento de quadro do quadro atual.
[00234] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é pré-armazenado.
[00235] O segundo coeficiente de interpolação À pode ser armazenado na memória 1110.
[00236] A FIG. 12 é um diagrama de blocos esquemático de um aparelho de decodificação de acordo com uma modalidade deste pedido. O aparelho de decodificação 1200 mostrado na FIG. 12 inclui: uma memória 1210, configurada para armazenar um programa; e um processador 1220, configurado para executar o programa armazenado na memória 1210, onde quando o programa na memória 1210 é executado, o processador 1220 é especificamente configurado para: decodificar um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário em um quadro atual; executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário que são obtidos após o processamento de mixagem ascendente no domínio do tempo; executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; e ajustar, baseado na diferença de tempo entre canais após o processamento de interpolação no quadro atual, um atraso do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem ascendente no domínio do tempo.
[00237] Neste pedido, ao executar processamento de interpolação na diferença de tempo entre canais no quadro atual e na diferença de tempo entre canais no quadro anterior ao quadro atual, a diferença de tempo entre canais após o processamento .—. de interpolação no quadro atual pode corresponder ao sinal de canal principal e ao sinal de canal secundário que são obtidos por decodificação atualmente. Isto pode reduzir um desvio entre uma diferença de tempo entre canais de um sinal estéreo que é finalmente obtido por decodificação e uma diferença de tempo entre canais de um sinal estéreo original. Portanto, a precisão de uma imagem de som estéreo do sinal estéreo que é finalmente obtido por decodificação é melhorada.
[00238] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=aeB+ (1-0a)eC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, Bé a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação, e O<a<l.
[00239] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
[00240] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S) /N, onde S é o atraso de codificação e decodificação e Né o comprimento de quadro do quadro atual.
[00241] Opcionalmente, em uma modalidade, o primeiro coeficiente de interpolação a é pré-armazenado.
[00242] O primeiro coeficiente de interpolação a pode ser armazenado na memória 1210.
[00243] Opcionalmente, em uma modalidade, a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculada de acordo com uma fórmula A=(1- B)eB+BeC, onde A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, BP é um segundo coeficiente de interpolação, e O<fB<1l.
[00244] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, onde o atraso de codificação e decodificação inclui um atraso de codificação em um processo de codificação, por um terminal de codificação, de um sinal de canal principal e de um sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, de um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário
[00245] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À satisfaz uma fórmula B=S/N, onde S é o atraso de codificação e decodificação e N é o comprimento de quadro do quadro atual.
[00246] Opcionalmente, em uma modalidade, o segundo coeficiente de interpolação À é pré-armazenado.
[00247] O segundo coeficiente de interpolação À pode ser armazenado na memória 1210.
[00248] Deve ser entendido que os métodos de codificação e decodificação para um sinal estéreo nas modalidades deste pedido podem ser executados por um dispositivo terminal ou um dispositivo de rede nas FIGS. 13 a 15. Além disso, os aparelhos de codificação e decodificação nas modalidades deste pedido podem estar ainda posicionados no dispositivo terminal ou no dispositivo de rede nas FIGS. 13 a 15. Especificamente o aparelho de codificação nas modalidades deste pedido pode ser um codificador estéreo no dispositivo terminal ou no dispositivo de rede nas FIGS. 13 a 15, e o aparelho de decodificação nas modalidades deste pedido pode ser um decodificador estéreo no dispositivo terminal ou no dispositivo de rede nas FIGS. 13 a 15
[00249] Como mostrado na FIG. 13, em comunicação de áudio, um codificador estéreo em um primeiro dispositivo terminal executa codificação estéreo em um sinal estéreo coletado, e um codificador de canal no primeiro dispositivo terminal pode executar codificação de canal em um fluxo de bits obtido pelo codificador estéreo. Em seguida, os dados obtidos pelo primeiro dispositivo terminal após a codificação de canal são transmitidos a um segundo dispositivo terminal mediante utilização de um primeiro dispositivo de rede e um segundo dispositivo de rede. Após o segundo dispositivo terminal receber os dados do segundo dispositivo de rede, um decodificador de canal no segundo dispositivo terminal executa decodificação de canal, para obter um fluxo de bits codificado de sinal estéreo. Um decodificador estéreo no segundo dispositivo terminal então restaura um sinal estéreo por decodificação, e o dispositivo terminal reproduz o sinal estéreo. Deste modo, comunicação de áudio é completada entre diferentes dispositivos terminais.
[00250] Deve ser entendido que, na FIG. 13, o segundo dispositivo terminal pode também codificar um sinal estéreo coletado, e finalmente transmitir, mediante utilização do segundo dispositivo de rede e do primeiro dispositivo de rede, dados que são finalmente obtidos por codificação ao primeiro dispositivo terminal. O primeiro dispositivo terminal executa decodificação de canal e decodificação estéreo nos dados para obter um sinal estéreo.
[00251] Na FIG. 13, o primeiro dispositivo de rede e o segundo dispositivo de rede podem ser dispositivos de comunicações de rede sem fio ou dispositivos de comunicações de rede com fio. O primeiro dispositivo de rede e o segundo dispositivo de rede podem comunicar-se entre si mediante utilização de um canal digital.
[00252] O primeiro dispositivo terminal ou o segundo dispositivo terminal na FIG. 13 pode executar os métodos de codificação e decodificação para um sinal estéreo nas modalidades deste pedido. Os aparelhos de codificação e decodificação nas modalidades deste pedido podem ser respectivamente o codificador estéreo e o decodificador estéreo no primeiro dispositivo terminal ou no segundo dispositivo terminal.
[00253] Em comunicação de áudio, um dispositivo de rede pode implementar transcodificação de um formato de codificação e decodificação de um sinal de áudio. Como mostrado na FIG. 14, se um formato de codificação e decodificação de um sinal recebido por um dispositivo de rede é um formato de codificação e decodificação correspondente a outro decodificador estéreo, um decodificador de canal no dispositivo de rede executa decodificação de canal no sinal recebido, para obter um fluxo de bits codificado correspondente ao outro decodificador estéreo. O outro decodificador estéreo decodifica o fluxo de bits codificado, para obter um sinal estéreo. Um codificador estéreo codifica o sinal estéreo para obter um fluxo de bits codificado do sinal estéreo. Finalmente, um codificador de canal executa codificação de canal no fluxo de bits codificado do sinal estéreo, para obter um sinal final (o sinal pode ser transmitido a um dispositivo terminal ou outro dispositivo de rede). Deve ser entendido que um formato de codificação e decodificação correspondente ao codificador estéreo na FIG. 14 é diferente do formato de codificação e decodificação correspondente ao outro decodificador estéreo. Considere-se que o formato de codificação e decodificação correspondente ao outro decodificador estéreo seja um primeiro formato de codificação e decodificação, e o formato de codificação e decodificação correspondente ao codificador estéreo seja um segundo formato de codificação e decodificação. Na FIG. 14, o dispositivo de rede converte o sinal de áudio do primeiro formato de codificação e decodificação para o segundo formato de codificação e decodificação.
[00254] Similarmente, como mostrado na FIG. 15, se um formato de codificação e decodificação de um sinal recebido por um dispositivo de rede é o mesmo que um formato de codificação e decodificação correspondente a um decodificador estéreo, após o decodificador de canal do dispositivo de rede executar decodificação de canal para obter um fluxo de bits codificado de um sinal estéreo, o decodificador estéreo pode decodificar o fluxo de bits codificado do sinal estéreo, para obter um sinal estéreo. Em seguida, outro codificador estéreo codifica o sinal estéreo baseado em outro formato de codificação e decodificação para obter um fluxo de bits codificado correspondente ao outro codificador estéreo. Finalmente, um codificador de canal executa codificação de canal no fluxo de bits codificado correspondente ao outro codificador estéreo, para obter um sinal final (o sinal pode ser transmitido a um dispositivo terminal ou outro dispositivo de rede). Igual ao caso na FIG. 14, o formato de codificação e decodificação correspondente ao decodificador estéreo na FIG. 15 é também diferente do formato de codificação e decodificação correspondente ao outro codificador estéreo. Se o formato de codificação e decodificação correspondente ao outro codificador estéreo for um primeiro formato de codificação e decodificação, e o formato de codificação e decodificação correspondente ao decodificador estéreo for um segundo formato de codificação e decodificação, na FIG. 15, O dispositivo de rede converte o sinal de áudio do segundo formato de codificação e decodificação para o primeiro formato de codificação e decodificação.
[00255] Nas FIGS. 14 e 15, Oo outro codificador e decodificador estéreo e o codificador e decodificador estéreo correspondem a diferentes formatos de codificação e decodificação respectivamente. Portanto, transcodificação do formato de codificação e decodificação do sinal estéreo é implementada após o processamento do outro codificador e decodificador estéreo e do codificador e decodificador estéreo.
[00256] Deve ser ainda entendido que o codificador estéreo na FIG. 14 pode implementar o método de codificação para um sinal estéreo nas modalidades deste pedido, e o decodificador estéreo na FIG. 15 pode implementar o método de decodificação para um sinal estéreo nas modalidades deste pedido. O aparelho de codificação nas modalidades deste pedido pode ser o codificador estéreo no dispositivo de rede na FIG. 14, e o aparelho de decodificação nas modalidades deste pedido pode ser o decodificador estéreo no dispositivo de rede na FIG. 15. Além disso, o dispositivo de rede nas FIGS. 14 e 15 pode ser especificamente um dispositivo de comunicações de rede sem fio ou um dispositivo de comunicações de rede com fio.
[00257] Deve ser entendido que os métodos de codificação e decodificação para um sinal estéreo nas modalidades deste pedido podem também ser executados por um dispositivo terminal ou um dispositivo de rede nas FIGS. 16 a 18. Além disso, os aparelhos de codificação e decodificação nas modalidades deste pedido podem ainda estar posicionados no dispositivo terminal ou no dispositivo de rede nas FIGS. 16 a 18. Especificamente, o aparelho de codificação nas modalidades deste pedido pode ser um codificador estéreo em um codificador de múltiplos canais no dispositivo terminal ou no dispositivo de rede nas FIGS. 16 a 18, e o aparelho de decodificação nas modalidades deste pedido pode ser um decodificador estéreo em um codificador de múltiplos canais no dispositivo terminal ou no dispositivo de rede nas FIGS. 16 a 18.
[00258] Como mostrado na FIG. 16, em comunicação de áudio, um codificador estéreo em um codificador de múltiplos canais em um primeiro dispositivo terminal executa codificação estéreo em um sinal estéreo gerado a partir de um sinal de múltiplos canais coletado. Um fluxo de bits obtido pelo codificador de múltiplos canais inclui um fluxo de bits obtido pelo codificador estéreo. Um codificador de canal no primeiro dispositivo terminal pode ainda executar codificação de canal no fluxo de bits obtido pelo codificador de múltiplos canais. Em seguida, os dados obtidos pelo primeiro dispositivo terminal após a codificação de canal são transmitidos a um segundo dispositivo terminal mediante utilização de um primeiro dispositivo de rede e de um segundo dispositivo de rede. Após o segundo dispositivo terminal receber os dados do segundo dispositivo de rede, um decodificador de canal do segundo dispositivo terminal executa decodificação de canal, para obter um fluxo de bits codificado do sinal de múltiplos canais, onde o fluxo de bits codificado do sinal de múltiplos canais inclui um fluxo de bits codificado do sinal estéreo. Um decodificador estéreo em um decodificador de múltiplos canais no segundo dispositivo terminal restaura um sinal estéreo por decodificação. Oo decodificador de múltiplos canais decodifica o sinal estéreo restaurado para obter um sinal de múltiplos canais. O segundo dispositivo terminal reproduz o sinal de múltiplos canais. Deste modo, a comunicação de áudio é completada entre diferentes dispositivos terminais.
[00259] Deve ser entendido que, na FIG. 16, o segundo dispositivo terminal pode também codificar o sinal de múltiplos canais coletado (especificamente, um codificador estéreo em um codificador de múltiplos canais do segundo dispositivo terminal executa codificação estéreo no sinal estéreo gerado a partir do sinal de múltiplos canais coletado, um codificador de canal no segundo dispositivo terminal então executa codificação de canal em um fluxo de bits obtido pelo codificador de múltiplos canais), e finalmente, dados obtidos são transmitidos ao primeiro dispositivo terminal mediante utilização do segundo dispositivo de rede e do primeiro dispositivo de rede. O primeiro dispositivo terminal obtém um sinal de múltiplos canais por decodificação de canal e decodificação de múltiplos canais.
[00260] Na FIG. 16, O primeiro dispositivo de rede e o segundo dispositivo de rede podem ser dispositivos de comunicações de rede sem fio ou dispositivos de comunicações de rede com fio. O primeiro dispositivo de rede e o segundo dispositivo de rede podem comunicar-se entre si mediante utilização de um canal digital.
[00261] O primeiro dispositivo terminal ou o segundo dispositivo terminal na FIG. 16 pode executar os métodos de codificação e decodificação para um sinal estéreo nas modalidades deste pedido. Além disso, o aparelho de codificação nas modalidades deste pedido pode ser o codificador estéreo no primeiro dispositivo terminal ou no segundo dispositivo terminal, e o aparelho de decodificação nas modalidades deste pedido pode ser o decodificador estéreo no primeiro dispositivo terminal ou no segundo dispositivo terminal.
[00262] Em comunicação de áudio, um dispositivo de rede pode implementar transcodificação de um formato de codificação e decodificação de um sinal de áudio. Como mostrado na FIG. 17, se um formato de codificação e decodificação de um sinal recebido por um dispositivo de rede for um formato de codificação e decodificação correspondente a outro decodificador de múltiplos canais, um decodificador de canal no dispositivo de rede executa decodificação de canal no sinal recebido, para obter um fluxo de bits codificado correspondente ao outro decodificador de múltiplos canais. O outro decodificador de múltiplos canais decodifica o fluxo de bits codificado, para obter um sinal de múltiplos canais. Um codificador de múltiplos canais codifica o sinal de múltiplos canais para obter um fluxo de bits codificado do sinal de múltiplos canais. Um codificador estéreo no codificador de múltiplos canais executa codificação estéreo em um sinal estéreo gerado a partir do sinal de múltiplos canais para obter um fluxo de bits codificado do sinal estéreo. O fluxo de bits codificado do sinal de múltiplos canais inclui o fluxo de bits codificado do sinal estéreo. Finalmente, um codificador de canal executa codificação de canal no fluxo de bits codificado, para obter um sinal final (o sinal pode ser transmitido a um dispositivo terminal ou outro dispositivo de rede).
[00263] Similarmente, como mostrado na FIG. 18, se um formato de codificação e decodificação de um sinal recebido por um dispositivo de rede for o mesmo que um formato de codificação e decodificação correspondente a um decodificador de múltiplos canais, após um decodificador de canal do dispositivo de rede executar decodificação de canal para obter um fluxo de bits codificado de um sinal de múltiplos canais, o decodificador de múltiplos canais pode decodificar o fluxo de bits codificado do sinal de múltiplos canais, para obter um sinal de múltiplos canais, onde um decodificador estéreo do decodificador de múltiplos canais executa decodificação estéreo em um fluxo de bits codificado de um sinal estéreo no fluxo de bits codificado do sinal de múltiplos canais. Em seguida, outro codificador de múltiplos canais codifica o sinal de múltiplos canais baseado em outro formato de codificação e decodificação, para obter um fluxo de bits codificado do sinal de múltiplos canais correspondente ao outro codificador de múltiplos canais. Finalmente, um codificador de canal executa codificação de canal no fluxo de bits codificado correspondente ao outro codificador de múltiplos canais, para obter um sinal final (o sinal pode ser transmitido a um dispositivo terminal ou a outro dispositivo de rede).
[00264] Deve ser entendido que, nas FIGS. 17 e 18, o outro codificador e decodificador de múltiplos canais e o codificador e decodificador de múltiplos canais correspondem a diferentes formatos de codificação e decodificação respectivamente. Por exemplo, na FIG. 17, o formato de codificação e decodificação correspondente ao outro decodificador estéreo é um primeiro formato de codificação e decodificação, e o formato de codificação e decodificação correspondente ao codificador de múltiplos canais é um segundo formato de codificação e decodificação. Neste caso, na FIG. 17, o dispositivo de rede converte o sinal de áudio do primeiro formato de codificação e decodificação para o segundo formato de codificação e decodificação. Similarmente, na FIG. 18, considera-se que o formato de codificação e decodificação correspondente ao codificador de múltiplos canais é um segundo formato de codificação e decodificação, e o formato de codificação e decodificação correspondente ao outro decodificador estéreo é um primeiro formato de codificação e decodificação. Neste caso, na FIG. 18, o dispositivo de rede converte o sinal de áudio do segundo formato de codificação e decodificação para o primeiro formato de codificação e decodificação. Portanto, transcodificação do formato de codificação e decodificação do sinal de áudio é implementada após o processamento do outro codificador e decodificador de múltiplos canais e do codificador e decodificador de múltiplos canais.
[00265] Deve ser ainda entendido que o codificador estéreo na FIG. 17 pode implementar o método de codificação para um sinal estéreo neste pedido, e o decodificador estéreo na FIG. 18 pode implementar o método de decodificação para um sinal estéreo neste pedido. O aparelho de codificação nas modalidades deste pedido pode ser o codificador estéreo no dispositivo de rede na FIG. 17, e o aparelho de decodificação nas modalidades deste pedido pode ser o decodificador estéreo no dispositivo de rede na FIG. 18. Além disso, o dispositivo de rede nas FIGS. 17 e 18 pode ser especificamente um dispositivo de comunicações de rede sem fio ou um dispositivo de comunicações de rede com fio.
[00266] Uma pessoa versada na técnica pode estar ciente que, em combinação com os exemplos descritos nas modalidades reveladas nesta especificação, unidades e etapas de algoritmos "podem ser implementadas por hardware eletrônico ou uma combinação de software de computador e hardware eletrônico. O fato de as funções serem executadas por hardware ou software depende de aplicações específicas e condições de restrição de projeto das soluções técnicas. Uma pessoa versada na técnica pode usar diferentes métodos para implementar as funções descritas para cada aplicação específica, mas não deve ser considerado que a implementação vá além do âmbito deste pedido.
[00267] Pode ser claramente entendido por uma pessoa versada na técnica que, por razões de conveniência e descrição resumida, para um processo de trabalho detalhado do sistema, aparelho e unidade precedentes, deve ser feita referência a um processo correspondente nas modalidades de métodos precedentes, e detalhes não são descritos novamente neste documento.
[00268] Nas diversas modalidades fornecidas neste pedido, deve ser entendido que os sistemas, aparelhos e métodos revelados podem ser implementados de outros modos. Por exemplo, as modalidades de aparelhos descritas são meramente exemplos. Por exemplo, a divisão de unidades é meramente divisão lógica de funções e pode ser outra divisão em implementação real. Por exemplo, uma pluralidade de unidades ou componentes pode ser combinada ou integrada em outro sistema, ou alguns recursos podem ser ignorados ou não executados. Além disso, os acoplamentos mútuos ou acoplamentos diretos ou conexões de comunicação exibidos ou discutidos podem ser implementados mediante utilização de algumas interfaces. Os acoplamentos indiretos ou conexões de comunicação entre os aparelhos ou unidades podem ser implementados em forma eletrônica, mecânica Ou outras formas.
[00269] As unidades descritas como partes separadas podem ou não estar fisicamente separadas, e partes exibidas como unidades podem ou não ser unidades físicas, podem estar localizadas em uma posição, ou podem estar distribuídas em uma pluralidade de unidades de rede. Algumas ou todas as unidades podem ser selecionadas de acordo com necessidades reais para alcançar os objetivos das soluções das modalidades.
[00270] Além disso, unidades funcionais nas modalidades deste pedido podem ser integradas em uma unidade de processamento, ou cada uma das unidades pode existir fisicamente isolada, ou duas ou mais unidades estar integradas em uma unidade.
[00271] Quando as funções são implementadas na forma de uma unidade funcional de software e vendidas ou usadas como um produto independente, as funções podem ser armazenadas em um meio de armazenamento legível por computador. Baseado em tal compreensão, as soluções técnicas deste pedido essencialmente, ou a parte que contribui para o estado da técnica, ou algumas das soluções técnicas podem ser implementadas na forma de um produto de software. O produto de software é armazenado em um meio de armazenamento e inclui diversas instruções para instruir um dispositivo computacional (que pode ser um computador pessoal, um servidor, um dispositivo de rede, ou similar) a executar todas as ou algumas das etapas dos métodos descritos nas modalidades deste pedido. O meio de armazenamento precedente inclui: qualquer meio que possa armazenar código de programa, tais como uma unidade flash USB, um disco rígido removível, uma memória apenas de leitura (read-only memory, ROM), uma memória de acesso aleatório (random access memory, RAM), um disco magnético, ou um disco ótico.
[00272] As descrições precedentes são meramente implementações específicas deste pedido, mas não se destinam a limitar o âmbito de proteção deste pedido.
Qualquer variação ou substituição facilmente vislumbrada por uma pessoa versada na técnica dentro do âmbito técnico revelado neste pedido deverá cair dentro do âmbito de proteção deste pedido.
Portanto, o âmbito de proteção deste pedido deverá estar sujeito ao âmbito de proteção das reivindicações.

Claims (30)

REIVINDICAÇÕES EMENDADAS
1. Método de codificação para um sinal estéreo, caracterizado pelo fato de que compreende: determinar (410) uma diferença de tempo entre canais em um quadro atual; executar (420) processamento de interpolação baseado na diferença de tempo entre canais no quadro corrente e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; executar (430) alinhamento de atraso em um sinal estéreo no quadro atual baseado na diferença de tempo entre canais em um quadro atual, para obter um sinal estéreo após o alinhamento de atraso no quadro atual; executar (440) processamento de mixagem descendente no domínio do tempo no sinal estéreo após o alinhamento de atraso no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário no quadro atual; quantizar (450) a diferença de tempo entre canais após o processamento de interpolação no quadro atual, e gravar uma diferença de tempo entre canais quantizada em um fluxo de bits; e quantizar (460) o sinal de canal principal e o sinal de canal secundário no quadro atual, e gravar um sinal de canal principal quantizado e um sinal de canal secundário quantizado em um fluxo de bits.
2. Método, de acordo com a reivindicação 1, caracterizado pelo fato de que a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculado de acordo com qualquer uma das fórmulas A=aºB+(1-0) ºC e A=(1-B) B+B-C, em que A é a diferença de tempo entre canais após oO processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação e O<a<1, B é um segundo coeficiente de interpolação e O<B<1.
3. Método, de acordo com a reivindicação 2, caracterizado pelo fato de que o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
4, Método, de acordo com a reivindicação 3, caracterizado pelo fato de que o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S)/N, em que S é o atraso de codificação e decodificação, e N é o comprimento de quadro do quadro atual.
5. Método, de acordo com a reivindicação 2, caracterizado pelo fato de que o segundo coeficiente de interpolação B é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
6. Método, de acordo com a reivindicação 5, caracterizado pelo fato de que o segundo coeficiente de interpolação B satisfaz uma fórmula B=S/N, em que S é o atraso de codificação e decodificação, e N é o comprimento de quadro do quadro atual.
7. Método, de acordo com qualquer uma das reivindicações 2 a 6, caracterizado pelo fato de que qualquer um do primeiro coeficiente de interpolação a e do segundo coeficiente de interpolação B é pré-armazenado.
8. Método de decodificação para um sinal estéreo, caracterizado pelo fato de que compreende: decodificar (710) um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário em um quadro atual, e uma diferença de tempo entre canais no quadro atual; executar (720) processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário no quadro atual, para obter um sinal do canal esquerdo reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo;
executar (730) processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; e ajustar (740) um atraso do sinal do canal esquerdo reconstruído e do sinal do canal direito reconstruído baseado na diferença de tempo entre canais após oO processamento de interpolação no quadro atual.
9. Método, de acordo com a reivindicação 8, caracterizado pelo fato de que a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculado de acordo com qualquer uma das fórmulas A=aºB+(1-0) ºC e A=(1-B) B+B-C, em que A é a diferença de tempo entre canais após oO processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação e O<a<1, B é um segundo coeficiente de interpolação e O<B<1.
10. Método, de acordo com a reivindicação O, caracterizado pelo fato de que o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
11. Método, de acordo com a reivindicação 10, caracterizado pelo fato de que o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S)/N, em que S é o atraso de codificação e decodificação, e N é o comprimento de quadro do quadro atual.
12. Método, de acordo com a reivindicação O, caracterizado pelo fato de que o segundo coeficiente de interpolação B é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
13. Método, de acordo com a reivindicação 12, caracterizado pelo fato de que o segundo coeficiente de interpolação B satisfaz uma fórmula B=S/N, em que S é o atraso de codificação e decodificação, e Né o comprimento de quadro do quadro atual.
1. Método, de acordo com qualquer uma das reivindicações 9 a 13, caracterizado pelo fato de que qualquer um do primeiro coeficiente de interpolação a e do segundo coeficiente de interpolação B é pré-armazenado.
15. Aparelho de codificação (900), caracterizado pelo fato de que compreende: um módulo de determinação (910), configurado para determinar uma diferença de tempo entre canais em um quadro atual; um módulo de interpolação (920), configurado para executar processamento de interpolação baseado na diferença de tempo entre canais no quadro corrente e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; um módulo de alinhamento de atraso (930), configurado para executar alinhamento de atraso em um sinal estéreo no quadro atual baseado na diferença de tempo entre canais no quadro atual, para obter um sinal estéreo após Oo alinhamento de atraso no quadro atual; um módulo de mixagem descendente (940), configurado para executar processamento de mixagem descendente no domínio do tempo no sinal estéreo após o alinhamento de atraso no quadro atual, para obter um sinal de canal principal e um sinal de canal secundário no quadro atual; e um módulo de codificação (950), configurado para quantizar a diferença de tempo entre canais após Oo processamento de interpolação no quadro atual, e gravar uma diferença de tempo entre canais quantizada em um fluxo de bits, e quantizar o sinal de canal principal e o sinal de canal secundário no quadro atual, e gravar um sinal de canal principal quantizado e um sinal de canal secundário quantizado em um fluxo de bits.
16. Aparelho (900), de acordo com a reivindicação 15, caracterizado pelo fato de que a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculado de acordo com qualquer uma das fórmulas A=aºB+(1-0) ºC e A=(1-B) B+B-C, em que A é a diferença de tempo entre canais após oO processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação e O<a<1, B é um segundo coeficiente de interpolação e O<B<1.
17. Aparelho (900), de acordo com a reivindicação 16, caracterizado pelo fato de que o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
18. Aparelho (900), de acordo com a reivindicação 17, caracterizado pelo fato de que o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S)/N, em que S é o atraso de codificação e decodificação, e N é o comprimento de quadro do quadro atual.
19. Aparelho (900), de acordo com a reivindicação 16, caracterizado pelo fato de que o segundo coeficiente de interpolação B ser diretamente proporcional a um atraso de codificação e decodificação, e ser inversamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
20. Aparelho (900), de acordo com a reivindicação 19, caracterizado pelo fato de que o segundo coeficiente de interpolação B satisfaz uma fórmula B=S/N, em que S é o atraso de codificação e decodificação, e N é o comprimento de quadro do quadro atual.
21. Aparelho (900), de acordo com qualquer uma das reivindicações 16 a 20, caracterizado pelo fato de que qualquer um do primeiro coeficiente de interpolação a e do segundo coeficiente de interpolação B é pré-armazenado.
22. Aparelho de decodificação (1000), caracterizado pelo fato de que compreende: um módulo de decodificação (1100), configurado para decodificar um fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário em um quadro atual, e uma diferença de tempo entre canais no quadro atual;
um módulo de mixagem ascendente (1200), configurado para executar processamento de mixagem ascendente no domínio do tempo no sinal de canal principal e no sinal de canal secundário no quadro atual, para obter um sinal do canal esquerdo reconstruído e um sinal do canal direito reconstruído que são obtidos após o processamento de mixagem ascendente no domínio do tempo; um módulo de interpolação (1300), configurado para executar processamento de interpolação baseado na diferença de tempo entre canais no quadro atual e em uma diferença de tempo entre canais em um quadro anterior ao quadro atual, para obter uma diferença de tempo entre canais após o processamento de interpolação no quadro atual; e um módulo de ajustamento de atraso (1400), configurado para ajustar um atraso do sinal do canal esquerdo reconstruído e do sinal do canal direito reconstruído baseado na diferença de tempo entre canais após oO processamento de interpolação no quadro atual.
23. Aparelho (1000), de acordo com a reivindicação 22, caracterizado pelo fato de que a diferença de tempo entre canais após o processamento de interpolação no quadro atual é calculado de acordo com qualquer uma das fórmulas A=aºB+(1-0)ºC e A=(1-B) B+BC, em que A é a diferença de tempo entre canais após o processamento de interpolação no quadro atual, B é a diferença de tempo entre canais no quadro atual, C é a diferença de tempo entre canais no quadro anterior ao quadro atual, a é um primeiro coeficiente de interpolação e O<a<l, B é um segundo coeficiente de interpolação, e O<B<1.
24. Aparelho (1000), de acordo com a reivindicação
23, caracterizado pelo fato de que o primeiro coeficiente de interpolação a é inversamente proporcional a um atraso de codificação e decodificação, e é diretamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
25. Aparelho (1000), de acordo com a reivindicação 24, caracterizado pelo fato de que o primeiro coeficiente de interpolação a satisfaz uma fórmula a=(N-S)/N, em que S é o atraso de codificação e decodificação, e N é o comprimento de quadro do quadro atual.
26. Aparelho (1000), de acordo com a reivindicação 23, caracterizado pelo fato de que o segundo coeficiente de interpolação B é diretamente proporcional a um atraso de codificação e decodificação, e é inversamente proporcional a um comprimento de quadro do quadro atual, em que o atraso de codificação e decodificação compreende um atraso de codificação em um processo de codificação, por um terminal de codificação, do sinal de canal principal e do sinal de canal secundário que são obtidos após o processamento de mixagem descendente no domínio do tempo, e um atraso de decodificação em um processo de decodificação, por um terminal de decodificação, do fluxo de bits para obter um sinal de canal principal e um sinal de canal secundário.
27. Aparelho (1000), de acordo com a reivindicação 26, caracterizado pelo fato de que o segundo coeficiente de interpolação B satisfaz uma fórmula B=S/N, em que S é o atraso de codificação e decodificação, e Né o comprimento de quadro do quadro atual.
28. Aparelho (1000), de acordo com qualquer uma das reivindicações 23 a 27, caracterizado pelo fato de que qualquer um do primeiro coeficiente de interpolação a e do segundo coeficiente de interpolação B é pré-armazenado.
29. Aparelho de codificação (1100), caracterizado pelo fato de que compreende: uma memória (1110), configurada para armazenar um programa; e um processador (1120), configurado para executar o programa armazenado na memória (1110), onde quando o programa na memória (1110) é executado, o processador (1120) é configurado para executar o método conforme definido em qualquer uma das reivindicações 1 a 7.
30. Aparelho de codificação (1200), caracterizado pelo fato de que compreende: uma memória (1210), configurada para armazenar um programa; e um processador (1220), configurado para executar o programa armazenado na memória (1210), onde quando o programa na memória (1210) é executado, o processador (1220) é configurado para executar o método conforme definido em qualquer uma das reivindicações 8 a 14.
BR112020001633-0A 2017-07-25 2018-07-25 métodos de codificação e decodificação, e aparelhos de codificação e decodificação para sinal estéreo BR112020001633A2 (pt)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
CN201710614326.7 2017-07-25
CN201710614326.7A CN109300480B (zh) 2017-07-25 2017-07-25 立体声信号的编解码方法和编解码装置
PCT/CN2018/096973 WO2019020045A1 (zh) 2017-07-25 2018-07-25 立体声信号的编解码方法和编解码装置

Publications (1)

Publication Number Publication Date
BR112020001633A2 true BR112020001633A2 (pt) 2020-07-21

Family

ID=65039996

Family Applications (1)

Application Number Title Priority Date Filing Date
BR112020001633-0A BR112020001633A2 (pt) 2017-07-25 2018-07-25 métodos de codificação e decodificação, e aparelhos de codificação e decodificação para sinal estéreo

Country Status (7)

Country Link
US (3) US11238875B2 (pt)
EP (2) EP3648101B1 (pt)
KR (1) KR102288111B1 (pt)
CN (1) CN109300480B (pt)
BR (1) BR112020001633A2 (pt)
ES (1) ES2945723T3 (pt)
WO (1) WO2019020045A1 (pt)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112151045B (zh) 2019-06-29 2024-06-04 华为技术有限公司 一种立体声编码方法、立体声解码方法和装置
CN115346537A (zh) * 2021-05-14 2022-11-15 华为技术有限公司 一种音频编码、解码方法及装置
CN115497485B (zh) * 2021-06-18 2024-10-18 华为技术有限公司 三维音频信号编码方法、装置、编码器和系统
CN115881138A (zh) * 2021-09-29 2023-03-31 华为技术有限公司 解码方法、装置、设备、存储介质及计算机程序产品
CN114258568A (zh) * 2021-11-26 2022-03-29 北京小米移动软件有限公司 一种立体声音频信号处理方法、装置、编码设备、解码设备及存储介质

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7006636B2 (en) * 2002-05-24 2006-02-28 Agere Systems Inc. Coherence-based audio coding and synthesis
CN101188878B (zh) * 2007-12-05 2010-06-02 武汉大学 立体声音频信号的空间参数量化及熵编码方法和所用系统
CN101582259B (zh) * 2008-05-13 2012-05-09 华为技术有限公司 立体声信号编解码方法、装置及编解码系统
US8504378B2 (en) * 2009-01-22 2013-08-06 Panasonic Corporation Stereo acoustic signal encoding apparatus, stereo acoustic signal decoding apparatus, and methods for the same
BRPI1009467B1 (pt) 2009-03-17 2020-08-18 Dolby International Ab Sistema codificador, sistema decodificador, método para codificar um sinal estéreo para um sinal de fluxo de bits e método para decodificar um sinal de fluxo de bits para um sinal estéreo
PL3035330T3 (pl) * 2011-02-02 2020-05-18 Telefonaktiebolaget Lm Ericsson (Publ) Określanie międzykanałowej różnicy czasu wielokanałowego sygnału audio
ES2571742T3 (es) 2012-04-05 2016-05-26 Huawei Tech Co Ltd Método de determinación de un parámetro de codificación para una señal de audio multicanal y un codificador de audio multicanal
CN104681029B (zh) 2013-11-29 2018-06-05 华为技术有限公司 立体声相位参数的编码方法及装置
ES2809677T3 (es) 2015-09-25 2021-03-05 Voiceage Corp Método y sistema para codificar una señal de sonido estéreo utilizando parámetros de codificación de un canal primario para codificar un canal secundario

Also Published As

Publication number Publication date
US20200160872A1 (en) 2020-05-21
US20220108710A1 (en) 2022-04-07
KR102288111B1 (ko) 2021-08-09
CN109300480A (zh) 2019-02-01
EP3648101B1 (en) 2023-04-26
EP4258697A2 (en) 2023-10-11
CN109300480B (zh) 2020-10-16
US20230352034A1 (en) 2023-11-02
EP4258697A3 (en) 2023-10-25
WO2019020045A1 (zh) 2019-01-31
EP3648101A4 (en) 2020-07-15
KR20200027008A (ko) 2020-03-11
ES2945723T3 (es) 2023-07-06
US11741974B2 (en) 2023-08-29
US11238875B2 (en) 2022-02-01
EP3648101A1 (en) 2020-05-06

Similar Documents

Publication Publication Date Title
BR112020001633A2 (pt) métodos de codificação e decodificação, e aparelhos de codificação e decodificação para sinal estéreo
ES2641390T3 (es) Codificación y decodificación eficientes de una señal de audio multicanal con múltiples flujos secundarios
JP6494741B2 (ja) 符号化及び復号化のための符号化装置、復号化装置、システム及び方法
BRPI0616019A2 (pt) conceito para a conexão em ponte da lacuna entre a conexão paramétrica de áudio multicanais e a conexão surround matrizada multicanais
BR112012011084B1 (pt) decodificador para gerar um sinal de áudio multicanal, codificador para gerar uma representação codificada de um sinal de áudio multicanal, método de gerar um sinal de áudio multicanal e método de gerar uma representação codificada de um sinal de áudio multicanal
BRPI0606387B1 (pt) Decodificador, dispositivo de reprodução de áudio, codificador, dispositivo de gravação, método para gerar um sinal de áudio multicanal, meio de armazenamento, método paracodificar um sinal de áudio multicanal, receptor, transmissor, sistema de transmissão, método de receber um sinal de áudio multicanal, e método de transmitir um sinal deáudio multicanal
BR112016022466B1 (pt) método para codificar um sinal sonoro, método para decodificar um sinal sonoro, dispositivo para codificar um sinal sonoro e dispositivo para decodificar um sinal sonoro
WO2021143692A1 (zh) 一种音频编解码方法和音频编解码设备
WO2010111876A1 (zh) 一种信号去噪的方法和装置及音频解码系统
BR112020003543A2 (pt) método e aparelho para reconstruir sinal durante codificação de sinal estéreo
WO2011097912A1 (zh) 一种多声道信号编码方法、解码方法、装置和系统
WO2019037714A1 (zh) 立体声信号的编码方法和编码装置
BR112016025330B1 (pt) Método de codificação de áudio e aparelho relacionado
US11922958B2 (en) Method and apparatus for determining weighting factor during stereo signal encoding
WO2021136344A1 (zh) 音频信号的编解码方法和编解码装置
BR112020026932A2 (pt) Método e aparelho de codificação de sinal estéreo, e método e aparelho de decodificação de sinal estéreo
WO2020001569A1 (zh) 立体声信号的编码、解码方法、编码装置和解码装置
JP7420829B2 (ja) 予測コーディングにおける低コスト誤り回復のための方法および装置
WO2024083520A1 (en) Parametric spatial audio encoding

Legal Events

Date Code Title Description
B350 Update of information on the portal [chapter 15.35 patent gazette]