RU2591663C2 - Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая обнаружение группы ранее декодированных спектральных значений - Google Patents
Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая обнаружение группы ранее декодированных спектральных значений Download PDFInfo
- Publication number
- RU2591663C2 RU2591663C2 RU2012122277/08A RU2012122277A RU2591663C2 RU 2591663 C2 RU2591663 C2 RU 2591663C2 RU 2012122277/08 A RU2012122277/08 A RU 2012122277/08A RU 2012122277 A RU2012122277 A RU 2012122277A RU 2591663 C2 RU2591663 C2 RU 2591663C2
- Authority
- RU
- Russia
- Prior art keywords
- value
- context
- spectral
- audio
- spectral values
- Prior art date
Links
- 230000003595 spectral effect Effects 0.000 title claims abstract description 434
- 238000000034 method Methods 0.000 title claims abstract description 52
- 238000001514 detection method Methods 0.000 title claims abstract description 37
- 238000004590 computer program Methods 0.000 title description 10
- 238000013507 mapping Methods 0.000 claims abstract description 69
- 230000008859 change Effects 0.000 claims abstract description 11
- 238000004364 calculation method Methods 0.000 claims description 26
- 238000006243 chemical reaction Methods 0.000 claims description 10
- 230000004044 response Effects 0.000 claims description 10
- 230000006872 improvement Effects 0.000 abstract description 3
- 230000000694 effects Effects 0.000 abstract 1
- 239000000126 substance Substances 0.000 abstract 1
- 230000006870 function Effects 0.000 description 104
- 238000004422 calculation algorithm Methods 0.000 description 42
- 238000011156 evaluation Methods 0.000 description 14
- 230000008569 process Effects 0.000 description 13
- 230000007704 transition Effects 0.000 description 11
- 230000006978 adaptation Effects 0.000 description 10
- 238000010586 diagram Methods 0.000 description 8
- 230000007246 mechanism Effects 0.000 description 8
- 238000012545 processing Methods 0.000 description 8
- 230000005540 biological transmission Effects 0.000 description 7
- 230000005236 sound signal Effects 0.000 description 7
- 230000003068 static effect Effects 0.000 description 6
- 230000001419 dependent effect Effects 0.000 description 5
- 230000005284 excitation Effects 0.000 description 5
- 230000008447 perception Effects 0.000 description 5
- 238000007789 sealing Methods 0.000 description 5
- 230000001174 ascending effect Effects 0.000 description 4
- 230000008901 benefit Effects 0.000 description 4
- 238000012805 post-processing Methods 0.000 description 4
- 238000001228 spectrum Methods 0.000 description 4
- 238000013139 quantization Methods 0.000 description 3
- 238000007906 compression Methods 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 230000007423 decrease Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 2
- 230000009977 dual effect Effects 0.000 description 2
- 230000000873 masking effect Effects 0.000 description 2
- 238000012795 verification Methods 0.000 description 2
- 239000011800 void material Substances 0.000 description 2
- 241001025261 Neoraja caerulea Species 0.000 description 1
- 108010076504 Protein Sorting Signals Proteins 0.000 description 1
- 230000001133 acceleration Effects 0.000 description 1
- 230000003044 adaptive effect Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 238000013144 data compression Methods 0.000 description 1
- 238000005265 energy consumption Methods 0.000 description 1
- 230000002349 favourable effect Effects 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 230000002123 temporal effect Effects 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G10—MUSICAL INSTRUMENTS; ACOUSTICS
- G10L—SPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
- G10L19/00—Speech 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
-
- G—PHYSICS
- G10—MUSICAL INSTRUMENTS; ACOUSTICS
- G10L—SPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
- G10L19/00—Speech 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/008—Multichannel audio signal coding or decoding using interchannel correlation to reduce redundancy, e.g. joint-stereo, intensity-coding or matrixing
-
- G—PHYSICS
- G10—MUSICAL INSTRUMENTS; ACOUSTICS
- G10L—SPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
- G10L19/00—Speech 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/0017—Lossless audio signal coding; Perfect reconstruction of coded audio signal by transmission of coding error
-
- G—PHYSICS
- G10—MUSICAL INSTRUMENTS; ACOUSTICS
- G10L—SPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
- G10L19/00—Speech 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/02—Speech 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 spectral analysis, e.g. transform vocoders or subband vocoders
- G10L19/0204—Speech 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 spectral analysis, e.g. transform vocoders or subband vocoders using subband decomposition
- G10L19/0208—Subband vocoders
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- Signal Processing (AREA)
- Health & Medical Sciences (AREA)
- Human Computer Interaction (AREA)
- Acoustics & Sound (AREA)
- Multimedia (AREA)
- Mathematical Physics (AREA)
- Spectroscopy & Molecular Physics (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Изобретение относится к аудио декодеру, аудио кодеру, способам и машиночитаемым носителям для предоставления декодированной и кодированной аудио информации. Технический результат заключается в повышении эффективности настройки контекста. Аудио декодер содержит арифметический декодер для обеспечения множества декодированных спектральных значений на основе арифметически кодированного представления спектральных значений и конвертер частотной области во временную область для обеспечения аудио представления временной области, используя декодированные спектральные значения, где арифметический декодер настроен, чтобы выбрать правило отображения, описывающее отображение значения кода на код символа в зависимости от состояния контекста, также чтобы определить текущее состояние контекста в зависимости от множества ранее декодированных спектральных значений, и чтобы обнаружить группу множества ранее декодированных спектральных значений, которые соответствуют по отдельности или вместе взятые заданному условию относительно их величины, а также определить или изменить текущее состояние контекста в зависимости от результата обнаружения. 6 н. и 13 з.п. ф-лы, 46 ил.
Description
Техническая область
Воплощения в соответствии с изобретением связаны с аудио декодером для обеспечения декодированной аудио информации на основе кодированной аудио информации, аудио кодером для обеспечения кодированной аудио информации на основе входной аудио информации, способ для получения декодированной аудио информации на основе кодированной аудио информации, способ получения кодированной аудио информации на основе входной аудио информации и компьютерной программой.
Воплощения в соответствии с изобретением связаны с улучшенным спектральным бесшумным кодированием, которое может быть использовано в аудио кодере и декодере, как, например, так называемом единый кодере речи и аудио (USAC).
Предпосылки создания изобретения
Далее будет кратко описана концепция изобретения в целях облегчения понимания настоящего изобретения и его преимуществ. За последние десять лет большие усилия были предприняты для создания возможности для цифрового хранения и распространения аудио содержания с хорошей эффективностью битрейта. Одним из важных достижений на этом пути является определение международного стандарта ISO / IEC 14496-3. Часть 3 данного стандарта связана с кодированием и декодированием аудио содержимого, а подраздел 4 части 3 связан с общим аудио кодированием. ISO/IEC 14496, часть 3, раздел 4 определяет концепцию кодирования и декодирования общего аудио содержания. Кроме того, дальнейшие улучшения были предложены с целью улучшения качества и/или снижения необходимой скорости передачи данных.
Согласно концепции, описанной в указанном стандарте, во временной области звуковой сигнал преобразуется в частотно-временное представление. Преобразование из временной области в частотно-временную область, как правило, осуществляется с помощью блоков преобразования, который обозначаются как ″кадры″ из образцов временной области. Было установлено, что выгоднее использовать перекрывающиеся кадры, которые перемещаются, например, на половину кадра, так как перекрытие позволяет эффективно избежать (или хотя бы уменьшить) артефакты. Кроме того, было обнаружено, что оконная работа должна быть выполнена для того, чтобы избежать артефактов, происходящих из этой обработки временно ограниченных кадров.
При преобразовании оконной части входного звукового сигнала из временной области в частотно-временную область, уплотнение энергии получается во многих случаях, так что некоторые спектральные значения составляют значительно большую величину, чем множество других спектральных значений. Соответственно, во многих случаях есть сравнительно небольшое число спектральных значений с величиной, которая существенно выше средней величины спектральных значений. Типичным примером преобразования из временной области в частотно-временную область, приводящего к уплотнению энергии, является так называемое модифицированное дискретное косинус преобразование (MDCT).
Спектральные значения часто масштабируются и квантуются в соответствии с психоакустической моделью, так что ошибки квантования сравнительно меньше для психоакустичеки важных спектральных значений и сравнительно больше для психоакустически менее важных спектральных значений. Масштабированные и квантованные спектральные значения кодируются в целях обеспечения эффективного битрейта их представления.
Например, использование так называемого Huffman кодирования квантованных спектральных коэффициентов описано в международном стандарте ISO / IEC 14496-3:2005 (Е), часть 3, раздел 4.
Тем не менее, было установлено, что качество кодирования спектральных значений оказывает значительное влияние на требуемый битрейт. Кроме того, было установлено, что сложность аудио декодирования, которое часто осуществляется в портативных устройствах потребителей, и которое поэтому должно быть дешевыми и потреблять мало энергии, зависит от кодирования, используемого для кодирования спектральных значений.
В связи с этой ситуацией, есть необходимость в концепции кодирования и декодирования аудио содержания, которая предусматривает улучшение компромисса между битрейт эффективностью и эффективностью использования ресурсов.
Сущность изобретения
Примером воплощения изобретения является аудио декодер для получения декодированной аудио информации (или декодированного аудио представления) на основе кодированной аудио информации (или кодированного аудио представления). Аудио декодер включает в себя арифметический декодер для предоставления множества декодированных спектральных значений на основе арифметически-кодированного представления спектральных значений. Аудио декодер также включает конвертер из частотной области во временную область для обеспечения во временной области аудио представления с помощью декодированных спектральных значений в целях получения декодированной аудио информации. Арифметический декодер предназначен для выбора правила отображения, описывающего отображение значения кода в код символа в зависимости от состояния контекста. Арифметический декодер настроен, чтобы определить текущее состояние контекста в зависимости от множества ранее декодированных спектральных значений. Арифметический декодер настроен на обнаружение группы из множества ранее декодированных спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины, а также для определения или изменения текущего состояния контекста в зависимости от результата обнаружения.
Этот вариант в соответствии с изобретением основан на открытии, что наличие группы из множества ранее декодированных (желательно, но не обязательно смежных) спектральных значений, которые соответствуют заданному условию относительно их величины, делает возможным особенно эффективное определение текущего состояния контекста, поскольку такие группы ранее декодированных (желательно смежных) спектральных значений являются характерной чертой в спектральном представлении, и поэтому могут быть использованы для облегчения определения текущего состояния контекста. При обнаружении группы из множества ранее декодированных (желательно смежных) спектральных значений, которые содержат, например, особенно малую величину, возможно узнать части сравнительно малой амплитуды в пределах спектра, а также настроить (определить или изменить) текущее состояние контекста соответственно, так что дальнейшие спектральные значения могут быть кодированы и декодированы с хорошей эффективностью кодирования (в пересчете на битрейт). Кроме того, группы из множества ранее декодированных смежных спектральных значений, которые содержат относительно большую амплитуду, могут быть обнаружены, и контекст может быть соответствующим образом скорректирован (определен или изменен), чтобы увеличить эффективность кодирования и декодирования. Кроме того, обнаружение группы из множества ранее декодированных (желательно смежных) спектральных значений, которые выполняют, по отдельности или вместе взятые, заданное условие, часто осуществляется с меньшими вычислительными усилиями, чем вычисление контекста, в котором многие ранее декодированные спектральные значения объединены. Подводя итоги, вышеописанные воплощения в соответствии с изобретением делают возможным упрощенное вычисление контекста и позволяют настройку контекста к конкретным совокупностям сигнала, в которых есть группы смежных сравнительно небольших спектральных значений или группы смежных сравнительно больших спектральных значений.
В предпочтительном варианте арифметический декодер настроен, чтобы определить или изменить текущее состояние контекста независимого от ранее декодированных спектральных значений в ответ на обнаружение, что заданное условие выполнено. Таким образом, получается вычислительно особенно эффективный механизм для вывода значения, описывающего контекст. Было установлено, что значительная адаптация контекста может быть достигнута, если обнаружение группы из множества ранее декодированных спектральных значений, которые соответствуют заданному условию, что приводит к простому механизму, который не требует вычислительно затратных числовых комбинаций ранее декодированных спектральных значений. Таким образом, вычислительное усилие уменьшается по сравнению с другими подходами. Кроме того, ускорения вывода контекста можно достичь, исключив сложные шаги расчета, которые зависят от обнаружения, поскольку такая концепция, как правило, неэффективна в программной реализации, выполняемой на процессоре.
В предпочтительном варианте арифметический декодер настроен на обнаружение группы из множества ранее декодированных смежных спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины.
В предпочтительном варианте арифметический декодер настроен на обнаружение группы из множества ранее декодированных смежных спектральных значений, которые, по отдельности или вместе взятые, содержат величину, которая меньше, чем заданный порог величины, и на определение текущего состояния контекста в зависимости от результатов обнаружения. Было установлено, что группа из множества смежных сравнительно низких спектральных значений может быть использована для выбора контекста, который хорошо адаптирован к данной ситуации. Если есть группа смежных сравнительно небольших спектральных значений, существует значительная вероятность того, что спектральное значение, декодируемое следующим, также содержит сравнительно небольшое значение. Соответственно, настройка контекста обеспечивает хорошую эффективность кодирования и может помочь избежать затрат времени на вычисление контекста.
В предпочтительном варианте арифметический декодер настроен на обнаружение группы из множества ранее декодированных смежных спектральных значений, при этом каждое из ранее декодированных спектральных значений имеет нулевое значение, а также на определение состояния контекста в зависимости от результата обнаружения. Было установлено, что в связи с спектральными или временными эффектами маскирования часто есть группы смежных спектральных значений, которые имеют нулевое значение.
Описанный вариант обеспечивает эффективную обработку такой ситуации. Кроме того, присутствие группы смежных спектральных значений, которые квантованы к нулю, делает весьма вероятным, что спектральное значение, декодируемой следующим, имеет либо нулевое значение, или сравнительно большое спектральное значение, что приводит к маскирующему эффекту.
В предпочтительном варианте арифметический декодер настроен на обнаружение группы из множества ранее декодированных смежных спектральных значений, которые содержат общее значение, которое меньше, чем заданный порог значения, и на определение состояния контекста в зависимости от результатов обнаружения. Было установлено, что в дополнение к группам смежных спектральных значений, которые равны нулю, также группы смежных спектральных значений, которые почти равны нулю в среднем (т.е. общее значение которых меньше заданного порогового значения) представляют собой характерную черту спектрального представления (например, время-частотное представление аудио содержания), которые могут быть использованы для адаптации контекста.
В предпочтительном варианте арифметический декодер настроен на установление текущего состояния контекста к заданному значению в ответ на обнаружение заданного условия. Было установлено, что эта реакция очень проста в реализации и по-прежнему приводит к адаптации контекста, которая обеспечивает хорошую эффективность кодирования.
В предпочтительном варианте арифметический декодер настроен выборочно пропускать расчет текущего состояния контекста в зависимости от числовых значений из множества ранее декодированных спектральных значений в ответ на обнаружение заданного условия. Таким образом, вычисление контекста существенно упрощается в связи с обнаружением группы из множества ранее декодированных смежных спектральных значений, которые удовлетворяют заданному условию. При экономии усилий на вычисление потребление энергии декодером аудио сигнала также снижается, что обеспечивает значительные преимущества в мобильных устройствах.
В предпочтительном варианте арифметический декодер настроен на установление текущего состояния контекста к значению, которое указывает на обнаружение заданного условия. Установив состояние контекста к значению, которое может быть в пределах заданного диапазона значений, дальнейшая оценка состояния контекста может быть проконтролирована. Тем не менее, следует отметить, что значение, в которое установлено текущее состояние контекста, может зависеть и от других критериев, даже если это значение находится в характерном диапазоне значений, которые указывают на обнаружение заданного условия.
В предпочтительном варианте арифметический декодер настроен на отображение кода символа на декодированное спектральное значение.
В предпочтительном варианте арифметический декодер настроен на оценку спектральных значений первого частотно-временного региона, обнаружение группы из множества спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины. Арифметический декодер настроен на получение числового значения, которое представляет состояние контекста, в зависимости от спектральных значений второго частотно-временного региона, который отличается от первого частотно-временного региона, если заданное условие не выполняется. Было установлено, что рекомендуется обнаружение группы из множества спектральных значений, которые удовлетворяют заданному условию относительно величины в регионе, который отличается от региона, обычно используемого для вычисления контекста. Это связано с тем, что расширение, например, частотное расширение, регионов, включающих сравнительно небольшие спектральные значения, или сравнительно большие спектральные значения, как правило, больше, чем размерность региона спектральных значений, которые рассматриваются для числовых расчетов числового значения, представляющего состояние контекста. Соответственно, рекомендуется провести анализ различных регионов для обнаружения группы из множества спектральных значений, выполняющих заданное условие, и для числового вычисления числового значения, представляющего состояние контекста (при этом числовой расчет может ожидаться на втором шаге, если обнаружение не дает бит.
В предпочтительном варианте арифметический декодер настроен на оценку одной или нескольких хэш-таблиц, чтобы выбрать правило отображения в зависимости от состояния контекста. Было установлено, что выбором правила отображения можно управлять с помощью механизма обнаружения множества смежных спектральных значений, которые удовлетворяют заданному условию.
Другой вариант использования изобретения приводит к созданию аудио кодера для получения кодированной аудио информации на основе входной аудио информации. Аудио кодер включает в себя энергоуплотняющий конвертер из временной области в частотную для обеспечения в частотной области аудио представления на основе представления входной аудио информации во временной области, так что аудио представление в частотной области включает в себя набор спектральных значений. Аудио кодер также включает в себя арифметический кодер, который настроен на кодирование спектрального значения, или его предварительно обработанной версии с помощью кодового слова с переменной длиной. Арифметический кодер настроен для отображения спектрального значения или значения наиболее значимого бита плоскости спектрального значения на значение кода. Арифметический кодер предназначен для выбора правила отображения, описывающего отображение спектрального значения или наиболее значимого бита плоскости спектрального значения на значение кода в зависимости от состояния контекста. Арифметический декодер предназначен, чтобы определять текущее состояние контекста в зависимости от множества ранее декодированных смежных спектральных значений. Арифметический декодер настроен на обнаружение группы из множества ранее декодированных смежных спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины, а также для определения текущего состояния контекста в зависимости от результата обнаружения.
Этот кодер аудио сигнала основан на тех же открытиях, как и декодер аудио сигнала, описанный выше. Было установлено, что механизм адаптации контекста, который показал свою эффективность для декодирования аудио содержания, следует также применять на стороне кодера для того, чтобы обеспечить последовательность системы.
Примером воплощения данного изобретения является создание способа для получения декодированной аудио информации на основе кодированной аудио информации.
Еще одним примером воплощения данного изобретения является создание способа для получения кодированной аудио информации на основе входной аудио информации.
Другой вариант воплощения изобретения содержит компьютерную программу для выполнения одного из указанных способов.
Эти способы и компьютерная программа основываются на тех же открытиях, как и вышеописанные аудио декодер и аудио кодер.
Краткое описание фигур
Использования изобретения будут далее описаны со ссылкой на прилагаемые фигуры, на которых:
Фиг.1 показывает блок-схему аудио кодера, согласно одному из вариантов использования изобретения;
Фиг.2 показывает блок-схему аудио декодера в соответствии с одним из вариантов использования изобретения;
Фиг.3 показывает представление кода псевдопрограммы алгоритма ″value_decode ()″ для декодирования спектрального значения;
Фиг.4 показывает схематическое представление контекста для вычисления контекста;
Фиг.5а показывает представление кода псевдопрограммы алгоритма ″arith_map_context ()″ для отображения контекста;
Фиг.5b и 5с показывают представление кода псевдопрограммы алгоритма ″arith_get_context ()″ для получения значения состояния контекста;
Фиг.5d показывает представление кода псевдопрограммы алгоритма ″get_pk(s)″ для извлечения значения индекса сводной таблицы частот ″pki″ из переменной состояния;
Фиг.5е показывает представление кода псевдопрограммы алгоритма ″arith_get_pk(s)″ для извлечения значения индекса сводной таблицы частот „pki″ из значения состояния;
Фиг.5f показывает представление кода псевдопрограммы алгоритма ″get_pk(unsigned long s)″ для извлечения значения индекса сводной таблицы частот „pki″ из значения состояния;
Фиг.5g показывает представление кода псевдопрограммы алгоритма ″arithdecode ()″ для арифметического декодирования символа из кодового слова переменной длины;
Фиг.5h показывает представление кода псевдопрограммы алгоритма ″arithupdatecontext ()″ для обновления контекста;
Фиг.5i показывает легенду определений и переменных;
Фиг.6а показывает синтаксис представления необработанного блока единого кодирования речи и аудио (USAC);
Фиг.6b показывает синтаксис представления единого элемента канала;
Фиг.6с показывает синтаксис представления парного элемента канала;
Фиг.6d показывает синтаксис представления ″ics″ контрольной информации;
Фиг.6е показывает синтаксис представления потока канала частотной области;
Фиг.6f показывает синтаксис представления арифметически кодированных спектральных данных;
Фиг.6g показывает синтаксис представление для декодирования множества спектральных значений;
Фиг.6h показывает легенду элементов данных и переменных;
Фиг.7 показывает блок-схему аудио кодера, согласно другому варианту осуществления изобретения;
Фиг.8 показывает блок-схему аудио декодера в соответствии с другим вариантом использования изобретения;
Фиг.9 показывает организацию сравнения бесшумного кодирования в соответствии с рабочим проектом 3 проекта стандарта USAC с схемой кодирования в соответствии с настоящим изобретением:
Фиг.10а показывает схематическое представление контекста расчета состояния, так как оно используется в соответствии с рабочим проектом 4 проекта стандарта USAC;
Фиг.10b показывает схематическое представление контекста расчета состояния, так как оно используется в воплощениях в соответствии с изобретением;
Фиг.11а показывает обзор таблицы, используемой в схеме арифметического кодирования в соответствии с рабочим проектом 4 проекта стандарта USAC;
Фиг.11b показывает обзор таблицы, используемой в схеме арифметического кодирования в соответствии с изобретением;
Фиг.12а показывает графическое представление запроса памяти только для чтения на схемы бесшумного кодирования в соответствии с настоящим изобретением и в соответствии с рабочим проектом 4 проекта стандарта USAC;
Фиг.12b показывает графическое представление общего запроса данных памяти только для чтения декодера USAC в соответствии с настоящим изобретением и в соответствии с рабочим проектом 4 проекта стандарта USAC;
Фиг.13а показывает таблицу представления средних битрейтов, которые используются кодером единого кодирования речи и аудио, с помощью арифметического кодера в соответствии с рабочим проектом 3 проекта стандарта USAC и арифметическим декодером в соответствии с вариантом осуществления настоящего изобретения;
Фиг.13b показывает таблицу представления контроля резервуара бит для кодера единого кодирования речи и аудио с помощью арифметического кодера в соответствии с рабочим проектом 3 проекта стандарта USAC и арифметического кодера в соответствии с вариантом осуществления настоящего изобретения;
Фиг.14 показывает таблицу представления средних битрейтов USAC кодера в соответствии с рабочим проектом 3 проекта стандарта USAC и в соответствии с вариантом осуществления настоящего изобретения;
Фиг.15 показывает таблицу представления минимального, максимального и среднего битрейта USAC на основе кадра;
Фиг.16 показывает таблицу представления лучшего и худшего случаев на основе кадра;
Фиг.17 (1) и 17 (2) показывают таблицу представления содержания таблицы ″ari_s_hash[387]″;
Фиг.18 показывает таблицу представления содержания таблицы ″ari_gs_hash[225]″;
Фиг.19 (1) и 19 (2) показывают таблицу представления содержания таблицы ″ari_cf_m[64][9]″; и
Фиг.20 (1) и 20 (2) показывают таблицу представления содержания таблицы ″ari_s_hash[387]″.
Подробное описание вариантов использования изобретения 1. Аудио кодер в соответствии с фиг.7
Фиг.7 показывает блок-схему аудио кодера, согласно одному из вариантов использования изобретения; Аудио декодер 700 настроен на получение входной аудио информации 710 и на представлении на ее основе кодированной аудио информации 712. Аудио кодер включает в себя энергоуплотняющий конвертер из временной области в частотную 720, который предназначен для обеспечения в частотной области аудио представления 722 на основе представления входной аудио информации 710 во временной области, так что аудио представление в частотной области 722 включает в себя набор спектральных значений. Аудио кодер 700 также включает в себя арифметический кодер 730, предназначенный для кодирования спектрального значения (из множества спектральных значений, формирующих в частотной области аудио представление 722), или его предварительно обработанной версии с помощью кодового слова переменной длиной, чтобы получить кодированную аудио информацию 712 (которая может включать, например, множество кодовых слов переменной длины).
Арифметический кодер 730 настроен на отображение спектрального значения или значения наиболее значимого бита плоскости спектрального значения на значение кода (т.е. на кодовое слово переменной длины) в зависимости от состояния контекста. Арифметический кодер 730 предназначен для выбора правила отображения, описывающего отображение спектрального значения или наиболее значимого бита плоскости спектрального значения на значение кода в зависимости от состояния контекста. Арифметический кодер предназначен, чтобы определять текущее состояние контекста в зависимости от множества ранее кодированных (желательно, но не обязательно смежных) спектральных значений. Для этого арифметический кодер настроен на обнаружение группы из множества ранее кодированных смежных спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины, а также для определения текущего состояния контекста в зависимости от результата обнаружения.
Как можно видеть, отображение спектрального значения или наиболее значимого бита плоскости спектрального значения на значение кода может осуществляться кодированием спектрального значения 740 с помощью отображения 742. Трекер состояния 750 может быть сконфигурирован для отслеживания состояния контекста и может включать в себя детектор группы 752 для обнаружения группы из множества ранее кодированных смежных спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины. Трекер состояния 750 также желательно настроить для определения текущего состояния контекста в зависимости от результата этого обнаружения, выполненного детектором группы 752. Таким образом, трекер состояния 750 обеспечивает информацию 754, описывающую текущее состояние контекста. Селектор правила отображения 760 может выбрать правило отображения, например, сводную таблицу частот, описывающую отображение спектрального значения, или наиболее значимого бита плоскости спектрального значения, на значение кода. Соответственно, селектор правила отображения 760 предоставляет информацию правила отображения 742 для спектрального кодирования 740.
Подводя итог вышесказанному, аудио кодер 700 выполняет арифметическое кодирование в частотной области аудио представления, осуществляемого конвертером из временной области в частотную. Арифметическое кодирование зависит от контекста, например, правило отображения (например, сводная таблица частот) выбирается в зависимости от ранее кодированных спектральных значений. Таким образом, спектральные значения, смежные во времени и/или частоте (или, по крайней мере, в заданном окружении) друг с другом и/или с в данный момент кодируемым спектральным значением (т.е. спектральные значения в заданном окружении в данный момент кодируемого спектрального значения) рассматриваются в арифметическом кодировании для регулировки распределения вероятности, оцениваемой арифметическим кодированием. При выборе соответствующего правила отображения, обнаружения проводится с целью выявления, есть ли группа из множества ранее кодированных смежных спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины. Результат этого обнаружения применяется при выборе текущего состояния контекста, т.е. при выборе правила отображения. Определив, существует ли группа из множества спектральных значений, которые являются особенно малыми или особенно большими, можно распознать особенности в частотной области аудио представления, которое может быть частотно-временным представлением. Особые черты, такие как, например, группа из множества особенно малых или особенно больших спектральных значений, показывают, что особое состояние контекста следует использовать, поскольку это особое состояние контекста может дать особенно хорошую эффективность кодирования. Таким образом, выявление группы смежных спектральных значений, которые удовлетворяют заданному условию, что обычно используется в сочетании с альтернативной оценкой контекста, основанной на сочетании множества ранее кодированных спектральных значений, представляет собой механизм, который позволяет эффективно выбирать соответствующий контекст, если входная аудио информация требует некоторых особых состояний (например, содержит большой маскированный диапазон частот).
Соответственно, эффективное кодирование может быть достигнуто при сохранении расчета контекста достаточно простым.
2. Аудио декодер в соответствии с фиг.8
Фиг.8 показывает блок-схему аудио декодера 800. Аудио декодер 800 настроен на получение кодированной аудио информации 810 и на представлении на ее основе декодированной аудио информации 812. Аудио декодер 800 включает в себя арифметический декодер 820, который предназначен для предоставления множества декодированных спектральных значений 822 на основе арифметически-кодированного представления 821 спектральных значений. Аудио декодер 800 также включает конвертер из частотной области во временную область 830, который предназначен для получения декодированных спектральных значений 822 и предоставления во временной области аудио представления 812, которое может включать декодированную аудио информацию, с помощью декодированных спектральных значений 822, для получения декодированной аудио информации 812.
Арифметический декодер 820 включает в себя определитель спектрального значения 824, настроенный на отображения значения кода арифметически кодированного представления 821 спектральных значений на код символа, представляющий одно или несколько декодированных спектральных значений, или, по крайней мере, часть (например, наиболее значимые биты плоскости) одного или нескольких декодированных спектральных значений. Определитель спектрального значения 824 может быть настроен для выполнения отображения в зависимости от правила отображения, которое может быть описано в информации правила отображения 828а.
Арифметический декодер 820 настроен на выбор правила отображения (например, сводной таблицы частот), описывающего отображение значения кода (описываемого в арифметически кодированном представлении 821 спектральных значений) на код символа (описывающий одно или несколько спектральных значений) в зависимости от состояния контекста (которое может быть описано в информации состояния контекста 826а). Арифметический декодер 820 настроен, чтобы определить текущее состояние контекста в зависимости от множества ранее декодированных спектральных значений 822. Для этого трекер состояния 826 может быть использован, который получает информацию с описанием ранее декодированных спектральных значений. Арифметический декодер также настроен на обнаружение группы из множества ранее декодированных (желательно, но не обязательно смежных) спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины, а также для определения текущего состояния контекста (описанного, например, в информации состояния контекста 826а) в зависимости от результата обнаружения.
Обнаружение группы из множества ранее декодированных смежных спектральных значений, которые соответствуют заданному условию относительно их величины, может, например, проводиться детектором группы, который является частью трекера состояния 826. Таким образом, получается информация текущего состояния контекста 826а. Выбор правила отображения может выполняться селектором правила отображения 828, который извлекается из информации правила отображения 828а из информации текущего состояния контекста 826а, и который обеспечивает информацию правила отображения 828а для определителя спектрального значения 824.
Что касается функциональных возможностей декодера аудио сигнала 800, следует отметить, что арифметический декодер 820 настроен на выбор правила отображения (например, сводную таблицу частот), которое, в среднем, хорошо адаптировано к спектральному значению для декодирования, так как правило отображения выбирается в зависимости от текущего состояния контекста, что в свою очередь, определяется в зависимости от множества ранее декодированных спектральных значений. Таким образом, статистические зависимости между смежными спектральными значениями для декодирования могут быть использованы. Более того, обнаружив группу из множества ранее декодированных смежных спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины, можно адаптировать правило отображения к особым условиям (или моделям) ранее декодированных спектральных значений. Например, особое правило отображения может быть выбрано, если группа из множества сравнительно небольших ранее декодированных смежных спектральных значений идентифицирована, или если группа из множества сравнительно больших ранее декодированных смежных спектральных значений идентифицирована. Было обнаружено, что присутствие группы сравнительно больших спектральных значений или группы сравнительно небольших спектральных значений можно рассматривать как существенный признак того, что выделенное правило отображения, специально адаптированное для такого состояния, должно быть использовано. Таким образом, вычислению контекста может способствовать (или ускорять) использование обнаружения такой группы из множества спектральных значений. Кроме того, те характеристики аудио содержания можно рассматривать, которые нельзя рассматривать так же легко без применения вышеупомянутой концепции. Например, обнаружение группы множества спектральных значений, которые соответствуют, по отдельности или вместе взятые, заданному условию относительно их величины, может быть выполнено на основе различных наборов спектральных значений, по сравнению с набором спектральных значения, используемых для вычисления нормального контекста.
Дальнейшие подробности будут описаны ниже.
3. Аудио кодер в соответствии с фиг.1
Далее будет описан аудио кодер в соответствии с вариантом осуществления настоящего изобретения. Фиг.1 показывает блок-схему такого аудио кодера 100.
Аудио кодер 100 настроен на получение входной аудио информации ПО и на предоставлении на ее основе битового потока 112, который представляет собой кодированную аудио информацию. Аудио декодер 100 может дополнительно включать препроцессор 120, который настроен на получение входной аудио информации ПО и предоставление на ее основе предварительно обработанную входную аудио информацию 110а. на фиг. Аудио кодер 100 также включает в себя энергоуплотняющий трансформер сигнала из временной области в частотную 130, который также обозначается как конвертер сигнала. Конвертер сигнала 130 настроен на получение входной аудио информации 110, 110а и предоставление на ее основе аудио информации 132 в частотной области, которая предпочтительно имеет вид набора спектральных значений. Например, трансформер сигнала 130 может быть сконфигурирован для получения кадра входной аудио информации 110, 110а (например, блок образцов временной области) и для предоставления набора спектральных значений, представляющих аудио содержание соответствующего аудио кадра. Кроме того, трансформер сигнала 130 может быть настроен на получение множества последующих, перекрывающихся или неперекрывающихся, аудио кадров входной аудио информации 110, 110а и предоставления на ее основе аудио представления во временной и частотной области, которое состоит из последовательности последующих наборов спектральных значений, один набор спектральных значений связан с каждым кадром.
Энергоуплотняющий трансформер сигнала из временной области в частотную 130 может включать в себя энергоуплотняющий банк фильтров, который обеспечивает спектральные значения, связанные с различными, перекрывающимися или неперекрывающимися, частотными диапазонами. Например, трансформер сигнала 130 может включать в себя оконный MDCT трансформер 130а, который настроен на оконную работу с входной аудио информацией 110, 110а (или его кадр) с помощью окна преобразования и выполнения модифицированного дискретного косинус-преобразования оконной входной аудио информации 110, 110а (или оконный кадр). Таким образом, аудио представление в частотной области 132 может включать в себя набор, например, 1024 спектральных значений в виде MDCT коэффициентов, связанных с кадром входной аудио информации.
Аудио декодер 100 может дополнительно включать спектральный постпроцессор 140, который настроен на получение аудио представления в частотной области 132 и предоставление на ее основе пост обработанное аудио представление в частотной области 142. Спектральный постпроцессор 140 может, например, быть настроен на выполнение временного ограничения шума и / или долгосрочного прогноза и / или любой другой спектральной постобработки, известной в данной области. Аудио кодер дополнительно содержит, по желанию, скейлер / квантователь 150, который настроен на получение в частотной области аудио представления 132 или ее версию пост-обработки 142 и для обеспечения масштабированного и квантованного аудио представления в частотной области 152.
Аудио кодер 100 дополнительно содержит, по желанию, психоакустическую модель процессора 160, который настроен на получение входной аудио информации 110 (или постобработанной версии 110а) и для представления на ее основе дополнительной контрольной информации, которая может быть использована для управления энергоуплотняющим трансформером сигнала из временной области в частотную 130 для управления дополнительным спектральным постпроцессором 140 и / или для контроля за дополнительным скейлером / квантователем 150. Например, психоакустическая модель процессора 160 может быть сконфигурирована для анализа входной аудио информации, чтобы определить, какие компоненты входной аудио информации 110, 110а особенно важны для человеческого восприятия аудио содержания и какие компоненты входной аудио информации 110, 110а менее важны для восприятия аудио содержания. Таким образом, психоакустическая модель процессора 160 может обеспечить контрольную информации, которая используется аудио кодером 100 для регулировки масштабирования аудио представления в частотной области 132, 142 скейлером / квантователем 150 и/или разрешением квантования, применяемом скейлером / квантователем 150. Следовательно, важные для восприятия группы масштабных коэффициентов (т.е. группы смежных спектральных значений, которые являются особенно важными для человеческого восприятия аудио содержания) масштабируется с большим коэффициентом масштабирования и квантуются со сравнительно высоким разрешением, в то время как менее важные для восприятия группы масштабных коэффициентов (т.е. группы смежных спектральных значений) масштабируются со сравнительно меньшим коэффициентом масштабирования и квантуются со сравнительно низким разрешением квантования. Таким образом, масштабированные спектральные значения частот более важных для восприятия, как правило, значительно больше, чем спектральные значения частот менее важных для восприятия.
Аудио кодер также включает в себя арифметический кодер 170, который настроен на получение масштабированной и квантованной версии 152 аудио представления в частотной области 132 (или, наоборот, постобработанной версии 142 аудио представления в частотной области 132, или даже само аудио представление в частотной области 132), а также для обеспечения арифметической информации кодового слова 172а на ее основе, например, так что арифметическая информация кодового слова представляет аудио представление в частотной области 152.
Аудио кодер 100 также включает в себя форматтер полезной нагрузки битового потока 190, который настроен на получение арифметической информации кодового слова 172а. Форматтер полезной нагрузки битового потока 190 также обычно настроен на получение дополнительной информации, как, например, информации коэффициента масштабирования, описывающей какие коэффициенты масштабирования были применены скейлером / квантователем 150. Кроме того, форматтер полезной нагрузки битового потока 190 может быть настроен на получение другой управляющей информации. Форматтер полезной нагрузки битового потока 190 настроен на обеспечение битового потока 112 на основе полученной информации путем сборки битового потока в соответствии с желаемым синтаксисом потока, который будет обсуждаться ниже.
Далее будут описаны подробности, касающиеся арифметического кодера 170. Арифметический кодер 170 настроен на получение множества постобработанных и масштабированных и квантованных спектральных значений аудио представления в частотной области 132. Арифметический кодер включает в себя экстрактор наиболее значимых битов плоскости 174, который настроена на извлечение наиболее значимых бит плоскости m спектрального значения. Следует отметить, что наиболее значимый бит плоскости может содержать один или более битов (например, два или три бита), которые являются наиболее значимыми битами спектрального значения. Таким образом, экстрактор наиболее значимых битов плоскости 174 обеспечивает значение наиболее значимого бита плоскости 176 спектрального значения.
Арифметический кодер 170 также включает в себя определитель первого кодового слова 180, который настроен, чтобы определить арифметическое кодовое слово acod_m[pki][m], представляющее значение наиболее значимого бита плоскости значение т.По желанию, определитель кодового слова 180 может также предоставить одно или большее количество управляющих кодовых слов (также обозначенные здесь с ″ARITHESCAPE″) с указанием, например, как много менее значимых бит плоскости доступны (и, следовательно, с указанием числового веса наиболее значимого бита плоскости). Определитель первого кодового слова 180 может быть сконфигурирован для обеспечения кодового слова, связанного с значением наиболее значимого бита плоскости m с помощью выбранной сводной таблицы частоты, имеющей (или которая ссылается на) индекс сводной таблицы частоты pki.
Для того чтобы определить, какую сводную таблицу частот надо выбрать, арифметический кодер предпочтительно включает в себя трекер состояния 182, который настроен на отслеживание состояния арифметического кодера, например, с помощью наблюдения за тем, какие спектральные значения были кодированы ранее. Трекер состояния 182, следовательно, дает информацию о состоянии 184, например, значение состояния обозначается ″s″ или ″t″. Арифметический кодер 170 также включает селектор сводной таблицы частот 186, который настроен на получение информации о состоянии 184 и предоставление информации 188, описывающей выбранную сводную таблицу частот для определителя кодового слова 180. Например, селектор сводной таблицы частот 186 может дать индекс сводной таблицы частот „pki″, описывающий какая сводная таблица частот из набора из 64 сводных таблиц частот выбрана для использования определителем кодового слова. Кроме того, селектор сводной таблицы частот 186 может обеспечить всю выбранную сводную таблицу частот для определителя кодового слова. Таким образом, определитель кодового слова 180 может использовать выбранную сводную таблицу частот для предоставления кодового слова acod_m[pki][m] значения наиболее значимого бита плоскости т, так что фактическое кодовое слово acod_m[pki][m] кодирования значения наиболее значимого бита плоскости m зависит от значения m и индекса сводной таблицы частот pki, и, следовательно, от информации текущего состояния 184. Более подробная информация о процессе кодирования и формате полученного кодового слова будет описана ниже.
Арифметический кодер 170 также включает в себя экстрактор наименее значимых битов плоскости 189а, который настроен на извлечение одного или более менее значимых бит плоскости из масштабированного и квантованного аудио представления в частотной области 152, если один или несколько спектральных значений для кодирования превышают диапазон кодируемых значений с помощью только самых значимых бит плоскости. Менее значимые биты плоскости могут включать один или несколько битов, по желанию. Соответственно, экстрактор наименее значимых битов плоскости 189а предоставляет информацию менее значимых бит плоскости 189b. Арифметический кодер 170 также включает в себя определитель второго кодового слова 189 с, который настроен на получение информации менее значимых бит плоскости 189d и предоставления не ее основе 0, 1 или более кодовых слов ″acod_r″, представляющих содержание 0, 1 или больше менее значимых бит плоскости. Определитель второго кодового слова 189 с может быть настроен на применение алгоритма арифметического кодирования или любой другой алгоритм кодирования для того, чтобы извлечь кодовые слова менее значимых бит плоскости ″acod_r″ из информации менее значимых бит плоскости 189b.
Следует отметить, что ряд менее значимых бит плоскости могут варьироваться в зависимости от значения масштабированных и квантованных спектральных значений 152, так что может не быть менее значимых бит плоскости вообще, если масштабированное и квантованное спектральное значение, которое будут кодировано, сравнительно невелико, например, может быть один менее значимый бит плоскости, если текущее масштабированное и квантованное спектральное значение для кодирования имеет средний диапазон и так, что может быть более одного менее значимых бит плоскости, если масштабированное и квантованное спектральное значение для кодирования имеет сравнительно большое значение.
Подводя итог вышесказанному, арифметический кодер 170 настроен на кодирование масштабированных и квантованных спектральных значений, которые описаны в информации 152 с помощью иерархического процесса кодирования. Наиболее значимый бит плоскости (включая, например, один, два или три бита на спектральное значение) кодируется для получения арифметического кодового слова ″acod_m[pki][m]″ значения наиболее значимого бита плоскости. Один или несколько менее значимых бит плоскости (каждая из менее значимых бит плоскости включает, например, один, два или три бита) кодируются, чтобы получить одно или несколько кодовых слов ″acodr″. При кодировании наиболее значимых битов плоскости значение m наиболее значимого бита плоскости отображается в кодовое слово acod_m[pki][m]. Для этого 64 разных сводных таблиц частоты доступны для кодирования значения m в зависимости от состояния арифметического кодера 170, т.е. в зависимости от ранее кодированных спектральных значений. Таким образом, получается кодовое слово ″acod_m[pki][m]″. Кроме того, одно или несколько кодовых слов "acod_r" предусмотрены и включены в битовый поток, если присутствуют один или несколько менее значимых бит плоскостей.
Описание сброса
Аудио кодер 100 может быть дополнительно настроен на решение о том, можно ли достичь повышения битрейта путем сброса контекста, например, установив индекса состояния на значение по умолчанию. Таким образом, аудио кодер 100 может быть сконфигурирован для обеспечения информации сброса (например, под названием ″arith_reset_flag″), указывающей, является ли контекст для арифметического кодирования сброшенным, а также указывающей, следует ли сбросить контекст для арифметического декодирования в соответствующем декодере.
Подробнее формат битового потока и применяемые сводные таблицы частоты будут рассмотрены ниже.
4. Аудио декодер
Далее будет описан аудио декодер в соответствии с вариантом осуществления настоящего изобретения. Фиг.2 показывает блок-схему такого аудио декодера 200.
Аудио декодер 200 настроен на получение битового потока 210, который представляет кодированную аудио информацию и который может быть одинаковым с битовым потоком 112, предоставляемым кодером 100. Аудио декодер 200 обеспечивает декодированную аудио информацию 212 на основе битового потока 210.
Аудио декодер 200 включает в себя дополнительный деформаттер полезной нагрузки битового потока 220, который настроен на получение битового потока 210 и извлечение из битового потока 210 кодированного аудио представления в частотной области 222. Например, деформаттер полезной нагрузки битового потока 220 может быть настроен на извлечение из битового потока 210 арифметически кодированных спектральных данных, таких как, например, арифметическое кодовое слово ″acodm[pki][m]″, представляющее значение наиболее значимого бита плоскости m спектрального значения а, а также кодовое слово ″acod_r″, представляющее содержание менее значимого бита плоскости спектрального значение а в аудио представлении в частотной области. Таким образом, кодированное аудио представление в частотной области 222 составляет (или включает) арифметически кодированное представление спектральных значений. Деформаттер полезной нагрузки битового потока 220 дополнительно настроен на извлечение из битового потока дополнительной информации управления, которая не показана на фиг.2. Кроме того, деформаттер полезной нагрузки битового потока дополнительно настроен на извлечение из битового потока 210 информации сброса состояния 224, которая также обозначается как арифметический флаг сброса или ″arithresetflag″.
Аудио декодер 200 включает в себя арифметический декодер 230, который также обозначается как ″спектральный бесшумный декодер″. Арифметический декодер 230 настроена на прием кодированного аудио представления в частотной области 220 и, при необходимости, информации о сбросе состояния 224. Арифметический декодер 230 также настроен на предоставление декодированного аудио представления в частотной области 232, которое может включать в себя декодированное представление спектральных значений. Например, декодированное аудио представление в частотной области 232 может содержать декодированное представление спектральных значений, которые описаны в кодированном аудио представлении в частотной области 220.
Аудио декодер 200 также включает в себя дополнительный обратный квантователь / рескейлер 240, который настроен на получение декодированного аудио представления в частотной области 232 и предоставление на его основе обратно квантованного и ре-масштабированного аудио представления в частотной области 242.
Аудио декодер 200 также дополнительно может включать спектральный предпроцессор 250, который настроен на получение обратно квантованного и ре-масштабированного аудио представления в частотной области 242 и предоставления на его основе предварительно обработанной версии 252 обратно квантованного и ре-масштабированного аудио представления в частотной области 242. Аудио кодер 200 также включает в себя трансформер сигнала из частотной области в временную 260, который также обозначается как конвертер сигнала. Трансформер сигнала 260 настроена на прием предварительно обработанной версии 252 обратно квантованного и ре-масштабированного аудио представления в частотной области 242 (или, наоборот, обратно квантованного и ре-масштабированного аудио представления в частотной области 242 или декодированного аудио представления в частотной области 232) и предоставления на его основе аудио информации представления 262 во временной области. Трансформер сигнала из частотной области во временную область 260 может, например, включать трансформер для выполнения обратного модифицированного дискретного косинус-преобразования (IMDCT) и соответствующей оконной работы (а также других вспомогательных функций, как, например, перекрытие-и-добление).
Аудио декодер 200 может дополнительно содержать постпроцессор временной области 270, который настроен на получение представления во временной области 262 аудио информации и для получения декодированной аудио информации 212 с помощью пост-обработки в временной области. Однако, если пост-обработка отсутствует, представление во временной области 262 может быть идентичным декодированной аудио информации 212.
Следует отметить, что обратный квантователь / рескейлер 240, спектральный предпроцессор 250, трансформер сигнала из частотной области во временную область 260 и постпроцессор во временной области 270 могут управляться в зависимости от управляющей информации, которая извлекается из битового потока 210 с помощью деформаттера полезной нагрузки битового потока 220.
Подводя итог общей функциональности аудио декодера 200, декодированное аудио представление в частотной области 232, например, набор спектральных значений, связанных с аудио кадром кодированной аудио информации, могут быть получены на основе кодированного представления в частотной области 222 с помощью арифметического декодера 230. Следовательно, множество, например, 1024 спектральных значений, которые могут быть MDCT коэффициентами, обратно квантованы, ре-масштабированы и предварительно обработаны. Соответственно, обратно квантованное, ре-масштабированное и спектрально предварительно обработанное множество спектральных значений (например, 1024 MDCT коэффициенты) получается. Впоследствии, представление во временной области аудио кадра извлекается из обратно квантованного, ре-масштабированного и спектрально предварительно обработанного множества значений в частотной области (например, MDCT коэффициенты). Соответственно, получается представление во временной области аудио кадра. Представление во временной области данного аудио кадра может быть объединено с представлениями во временной области предыдущего и/или последующих аудио кадров. Например, перекрытие-и-добавление между представлениями во временной области последующих аудио кадров может быть выполнено для того, чтобы сгладить переходы между представлениями во временной области смежных аудио кадров и с целью получения отмены сглаживания. Для получения дополнительной информации о реконструкции декодированной аудио информации 212 на основе декодированного аудио представления в частотно-временной области 232, делается ссылка, например, на международный стандарт ISO / IEC 14496-3, часть 3, субчасть 4, где это детально обсуждается. Тем не менее, другие более сложные схемы перекрытия и отмены наложения могут быть использованы.
Далее будут описаны подробности, касающиеся арифметического декодера 230. Арифметический декодер 230 включает в себя определитель наиболее значимого бита плоскости 284, который настроен на получение арифметического кодового слова acod_m [pki][m], описывающего значение m наиболее значимого бита плоскости. Определитель наиболее значимого бита плоскости 284 может быть настроен на использование сводной таблицы частот из набора, содержащего множество 64 сводных таблиц частот для извлечения значения m наиболее значимого бита плоскости из арифметического кодового слова ″acod_m [pki][m]″.
Определитель наиболее значимого бита плоскости 284 настроен на извлечение значений 286 наиболее значимого бита плоскости спектральных значений на основе кодового слова acod_m. Арифметический декодер 230 дополнительно включает определитель наименее значимого бита плоскости 288, который настроен на получение одного или нескольких кодовых слов ″acod_r″, представляющих один или несколько менее значимых бит плоскости спектрального значения. Соответственно, определитель наименее значимого бита плоскости 288 настроен обеспечить декодированные значения 290 одного или нескольких менее значимых бит плоскости. Аудио декодер 200 также включает в себя сумматор бит плоскости 292, который настроен на получение декодированных значений 286 наиболее значимых бит плоскости спектральных значений и декодированных значений 290 одной или нескольких менее значимых бит плоскостей спектральных значений, если такие менее значимые бит плоскости доступные для текущих спектральных значений. Соответственно, сумматор бит плоскости 292 обеспечивает декодированные спектральные значения, которые являются частью декодированного аудио представления в частотной области 232. Естественно, арифметический декодер 230, как правило, настроены на предоставлении множества спектральных значений для того, чтобы получить полный набор декодированных спектральных значений, связанных с текущим кадром аудио содержания.
Арифметический декодер 230 дополнительно включает селектор сводной таблицы частот 296, который настроен на выбор одной из 64 сводных таблиц частот в зависимости от индекса состояния 298, описывающего состояние арифметического декодера. Арифметический декодер 230 дополнительно включает трекер состояния 299, который настроен для отслеживания состояния арифметического декодера в зависимости от ранее декодированных спектральных значений. Информация о состоянии может необязательно быть сброшена к информации состояния по умолчанию в ответ на информацию сброса состояния 224. Таким образом, селектор сводной таблицы частот 296 настроен для предоставления индекса (например, pki), выбранной сводной таблицы частот или самой выбранной сводной таблицы частот, для применения в декодировании значения m наиболее значимого бита плоскости в зависимости от кодового слова ″acodm″.
Подводя итог функциональности аудио декодера 200, аудио декодер 200 настроен на получение битрейт эффективного кодированного аудио представления в частотной области 222 и получение декодированного аудио представления в частотной области на его основе. В арифметическом декодере 230, который используется для получения декодированного аудио представления в частотной области 232 на основе кодированного аудио представления в частотной области 222, вероятность различных комбинаций значений наиболее значимых бит плоскостей смежных спектральных значений используется с помощью арифметического декодера 280, который настроен применять сводную таблицу частот. Другими словами, статистические зависимости между спектральными значениями эксплуатируются путем выбора различных сводных таблиц частоты из набора, включающего 64 различных сводных таблиц частоты в зависимости от индекса состояния 298, который получается при наблюдении за ранее вычисленными декодированными спектральными значениями.
5. Обзор за инструментов спектрального бесшумного кодирования
Далее будут описаны подробности, касающиеся алгоритма кодирования и декодирования, который выполняется, например, арифметическим кодером 170 и арифметическим декодером 230.
Основное внимание уделяется описанию алгоритма декодирования. Следует отметить, однако, что соответствующий алгоритм кодирования может быть выполнен в соответствии с объяснением алгоритма декодирования, в котором отображения меняются на противоположные.
Следует отметить, что декодирование, которое будет обсуждаться далее, используется для того, чтобы обеспечить так называемое ″спектральное бесшумное кодирование″ обычно постобработанных, масштабированных и квантованных спектральных значений. Спектральное бесшумное кодирование используются в концепции аудио кодирования / декодирования для дальнейшего сокращения избыточности квантованного спектра, которые получают, например, при помощи энергоуплотняющего трансформера из временной области в частотную область.
Схема спектрального бесшумного кодирования, которое используется в вариантах изобретения, основана на арифметическом кодировании в сочетании с динамически адаптированным контекстом. Бесшумное кодирование снабжается (оригинальными или кодированными представлениями) квантованными спектральными значениями и использует контекстно-зависимые сводные таблицы частот, полученные, например, из множества ранее декодированных соседних спектральных значений. Здесь, учитывается соседство как во времени, так и по частоте, как показано на фиг.4. Сводные таблицы частот (о которых будет сказано ниже) затем используются арифметическим кодером для создания двоичного кода переменной длины и арифметическим декодером для извлечения декодированных значений из двоичного кода переменной длины.
Например, арифметический кодер 170 производит двоичный код для данного набора символов, в зависимости от соответствующих вероятностей. Двоичный код образуется путем отображения интервала вероятности, в котором лежит набор символов, на кодовое слово.
Далее будет дан еще один короткий обзор инструментов спектрального бесшумного кодирования. Спектральное бесшумное кодирование используется для дальнейшего сокращения избыточности квантованного спектра. Схема спектрального бесшумного кодирования основывается на арифметическом кодировании в сочетании с динамически адаптированным контекстом. Бесшумное кодирование снабжается квантованными спектральными значениями и использует контекстно-зависимые сводные таблицы частот, полученные, например, из семи ранее декодированных соседних спектральных значений.
Здесь, учитывается соседство как во времени, так и по частоте, как показано на фиг.4. Сводные таблицы частот затем используются арифметическим кодером для генерации двоичного кода переменной длины.
Арифметический кодер производит двоичный код для данного набора символов и их соответствующих вероятностей. Двоичный код образуется путем отображения интервала вероятности, в котором лежит набор символов, на кодовое слово.
6. Процесс декодирования
6.1 Обзор процесса декодирования
Далее будет дан обзор процесса декодирования спектрального значения со ссылкой на фиг.3, которая показывает представление псевдопрограммного кода процесса декодирования множества спектральных значений.
Процесс декодирования множества спектральных значений содержит инициализацию 320 контекста. Инициализация 310 контекста включает в себя извлечение текущего контекста из предыдущего контекста с помощью функции ″arithmapcontext (lg)″. Извлечение текущего контекста из предыдущего контекста может включать в себя сброс контекста. И сброс контекста, и извлечение текущего контекста из предыдущего контекста будут рассмотрены ниже.
Декодирование множества спектральных значений также включает в себя повторение декодирования спектральных значений 312 и обновление контекста 314, которое обновление выполняется функцией ″Arith_update_context(a,i,lg)″, которая описана ниже. Декодирование спектральных значений 312 и обновление контекста 314 повторяется lg раз, при этом lg указывает число спектральных значений для декодирования (например, для аудио кадра). Декодирование спектральных значений 312 включает в себя расчет значения контекста 312а, декодирование наиболее значимого бита плоскости 312b, и добавление менее значимого бита плоскости 312с.
Вычисление значения состояния 312а включает в себя вычисление первого значения состояния s при помощи функции ″arith_get_context(i, lg, arith_reset_flag, N/2)″, которая возвращает первое значение состояния s. Вычисление значения состояния 312а также включает в себя вычисление значения уровня ″lev0″ и значения уровня ″lev″, эти значения уровня ″lev0″, „lev″ получаются путем сдвига первого значения состояния s вправо на 24 бит. Вычисление значения состояния 312а также включает в себя вычисление второго значения состояния t в соответствии с формулой, приведенной на фиг.3 на ссылке с номером 312а.
Декодирование наиболее значимого бита плоскости 312b включает в себя итерационное выполнение алгоритма декодирования 312ba, при этом переменная j инициализируется до 0 перед первым выполнением алгоритма 312ba.
Алгоритм 312ba включает в себя вычисление индекса состояния „pki″ (который также служит в качестве индекса сводной таблицы частот) в зависимости от второго значения состояния t, а также в зависимости от значений уровня „lev" и lev0, с помощью функции ″arith_get_pk()″„, которая обсуждается ниже. Алгоритм 312ba также включает в себя выбор сводной таблицы частот в зависимости от индекса состояния pki, где переменная ″cumfreq″ может быть установлена на начальный адрес одной из 64 сводных таблиц частот в зависимости от индекса pki. Кроме того, переменная ″cfl″ может быть инициализирована на длину выбранной сводной таблицы частот, которая, например, равна количества символов в алфавите, то есть количеству различных значений, которые могут быть декодированы. Длины всех сводных таблиц частот от ″arith_cf_m[pki=0][9]″ до ″arith_cf_m[pki=63][9]″, доступных для декодирования значения наиболее значимого бита плоскости ш, составляют 9, так что восемь различных значений наиболее значимых бит плоскости и управляющий символ могут быть декодированы. Впоследствии, значение наиболее значимого бита плоскости m может быть получено путем выполнения функции ″arith_decode()″, с учетом выбранной сводной таблицы частоты (описанной переменной ″cum freq″ и переменной ″cfl″). При извлечении значения наиболее значимого бита плоскости m, биты под названием ″acod_m″ в битовом потоке 210 могут быть оценены (см., например, фиг.6g).
Алгоритм 312ba также включает в себя проверку того, равно ли значение наиболее значимого бита плоскости m управляющему символу ″ARITHESCAPE″, или нет. Если значение наиболее значимого бита плоскости m не равно арифметическому управляющему символу, алгоритм 312ba прерывается (условие ″перерывания″), а остальные инструкции алгоритма 312ba поэтому пропущены. Таким образом, выполнение процесса продолжается установкой спектрального значения а равным значению наиболее значимого бита плоскости m (инструкция ″а=m″). В отличие от этого, если декодированное значение наиболее значимого бита плоскости m совпадает с арифметическим управляющим символом ″ARITHESCAPE″, значение уровня „lev″ увеличивается на единицу. Как уже упоминалось, алгоритм 312ba повторяется до тех пор, пока декодированное значение наиболее значимого бита плоскости m отличается от арифметического управляющего символа.
Как только декодирование наиболее значимого бита плоскости завершено, то есть значение наиболее значимого бита плоскости m, которое отличается от арифметического управляющего символа, декодировано, переменная спектрального значения ″а″ устанавливается равной значению самого значимого бита плоскости m. Впоследствии, получаются менее значимые биты плоскости, например, как показано на ссылке с номером 312 с на фиг.3. Для каждого менее значимого бита плоскости спектрального значения, одно из двух двоичных значений декодируется. Например, получается значение менее значимого бита плоскости r. Впоследствии, переменная спектрального значения ″а″ обновляется, сдвигая содержание переменной спектрального значения ″а″ влево на 1 бит и добавляя значение ранее декодированного менее значимого бита плоскости r как наименее значимого бита. Тем не менее, следует отметить, что концепция для получения значений менее значимых бит плоскостей не имеет особого значения для настоящего изобретения. В некоторых вариантах, декодирование любых менее значимых бит плоскостей может даже быть опущено. Кроме того, различные алгоритмы декодирования могут быть использованы для этой цели.
6.2 Порядок декодирования в соответствии с фиг.4
Далее будет описан порядок декодирования спектральных значений.
Спектральные коэффициенты бесшумно кодируются и передаются (например, в битовом потоке), начиная с самого низкочастотного коэффициента и переходя к самому высокочастотному коэффициенту.
Коэффициенты из перспективного звукового кодирования (ААС) (например, полученные с помощью модифицированного дискретного косинус преобразования, как описано в ISO/IEC 14496, часть 3, подчасть 4) хранятся в массиве ″x_ac_quant[g][win][sfb][bin]″, а порядок передачи кодового слова бесшумного кодирования (т.е. acod_m, acod_r) такой, что, когда они декодируются в порядке поступления и хранятся в массиве, ″bin″ (индекс частоты) является наиболее быстро увеличивающимся индексом и ″g″ является наиболее медленно увеличивающимся индексом.
Спектральные коэффициенты, связанные с более низкой частотой, кодируются перед спектральными коэффициентами, связанными с более высокой частотой.
Коэффициенты из преобразования кодированного возбуждения (ТСХ) хранятся непосредственно в массиве x_tcx_invquant[win][bin], а порядок передачи кодовых слов бесшумного кодирования такой, что, когда они декодируются в порядке поступления и хранятся в массиве, ″bin″ является наиболее быстро увеличивающимся индексом и ″win″ является наиболее медленно увеличивающимся индексом. Другими словами, если спектральные значения описывают преобразование кодированного возбуждения фильтра линейного предсказания кодера речи, спектральные значения а связаны со смежными и увеличивающимися частотами преобразование кодированного возбуждения.
Спектральные коэффициенты, связанные с более низкой частотой, кодируются перед спектральными коэффициентами, связанными с более высокой частотой.
Примечательно, что аудио декодер 200 может быть настроен на применение декодированного аудио представления в частотной области 232, которое обеспечивается арифметическим декодером 230, как для ″прямой″ генерации представления аудио сигнала во временной области с помощью преобразования сигнала из частотной области во временную область, так и для ″косвенного″ предоставления представления аудио сигнала, используя как декодер из частотной области во временную область, так и фильтр линейного предсказания, возбуждаемый выходом трансформера сигнала из частотной области во временную область.
Другими словами, арифметический декодер 200, функциональность которого обсуждается здесь в деталях, хорошо подходит для декодирования спектральных значений представления во временной и частотной области аудио содержания, кодированного в частотной области, и для обеспечения представления во временной и частотной области сигнала стимула для фильтра линейного предсказания, адаптированного для декодирования речевого сигнала, кодированного в области линейного предсказания. Таким образом, арифметический декодер хорошо подходит для использования в аудио декодере, способном работать как с аудио содержанием, кодированном в частотной области, так и с аудио содержанием, кодированном в линейно предсказанной частотной области (режим преобразования кодированного возбуждения области линейного предсказания).
6.3. Инициализация контекста в соответствии с фиг.5а и 5b
Далее будет описана инициализация контекста (также обозначается как ″отображение контекста″), которая выполняется в шаге 310.
Инициализация контекста включает сопоставление между прошлым контекстом и текущим контекстом в соответствии с алгоритмом ″arith_map_ context()″, который показан на фиг.5а. Как видно, текущий контекст хранится в глобальной переменной q[2][ncontext], которая принимает форму массива, имеющего первое измерение из двух и второе измерение из n_context. Прошлый контекст хранится в переменной qs[n_context], которая принимает форму таблицы, имеющей измерение из n_context. Переменная ″previouslg″ описывает количество спектральных значений прошлого контекста.
Переменная ″lg″ описывает количество спектральных коэффициентов для декодирования в кадре. Переменная ″previouslg″ описывает предыдущее количество спектральных линий предыдущего кадра.
Отображение контекста может быть выполнено в соответствии с алгоритмом ″arith_map_context()″. Следует отметить, что функция ″arith_map_context()″ устанавливает записи q[0][i] текущего массива контекста q в значения qs[i] предыдущего массива контекста qs, если количество спектральных значений, связанных с текущим (например, кодированном в частотной области) аудио кадром, совпадает с количеством спектральных значений, связанных с предыдущим аудио кадром для i=0 до i=lg-1.
Однако, более сложное отображение выполняется, если количество спектральных значений, связанных с текущим аудио кадром, отличается от количества спектральных значений, связанных с предыдущим аудио кадром. Однако подробности, касающиеся отображения в данном случае, не особенно важны для ключевой идеи настоящего изобретения, так что за более подробной информацией делается ссылка на псевдо программный код на фиг.5 а.
6.4 Вычисление значения состояния в соответствии с фиг.5b и 5 с
Далее вычисление значение состояния 312а будет описано более подробно.
Следует отметить, что первое значение состояния s (как показано на фиг.3) может быть получено в качестве возвращаемого значения функции ″arith_get_context(i, lg, arith_reset_fiag, N/2)″, представление псевдо программного кода, которое показано на фиг.5b и 5с.
Что касается вычисления значения состояния, делается также ссылка на фиг.4, которая показывает контекст, используемый для оценки состояния. Фиг.4 показывает двумерное представление спектральных значений как по времени, так и по частоте. Абсцисса 410 описывает время, а ордината 412 описывает частоту. Как видно на фиг.4, спектральное значение 420 для декодирования, связано с индексом времени t0 и индексом частоты i. Как видно, для индекса времени t0, кортежи, имеющие индексы частоты i-1, i-2 и i-3, уже декодированы в то время, когда спектральное значение 420 с индексом частоты i должно быть декодировано. Как видно из фиг.4, спектральное значение 430, имеющее индекс времени t0 и индекс частоты i-1, уже декодировано до того, как спектральное значение 420 декодировано, а спектральное значение 430 рассматривается для контекста, который используется для декодирования спектрального значения 420. Таким же образом, спектральное значение 434, имеющее индекс времени t0 и индекс частоты i-2, уже декодировано, до того как спектральное значение 420 декодируется, и спектральное значение 434 рассматривается для контекста, который используется для декодирования спектрального значения 420. Таким же образом, спектральное значение 440, имеющее индекс времени t-1 и индекс частоты i-2, спектральное значение 444, имеющее индекс времени t-1 и индекс частоты i-1, спектральное значение 448, имеющее индекс времени t-1 и индекс частоты i, спектральное значение 452, имеющее индекс времени t-1 и индекс частоты i+1, и спектральное значение 456, имеющее индекс времени t-1 и индекс частоты i+2 уже декодированы, до того как спектральное значение 420 декодируется, и рассматриваются для определения контекста, который используется для декодирования спектрального значения 420. Спектральные значения (коэффициенты), уже декодированные в то время, когда спектральное значение 420 декодируется и рассматривается для контекста, показаны в заштрихованных квадратах. В отличие от этого, некоторые другие спектральные значения, уже декодированные (в то время, когда спектральное значение 420 декодируется), которые представлены квадратами с пунктирными линиями, а также другие спектральные значения, которые до сих пор не декодированы (в то время, когда спектральное значение 420 декодируется) и которые показаны кружками с пунктирными линиями, которые не используются для определения контекста для декодирования спектрального значения 420.
Тем не менее, следует отметить, что некоторые из этих спектральных значений, которые не используются для ″обычного″ (или ″нормального″) вычисления контекста для декодирования спектрального значения 420, могут, тем не менее, быть оцененными для выявления множества ранее декодированных смежных спектральных значений, которые выполняют, по отдельности или вместе взятые, заданное условие относительно их величины.
Обратимся к фиг.5b и 5с, которые показывают функциональность функции ″arith_get_context()″ в виде псевдо программного кода, больше подробностей относительно расчета первого значения контекста ″s″, который осуществляется с помощью функции ″arith_get_context()″, будут описаны.
Следует отметить, что функция ″arith_get_context()″ получает, в качестве входных переменных индекс i спектрального значения для декодирования. Индекс i, как правило, является индексом частоты. Входная переменная lg описывает (общее) количество ожидаемых квантованных коэффициентов (для текущего аудио кадра). Переменная N описывает количество линий преобразования. Флаг ″arith_reset_flag″ указывает должен ли контекст быть сброшен. Функция ″arith_get_context″ предоставляет, в качестве выходного значения, переменную ″t″, которая представляет собой сцепленный индекс состояния s и предсказанный уровень бита плоскости lev0.
Функция ″arith_get_context()″ использует целочисленные переменные а0, с0, c1, с2, с3, с4, с5, с6, lev0, и «область».
Функция ″arith_get_context()″ содержит в качестве основных функциональных блоков, обработку первого арифметического сброса 510, обнаружение 512 группы из множества ранее декодированных смежных нулевых спектральных значений, установку первой переменной 514, установку второй переменной 516, адаптацию уровня 518, установку значения области 520, адаптацию уровня 522, ограничение уровня 524, обработку арифметического сброса 526, установку третьей переменной 528, установку четвертой переменной 530, установку пятой переменной 532, адаптацию уровня 534, и селективное вычисление возвращаемого значения 536.
При обработке первого арифметического сброса 510 проверяется, установлен ли флаг арифметического сброса ″arith_reset_flag″, когда индекс спектрального значения для декодирования равен нулю. В этом случае нулевое значение контекста возвращается, а функция прерывается.
При обнаружении 512 группы из множества ранее декодированных нулевых спектральных значений, которое производится, только если флаг арифметического сброса неактивен, а индекс i спектрального значение для декодирования отличается от нуля, переменная с именем ″flag″ устанавливается в 1, как показано на ссылке с номером 512а, и область спектрального значения, которое оценивается, определяется как показано на ссылке с номером 512b. Впоследствии область спектральных значений, которая определяется, как показано на ссылке с номером 512b, оценивается, как показано на ссылке с номером 512 с.Если установлено, что имеется достаточная область ранее декодированных нулевых спектральных значений, значение контекста 1 возвращается, как показано на ссылке с номером 512d. Например, верхняя граница индекса частоты ″lim_max″ устанавливается в положение i+6, если индекс i спектрального значения для декодирования не близок к максимальному индексу частоты lg-1, и в этом случае специальная установка верхней границы индекса частоты производится, как показано на ссылке с номером 512b. Кроме того, нижняя граница индекса частоты ″lim_min″ устанавливается в положение -5, если индекс i спектрального значения для декодирования не близок к нулю (i+lim_min<0), и в этом случае специальное вычисление нижней границы индекса частоты lim_min производится, как показано на ссылке с номером 512b. При оценке области спектральных значений, определенных в шаге 512b, оценка сначала исполнена для отрицательных индексов частоты к между нижней границей индекса частоты lim_nin и нулем. Для индексов частоты к между lim_min и нулем проверяется, равен ли хотя бы один из значений контекста q[0][k].c и q[l][k].c нулю. Если, однако, оба значения контекста q[0][k].c и q[l][k].c отличны от нуля для любых индексов частоты к между lim_min и нулем, можно сделать вывод, что нет достаточной группы нулевых спектральных значений, и оценка 512с прерывается. Далее значения контекста q[0][k].c для индексов частоты между нулем и lim_max оцениваются. Если обнаруживается, что любые из значений контекста q[0][k].c для любых индексов частоты между нулем и lim_max отличаются от нуля, можно сделать вывод, что нет достаточной группы ранее декодированных нулевых спектральных значений, и оценка 512с прерывается. Однако, если будет установлено, что для каждого индекса частоты к между lim_min и нулем, то есть по крайней мере одно значение контекста q[0][k].c или q[l][k].c, которое равно нулю, и если есть нулевое значение контекста q[0][k].c для каждого индекса частоты к между нулем и lim_max, можно сделать вывод, что есть достаточная группа ранее декодированных нулевых спектральных значений. Таким образом, значение контекста 1 возвращается в этом случае, чтобы указать на это условие, без каких-либо дополнительных расчетов. Другими словами, расчеты 514, 516, 518, 520, 522, 524, 526, 528, 530, 532, 534, 536 пропускаются, если достаточная группа множества значений контекста q[0][k].c, q[l][k].c, имеющих нулевое значение, выявлена. Другими словами, возвращаемое значение контекста, которое описывает состояние контекста (s), определяется независимо от ранее декодированных спектральных значений в ответ на обнаружение, что заданное условие выполнено.
В противном случае, т.е. если нет достаточной группы значений контекста [q][0][k].c, [q][l][k].c, которые равны нулю, по крайней мере некоторые из вычислений 514, 516, 518, 520, 522, 524 526, 528, 530, 532, 534, 536, выполняются.
При установке первой переменной 514, которая избирательно выполняется, если (и только если) индекс i спектрального значения для декодирования меньше 1, то переменная а0 инициализируется для принятия значения контекста q[l][i-l], а переменная с0 инициализируется для принятия абсолютного значения переменной а0. Переменная ″lev0″ инициализируется для принятия значения нуля. Впоследствии переменные ″lev0″ и с0 увеличиваются, если переменная а0 содержит сравнительно большое абсолютное значение, т.е. меньше, чем -4, или больше или равно 4. Увеличение переменных ″lev0″ и с0 выполняется итеративно, пока значение переменной а0 приводится в диапазон между - 4 и 3 путем операции сдвига направо (шаг 514b).
Впоследствии переменные с0 и ″lev0″ ограничиваются максимальными значениями 7 и 3 соответственно (шаг 514с).
Если индекс i спектрального значения для декодирования равен 1, а флаг арифметического сброса (″arith_reset_flag″) является активным, значение контекста возвращается, которое рассчитывается лишь на основе переменных с0 и lev0 (шаг 514d). Таким образом, только одно ранее декодированное спектральное значение, имеющее один и тот же индекс времени как спектральное значение для декодирования, и имеющее индекс частоты, который меньше, на 1, чем индекс частоты i спектрального значения для декодирования, рассматривается для вычисления контекста (шаг 514d). В противном случае, т.е. если нет функциональности арифметического сброса, переменная с4 инициализируется (шаг 514е).
В заключение, установка первой переменной 514, переменных с0 и ″lev0″ инициализируются в зависимости от ранее декодированных спектральных значений, декодированных за тот же кадр, как и спектральное значение для текущего декодирования и для предыдущей спектральной ячейки i-1. Переменная с4 инициализируется в зависимости от ранее декодированного спектрального значения, декодированного из предыдущего аудио кадра (имеющего индекс времени t-1) и имеющего частоту, которая ниже (например, на одну ячейку частоты), чем частота, связанная с спектральным значением для текущего декодирования.
Установка второй переменной 516, которая избирательно выполняется, если (и только если) индекс частоты спектрального значения для текущего декодирования больше 1, включает в себя инициализацию переменных c1 и с6 и обновление переменной lev0. Переменная c1 обновляется в зависимости от значения контекста q[l][i-2].c, связанного с ранее декодированным спектральным значением текущего аудио кадра, частота которого меньше (например, на две ячейки частоты), чем частота спектрального значения для текущего декодирования. Кроме того, переменная с6 инициализируется в зависимости от значения контекста q[0][i-2].c, которое описывает ранее декодированное спектральное значение предыдущего кадра (имеющего индекс времени t-1), связанная частота которого меньше (например, две ячейки частоты), чем частота, связанная со спектральным значение для текущего декодирования. Кроме того, переменная уровня ″lev0″ устанавливается на значение уровня q[l][i-2].l, связанное с ранее декодированным спектральным значением текущего кадра, связанная частота которого меньше (например, на две ячейки частоты), чем частота, связанная со спектральным значением для текущего декодирования, если q[l][i-2].1 больше, чем lev0.
Адаптация уровня 518 и установка значения области 520 выборочно выполняются, если (и только если) индекс i спектрального значения для декодирования больше, чем 2. При адаптации уровня 518, переменная уровня ″lev0″ увеличивается на значение q[l][i-3].1, если значение уровня q[l][i-3].1, связанное с ранее декодированным спектральным значением текущего кадра, связанная частота которого меньше (например, на три ячейки частоты), чем частота, связанная со спектральным значением для текущего декодирования, больше, чем значение уровня lev0.
При установке значения области 520 переменная «область» устанавливается в зависимости от оценки, в которой спектральной области, из множества спектральных областей, спектральное значения для текущего декодирования получается. Например, если установлено, что спектральное значение для текущего декодирования связано с ячейкой частоты (имеющей индекс ячейки частоты i), которая есть в первой (самой нижней) четверти ячеек частоты (0≤i<N / 4), переменная области «область» равна нулю. В противном случае, если спектральное значение для текущего декодирования связано с ячейкой частоты, которая во второй четверти ячеек частоты, связанное с текущим кадром (N / 4≤i<N / 2), переменная области устанавливается в значение 1. В противном случае, если спектральное значение для текущего декодирования связано с ячейкой частоты, которая во второй (верхней) половиной ячеек частоты (N / 2≤i<N), переменная области устанавливается в значение 2. Таким образом, переменная области устанавливается в зависимости от оценки, с какой частотной областью спектральное значение для текущего декодирования связано. Можно выделить две или более частотных областей.
Дополнительная адаптация уровня 522 выполняется, если (и только если) спектральное значение для текущего декодирования включает в себя спектральный индекс, который больше, чем 3. В этом случае переменная уровня ″lev0″ увеличивается (устанавливается на значение q[l][i-4].1), если значение уровня q[i][i-4].1, связанное с ранее декодированным спектральным значением текущего кадра, который связан с частотой, которая меньше, например, на четыре ячейки частоты, чем частота, связанная со спектральным значением для текущего декодирования, больше, чем текущий уровень ″lev0″ (шаг 522). Переменная уровня ″lev0″ ограничивается максимальным значением 3 (шаг 524).
Если условие арифметического сброса обнаруживается и индекс i спектрального значения для текущего декодирования больше, чем 1, значение состояния возвращается в зависимости от переменных с0, c1, lev0, а также в зависимости от переменной области ″область″ (шаг 526). Таким образом, ранее декодированные спектральные значения любого предыдущего кадра остаются без внимания, если условие арифметического сброса дается.
В установке третьей переменной 528 переменная с2 устанавливается в значение контекста q[0][i].c, которое связано с ранее декодированным спектральным значением предыдущего аудио кадра (имеющего индекс времени t-1), которое ранее декодированное спектральное значение связано с той же частотой как и спектральное значение для текущего декодирования.
В установке четвертой переменной 530 переменная с3 устанавливается в значение контекста q[0][i+l].c, которое связано с ранее декодированным спектральным значением предыдущего аудио кадра, имеющего индекс частоты i+1, если спектральное значение для текущего декодирования не связано с самым большим возможным индексом частоты lg-1.
В установке пятой переменной 532 переменная с5 устанавливается в значение контекста q[0][i+2].c, которое связано с ранее декодированным спектральным значением предыдущего аудио кадра, имеющего индекс частоты i+2, если индекс частоты i спектрального значения для текущего декодирования не слишком близко к максимальному значению индекса частоты (т.е. имеет значение индекса частоты lg-2 или lg-1).
Дополнительная адаптация переменной уровня ″lev0″ выполняется, если индекс частоты i равен нулю (т.е. если спектральное значение для текущего декодирования является самым нижним спектральным значением). В этом случае переменная уровня ″lev0″ увеличивается от нуля до 1, если переменная с2 или с3 имеет значение 3, что указывает на то, что ранее декодированное спектральное значение предыдущего аудио кадра, который связан с той же частотой или даже с более высокой частотой по сравнению с частотой, связанной со спектральным значением для текущего кодирования, имеет сравнительно большое значение.
В выборочном вычислении возвращаемого значения 536 возвращаемое значение вычисляется в зависимости от того, имеет ли индекс i спектрального значения для текущего декодирования значение нуль, 1 или большее значение. Возвращаемое значение вычисляется в зависимости от переменных с2, с3, с5 и lev0, как указано в ссылке с номером 536а, если индекс i принимает значения нуль. Возвращаемое значение вычисляется в зависимости от переменных с0, с2, с3, с4, с5, и ″lev0″, как показано на ссылке с номером 536b, если индекс i принимает значение 1. Возвращаемое значение вычисляется в зависимости от переменных с0, с2, с3, с4, с5, с6, ″область″ и ″lev0″, если индекс i принимает значение, которое отличается от нуля или 1 (ссылка с номером 536 с).
Подводя итог сказанному выше, вычисление значения контекста ″arith_get_context()″ включает в себя обнаружение 512 группы множества ранее декодированных нулевых спектральных значений (или, по крайней мере, достаточно малых спектральных значений). Если обнаружена достаточная группа ранее декодированных нулевых спектральных значений, наличие специального контекста указывается путем установки возвращаемого значения в 1. В противном случае, производится вычисление значения контекста. В целом можно сказать, что при вычислении значения контекста значение индекса i оценивается для того, чтобы решить, сколько ранее декодированных спектральных значений должно быть оценено. Например, количество оцененных ранее декодированных спектральных значений уменьшается, если индекс частоты i спектрального значения для текущего декодирования близок к нижней границе (например, нулю), или близок к верхней границе (например, lg-1). Кроме того, даже если индекс частоты i спектрального значения для текущего декодирования достаточно далек от минимального значения, разные спектральные области выделяются установкой значения области 520. Соответственно, различные статистические свойства различных спектральных областей (например, во-первых, низкочастотная спектральная область, во-вторых, среднечастотная спектральная область, и, в-третьих, высокочастотная спектральная область) принимаются во внимание. Значение контекста, которое рассчитывается в качестве возвращаемого значения, зависит от переменной «область», такой, что возвращаемое значение контекста зависит от того, находится ли спектральное значение для текущего декодирования в первой заданной частотной области или во второй заданной частотной области (или в любой другой заданной частотной области).
6.5 Выбор правила отображения
Далее будет описан выбор правила отображения, например, сводной таблицы частот, которая описывает отображение значения кода на код символа. Выбор правила отображения производится в зависимости от состояния контекста, который описывается значением состояния s или t
6.5.1 Выбор правила отображения с помощью алгоритма в соответствии с Фиг.5е
Далее описывается выбор правила отображения с помощью функции ″get_pk″ в соответствии с фиг.5d. Следует отметить, что функция ″get_pk″ может быть выполнена, чтобы получить значение ″ pki ″ в суб-алгоритме 312ba алгоритма на фиг.3. Таким образом, функция ″get_pk″ может заменить функцию ″arith_get_pk″ в алгоритме на фиг.3.
Следует также отметить, что функция ″get_pk″ в соответствии с фиг.5d может оценить таблицу ″ari_s_hash [387]″ в соответствии с фиг.17 (1) и 17 (2) и таблицу ″ari_gs_hash″ [225] в соответствии с фиг.18.
Функция ″get_pk″ получает, в качестве входной переменной, значение состояния s, которое может быть получено путем сочетания переменной ″t″ в соответствии с фиг.3 и переменных ″lev″, ″lev0″ в соответствии с фиг.3. Функция ″get_pk″ также в качестве возвращаемого значения может вернуть значение переменной ″ pki ″, которая характеризует правило отображения или сводную таблицу частот. Функция ″get_pk″ настроена отобразить значение состояния s на значение индекса правила отображения ″pki″.
Функция ″get_pk″ включает в себя первую оценочную таблицу 540 и вторую оценочную таблицу 544. Первая оценочная таблица 540 включает в себя инициализацию переменной 541, в которой инициализируются переменные i_min, i_max, и i, как показано на ссылке с номером 541. Первая оценочная таблица 540 также включает в себя итеративный поиск в таблице 542, в ходе которого определяется, есть ли запись в таблице ″arishash″, которая соответствует значению состояния s. Если такое совпадение выявляется в ходе поиска итерационной таблицы 542, функция get_pk прерывается, при этом возвращаемое значение функции определяется записью таблицы ″arishash″, которая соответствует значению состояния s, что будет описано более подробно далее. Если, однако, в ходе итерационного поиска таблицы 542 не выявляется идеальное соответствие значения состояния s и записи таблицы ″ari_s_hash″, выполняется проверка граничной записи 543.
Обратимся теперь к деталям первой оценочной таблицы 540, видно, что интервал поиска определяется переменными i_min и i_max. Итеративный поиск таблицы 542 повторяется до тех пор, пока интервал, определенный переменными i_min и i_max, достаточно велик, что может быть истинным, если условие i_max-i_min> 1 выполняется. Впоследствии устанавливается переменная i, по крайней мере приблизительно, для обозначения середины интервала (i=i_min+(i_max-i_min)/2). Далее устанавливается переменная j на значение, которое определяется массивом ″ari_s_hash″ в. положении массива, обозначенном переменной i (ссылка с номером 542). Здесь следует отметить, что каждая запись в таблице ″ari_s_hash″ описывает как значение состояния, которое связано с записью таблицы, так и значение индекса правила отображения, которое связано с записью таблицы. Значение состояния, которое связано с записью таблицы, описывается более значимыми битами (8-31 биты) записи таблицы, в то время как значения индекса правила отображения характеризуются нижними битами (например, биты 0-7) записи указанной таблицы. Нижняя граница i_min или верхняя граница i_max адаптированы в зависимости от того, если значение состояния s меньше, чем значение состояния, описываемое наиболее значимыми 24 битами записи ″ari_s_hash[i]″ таблицы ″ari s hash″, которая ссылается на переменную i. Например, если значение состояния s меньше, чем значение состояния, описанное более значимыми 24 битами записи ″arishash [i]″, верхняя граница i_max интервала таблицы устанавливается в значение i. Соответственно, интервал таблицы для следующей итерации итеративного поиска таблицы 542 ограничен нижней половиной интервала таблицы (от i_min в i_max), используемой для текущей итерации итеративного поиска таблицы 542. Если, напротив, значение состояния s больше значений состояния, описываемого более значимыми 24 битами записи таблицы ″arishash [i]″, то нижняя граница i_min интервала таблицы для следующей итерации итеративного поиска таблицы 542 устанавливается в значение i, так что верхняя половина текущего интервала таблицы (между i_min и i_max) используется в качестве интервала таблицы для следующего итеративного поиска таблицы. Однако, если будет установлено, что значение состояния s идентично значению состояния, описанному наиболее значимыми 24 битами записи таблицы ″ari_s_hash [i]″, значение индекса правила отображения, описываемое менее значимыми 8 битами записи таблицы ″ari_s_hash [i]″, возвращается функцией ″get_pk″, а функция отменяется.
Итеративный поиск таблицы 542 повторяется, пока интервал таблицы, определяемый переменными i_min и i_max, становится достаточно малым.
Проверка граничной записи 543 (дополнительно) выполняется в дополнение к итеративному поиску таблицы 542. Если индексная переменная i равна индексной переменной i_max после завершения итеративного поиска таблицы 542, окончательная проверка производится, является ли значение состояния s равным значению состояния, описываемому более значимыми 24 битами записи таблицы ″ari_s_hash [i_min] ″, и значение индекса правила отображения, описываемое менее значимыми 8 битами записи ″ari_s_hash [i_min]″ возвращается, в этом случае, как результат функции ″get_pk ″. С другой стороны, если индексная переменная i отличается от индексной переменной i_max, то выполняется проверка, является ли значение состояния s равным значению состояния, описываемому более значимыми 24 битами записи таблицы ″arishash [i_max]″, и значение индекса правила отображения, описываемое менее значимыми 8 битами записи указанной таблицы ″ari_s_hash [i_max]″, возвращается в виде возвращаемого значения функции″ get_pk ″в данном случае.
Тем не менее, следует отметить, что проверка граничной записи 543 может рассматриваться как дополнительная в полном объеме.
После первой оценочной таблицы 540 выполняется вторая оценочная таблица 544, если не произошло ″прямое попадание″ во время первой оценочной таблицы 540, в которой значение состояния s совпадает с одним из значений состояния, описываемых записями таблицы ″ari_s_hash″ (или, точнее, более значимыми 24 битами).
Вторая оценочная таблица 544 включает в себя инициализацию переменной 545, в которой индексные переменные i_min, i и i_max инициализируются, как показано на ссылке с номером 545. Вторая оценочная таблица 544 также включает в себя итеративный поиск таблицы 546, в ходе которого в таблице ″ari_gs_hash″ ищется запись, которая представляет собой значение состояния, идентичное значению состояния s. Наконец, вторая таблица поиска 544 включает в себя определение возвращаемого значения 547.
Итеративный поиск таблицы 546 повторяется до тех пор, пока интервал таблицы, определяемый индексными переменными i_min и i_max, является достаточно высоким (например, до тех пор, пока i_max - i_min> 1). В процессе итерации итеративного поиска таблицы 546 переменная i устанавливается к центру интервала таблицы, определяемому i_min и i_max (шаг 546а). Впоследствии запись j таблицы ″ari_gs_hash″ выполняется в части таблицы, определяемой по индексной переменной i (546b). Другими словами, запись таблицы ″ari_gs_hash [i]″ является записью таблице в центре текущего интервала таблицы, определяемого индексами таблицы i_min и i_max. Далее определяется интервал таблицы для следующей итерации итеративного поиска таблицы 546. Для этой цели значение индекса imax, описывающее верхнюю границу интервала таблицы, устанавливается в значение i, если значение состояния s меньше, чем значение состояния, описываемое более значимыми 24 битами записи таблицы ″j = ari_gs_hash [i] ″(546с). Другими словами, нижняя половина текущего интервала таблицы выбирается в качестве нового интервала таблицы для следующей итерации итеративного поиска таблицы 546 (шаг 546с). В противном случае, если значение состояния s больше, чем значение состояния, описываемое более значимыми 24 битами записи таблицы ″j = ari_gs_hash [i]″, значение индекса ijnin устанавливается в значение i. Таким образом, верхняя половина текущего интервала таблицы выбирается в качестве нового интервала таблицы для следующей итерации итеративного поиска таблицы 546 (шаг 546d). Однако, если будет установлено, что значение состояния s совпадает с значением состояния, описываемым более значимыми 24 битами записи таблицы ″j = ari_gs_hash [i]″, индексная переменная i_max устанавливается в значение i+1 или в значение 224 (если i+1 больше, чем 224), и итеративный поиск таблицы 546 отменяется. Однако, если значение состояния s отличается от значения состояния, описываемого более значимыми 24 битами таблицы ″j = ari_gs_hash [i]″, итеративный поиск таблицы 546 повторяется с вновь установленным интервалом таблицы, определяемым обновленными значениями индекса i_min и i_max, пока интервал таблицы не будет слишком мал (i_max - i_min ≤ 1). Таким образом, длительность интервала таблицы (определяемого i_min и i_max) итеративно уменьшается, пока ″прямое попадание″ не будет обнаружено (s==(j>>8)), или интервал достигнет минимально допустимую длительность (i_max - i_min ≤ 1). Наконец, после прекращения итеративного поиска таблицы 546 определяется запись таблицы ″j = ari_gs_hash [i_max]″ и значение индекса правила отображения, описываемое менее значимыми 8 битами записи указанной таблицы ″j = ari_gs_hash [i_max]″, возвращается в качестве возвращаемого значения функции ″get_pk ″. Таким образом, значение индекса правила отображения определяется в зависимости от верхней границы i_max интервала таблицы (определяемого i_min и i_max) после завершения или отмены итеративного поиска таблицы 546.
Описанные выше оценочные таблицы 540, 544, которые обе используют итеративный поиск таблиц 542, 546, позволяют проверить таблицы ″ari_s_hash″ и ″ari_gs_hash″ на наличие данного значимого состояния с очень высокой вычислительной эффективностью. В частности, количество операций доступа к таблице может оставаться умеренно небольшим даже в худшем случае. Было установлено, что числовая упорядоченность таблицы ″ari_s_hash″ и ″ari_gs_hash″ позволяет ускорить поиск соответствующего хэш-значения. Кроме того, размер таблицы может оставаться небольшим, так как включение управляющих символов в таблицах ″arishash″ и ″ari_gs_hash″ не требуется. Таким образом, устанавливается эффективный механизм контекстного хэширования, хотя существует большое количество различных состояний: На первом этапе (первая оценочная таблица 540) ведется поиск прямого попадания (s==j>>8)).
На втором этапе (вторая оценочная таблица 544) диапазоны значения состояния s можно отобразить на значения индекса правила отображения. Таким образом, может выполняться хорошо отрегулированная обработка особенно значимых состояний, для которых существует соответствующая запись в таблице ″ari_s_hash″, и менее значимых состояний, для которых существует поэтапная обработка. Таким образом, функция ″get_pk″ представляет собой эффективное выполнение выбора правила отображения.
За более подробной информацией сделана ссылка на псевдо программный код на фиг.5d, который показывает функциональность функции ″get_pk″ в представлении в соответствии с известным языком программирования С.
6.5.2 Выбор правила отображения с помощью алгоритма в соответствии с Фиг.5е
Далее будет описан другой алгоритм для выбора правила отображения, показанный на фиг.5е. Следует отметить, что алгоритм ″arith_get_pk″ на фиг.5е получает, в качестве входной переменной, значение состояния s, описывающее состояния контекста. Функция ″arith_get_pk» предоставляет, в качестве выходного значения, или возвращаемого значения, индекс ″pki″ вероятностной модели, которая может быть индексом для выбора правила отображения (например, сводная таблица частот).
Следует отметить, что функция ″arith_get_pk″ на фиг.5е может заменить функциональность функции ″arith_get_pk″ функции ″value_decode″ на фиг.3.
Следует также отметить, что функция ″arith_get_pk″ может, например, оценить таблицу ari_s_hash в соответствии с фиг.20 и таблицу ari_gs_hash в соответствии с на фиг.18.
Функция ″arith_get_pk″ на фиг.5е состоит из первой оценочной таблицы 550 и второй оценочной таблицы 560. В первой оценочной таблице 550 проводится линейное сканирование с помощью таблицы arishash, чтобы получить запись j=ari_s_hash [i] указанной таблицы. Если значение состояния, описываемое более значимыми 24 битами записи таблицы j=ari_s_hash[i] таблицы ari_s_hash, равно значению состояния s, значение индекса правила отображения „pki″, описываемое менее значимыми 8 битами указанной выявленной таблицы, запись j=ari_s_hash[i] возвращается, и функция ″arith_get_pk″ отменяется. Соответственно, все 387 записи в таблице ari_s_hash оцениваются в возрастающем порядке, пока не идентифицируется ″прямое попадание″ (значение состояния s, равное значению состояния, описанному более значимыми 24 битами записи таблицы]).
Если прямое попадание не идентифицируется в первой оценочной таблице 550, выполняется вторая оценочная таблица 560. В ходе второй оценочной таблицы выполняется линейное сканирование с индексами записи i, увеличивающееся линейно от 0 до максимального значения 224. Во второй оценочной таблице запись ″ari_gs_hash [i]″ таблицы ″ari_gs_hash″ для таблицы i прочитывается, и запись таблицы ″j=ari_gs_hash[i]″ оценивается таким образом, что определяется является ли значение состояния, определяемое более значимыми 24 битами записи таблицы j, большим, чем значение состояния s. В этом случае значение индекса правила отображения, описанное менее значимыми 8 битами записи указанной таблицы j, возвращается в качестве возвращаемого значения функции ″arith_get_pk″, а выполнение функции ″arith_get_pk″ отменяется. Если, однако, значение состояния s не меньше значения состояния, описанного более значимым числом 24 бит текущей записи таблицы j=ari_gs_hash[i], сканирование записей таблицы ari_gs_hash продолжается, увеличивая индекс таблицы i. Если, однако, значение состояния s больше или равно любому из значений состояния, описанных записями таблицы ari_gs_hash, значение индекса правила отображения „pki″, определенное менее значимыми 8 битами последней записи таблицы arigshash, возвращается в качестве возвращаемого значения функции ″arith_get_pk″.
Итак, функция ″arith_get_pk″ соответственно фиг.5е выполняет двушаговое хэширование. На первом этапе выполняется поиск прямого попадания, при этом определяется равно ли значение состояния s значению состояния, определенному любыми записями первой таблицы ″ari_s_hash″. Если прямое попадание идентифицируется в первой оценочной таблице 550, возвращаемое значение получается из первой таблицы ″ari_s_hash″, и функция ″arith_get_pk″ отменяется. Однако, если прямое попадание не идентифицировано в первой оценочной таблице 550, выполняется вторая оценочная таблица 560. Во второй оценочной таблице выполняется оценка диапазона. Последующие записи второй таблицы ″ari_gs_hash″ определяют диапазоны. Если будет установлено, что значение состояния s лежит в пределах такого диапазона (о чем свидетельствует тот факт, что значение состояния, описанное более значимыми 24 битами текущей записи таблицы ″j=ari_gs_hash[i]″, больше значения состояния s, значение индекса правила отображения ″pki″, описанное менее значимыми 8 битами записи таблицы j=ari_gs_hash[i] возвращается.
6.5.3 Выбор правила отображения с помощью алгоритма в соответствии с Фиг.5f
Функция ″get_pk″ на фиг.5f в основном эквивалентна функции ″arith_get_pk″ на фиг.5е. Поэтому сделана ссылка на вышеизложенное пояснение. Для более детальной информации сделана ссылка на псевдо программное представление на фиг.5f.
Следует отметить, что функция ″get_pk″ на фиг.5f может заменить функцию ″arith_get_pk″, вызванную в функции ″value_decode″ на фиг.3.
6.6. Функция ″arith_decode ()″ на фиг.5g
Далее будет подробно объяснена функциональность функции ″arith_decode ()″ в соответствии с фиг.5g. Следует отметить, что функция ″arith_decode ()″ использует вспомогательную функцию ″arith_first_symbol (void)″, которая возвращает TRUE, если это первый символ последовательности и FALSE, если не первый. Функция ″arith_decode ()″ также использует вспомогательную функцию ″arith_get_next_bit (void)″, которая получает и предоставляет следующий бит битового потока.
Кроме того, функция ″arith_decode ()″ использует глобальные переменные ″low″, ″high″ и ″value″. Кроме того, функция ″arith_decode ()″ получает в качестве входной переменной, переменную ″cum_freq []″, которая указывает на первую запись или элемент (имеющий индекс элемента или индекс записи 0) выбранной сводной таблицы частоты. Кроме того, функция ″arith_decode ()″ использует входную переменную ″cfl″, которая указывает на длину выбранной сводной таблицы частот, обозначенной переменной ″cum_freq []″.
Функция ″arithdecode ()″ включает в себя в качестве первого этапа инициализацию переменной 570а, которая выполняется, если вспомогательная функция ″arith_first_symbol ()″ показывает, что первый символ последовательности символов декодируется. Инициализация значения 550а инициализирует переменную ″value″ в зависимости от множества, например, 20 бит, которые получаются из битового потока, используя вспомогательную функцию ″arith_get_next_bit″, так, что переменная ″value″ имеет значение, представленное указанным числом бит. Кроме того, переменная ″low″ инициализируется, чтобы принять значение 0, а переменная ″high″ инициализируется, чтобы принять значение 1048575.
На втором этапе 570b переменная ″ range″ устанавливается в значение, которое больше на 1, чем разница между значениями переменных ″high″ и ″low″. Переменная ″cum″ устанавливается в значение, которое представляет собой относительное положение значения переменной ″value″ между значением переменной ″low″ и значением переменной ″high″. Таким образом, например, переменная ″cum″ принимает значение от 0 до 216 в зависимости от значения переменной ″value″.
Указатель р инициализируется в значение, которое меньше на 1, чем начальный адрес выбранной сводной таблицы частот.
Алгоритм ″arith_decode ()″ также включает в себя итеративный поиск сводной таблицы частот 570с. Итеративный поиск сводной таблицы частот повторяется, пока переменная cfl меньше или равна 1. В итеративном поиске сводной таблицы частот 570с указатель переменной q устанавливается в значение, равное сумме текущего значения указателя переменной р и половине значения переменной ″cfl″. Если значение записи *q выбранной сводной таблицы частот, запись которой адресована указателем переменной q, больше, чем значение переменной ″cum", указатель переменной р устанавливается в значение указателя переменной q, и переменная ″cfl″ увеличивается. Наконец, переменная ″cfl″ смещается вправо на один бит, тем самым фактически разделяя значение переменной ″cfl″ на 2 и пренебрегая частью модуля.
Таким образом, итеративный поиск сводной таблицы частот 570 с фактически сравнивает значение переменной ″cum″ и множество записей выбранной сводной таблицы частот, чтобы определить интервал выбранной сводной таблицы частот, который ограничен записями сводной таблицы частот, так что значение cum находится в пределах выявленного интервала. Соответственно, записи выбранной сводной таблицы частот определяют интервалы, в которых соответствующие значения символа связанны с каждым из интервалов выбранной сводной таблицы частот. Кроме того, ширины интервалов между двумя смежными значениями сводной таблицы частот определяет вероятности символов, связанных с указанными интервалами, так что выбранная сводная таблица частот в целом определяет вероятность распределения разных символов (или значений символов). Подробнее о доступных сводных таблицах частот будет рассказано ниже, см. на фиг.19.
Возвращаясь к фиг.5g, значение символа получено из значения переменной указателя р, в котором значение символа извлекается как показано на фиг.570d. Таким образом, разница между значением переменной указателя р и начальным адресом ″cum_freq″ оценивается для того, чтобы получить значение символа, которое представлено переменной ″symbol″.
Алгоритм ″arith_decode″ также включает в себя адаптацию 570е переменных ″high″ и ″low″. Если значение символа представлено переменной ″symbol″ отличается от 0, переменная ″high″ обновляется, как показано на фиг.570е. Кроме того, значение переменной ″low″ обновляется, как показано на ссылке с номером 570е. Переменная ″high″ устанавливается в значение, которое определяется значением переменной ″low″, переменная ″range″ и запись с индексом ″symbol -1″ выбранной сводной таблицы частот. Переменная ″low″ увеличивается, причем величина роста определяется переменной ″range″ и записью выбранной сводной таблицы частот с индексом ″symbol″. Соответственно, разница между значениями переменных ″low″ и ″high″ регулируется в зависимости от числовой разницы между двумя смежными записями выбранной сводной таблицы частот.
Соответственно, если значение символа, имеющее низкую вероятность, обнаружено, интервал между значениями переменных ″low″ и ″high″ сводится к малой ширине. Напротив, если обнаруженное значение символа содержит сравнительно большую вероятность, ширина интервала между значениями переменных ″low″ и ″high″ устанавливается в сравнительно большое значение. Опять ширина интервала между значениями переменных ″low″ и ″high″ зависит от обнаруженного символа и соответствующих записей сводной таблицы частот.
Алгоритм ″arith_decode ()″ также включает перенормировка интервала 570f, в котором интервал, определенный на шаге 570е, итеративно изменяется и масштабируется, пока условие ″break″ не будет достигнуто. В перенормировке интервала 570f выполняется выборочная операция 570fa сдвига вниз. Если переменная ″high″ меньше, чем 524286, ничего не делается, а перенормировка интервала продолжает операцию увеличения размера интервала 570fb. Однако, если переменная ″high″ не меньше 524 286, а переменная ″low″ больше или равна 524 286, переменные ″values″, ″low″ и ″high″ сокращаются на 524 286, так что интервал, определенный переменными ″low″ and ″high″, смещается вниз, и так, что значение переменной ″value″ также сдвигается вниз. Однако, если будет установлено, что значение переменной high″ не меньше 524 286, а также, что переменная ″low″ не превышает или равна 524 286, а также, что переменная ″low″ больше или равна 262 143 и, что переменная ″high″ меньше, чем 786 429, переменные ″value″, ″low″ и ″high″ сокращаются 262 143, таким образом, смещая вниз интервал между значениями переменных ″high″ и ″low″, а также значение переменной ″value″. Если, однако, ни одно из указанных выше условий не выполняется, перенормировка интервала отменяется.
Однако, если любое из вышеуказанных условий, которые оцениваются в шаге 570fa, выполняется, операция увеличения интервала 570fb выполняется. В операции увеличения интервала 570fb значение переменной ″low″ удваивается. Кроме того, значение переменной ″high″ удваивается, и результат удвоения увеличивается на 1. Кроме того, удваивается значение переменной ″yalue″ (сдвигается влево на один бит), и бит битового потока, который получен вспомогательной функцией ″arith_get_next_bit″, используется как наименее значимый бит. Соответственно, размер интервала между значениями переменных ″low″ и ″high″ приблизительно удваивается, и точность переменной ″value″ увеличивается за счет нового бита битового потока. Как уже упоминалось выше, шаги 570fa и 570fb повторяются, пока не выполнится условие ″break″, то есть, пока интервал между значениями переменных ″low″ и ″high″ достаточно велик.
Что касается функциональности алгоритма ″arith_decode ()″, следует отметить, что интервал между значениями переменных ″low″ и ″high″ сокращается на шаге 570е в зависимости от двух смежных записей сводной таблицы частот, на которую ссылается переменная ″cum_freq″. Если интервал между двумя смежными значениями выбранной сводной таблицы частот маленький, то есть, если смежные значения сравнительно близки друг к другу, интервал между значениями переменных ″low″ и ″high″, которые получается в шаге 570е, будет сравнительно небольшой. С другой стороны, если две смежные записи сводной таблицы частот расположены дальше, интервал между значениями переменных ″low″ и ″high″, который получается в шаге 570е, будет сравнительно большим.
Следовательно, если интервал между значениями переменных ″low″ и ″high″, который получается в шаге 570е, сравнительно невелик, будет выполнено большое количество шагов перенормировки интервала, чтобы перемасштабировать интервал к достаточному размеру (так, что ни одно из условий 570fa оценки условий не выполняется). Таким образом, сравнительно большое количество бит битового потока будет использовано для того, чтобы повысить точность переменной ″value″. Если, напротив, размер интервала, полученного в шаге 570е, является сравнительно большим, потребуется только меньшее количество повторений шагов перенормировки интервала 570fa и 570fb, чтобы перенормировать интервал между значениями переменных ″low″ и ″high″ до «достаточного» размера. Соответственно, будет использоваться лишь сравнительно небольшое количество бит битового потока, чтобы увеличить точность переменной ″value″ и подготовить декодирование следующего символа.
Подводя итог вышесказанному, если символ декодирован, который содержит сравнительно высокую вероятность, и с которым связан большой интервал записей выбранной сводной таблицы частот, лишь сравнительно небольшое количество бит будет считано из битового потока, с тем чтобы обеспечить декодирование последующих символов. С другой стороны, если символ декодирован, который содержит сравнительно небольшую вероятность, и с которым связан малый интервал записей выбранной сводной таблицы частот, из битового потока будет взято сравнительно большое количество бит, чтобы подготовить декодирование следующего символа.
Таким образом, записи сводных таблиц частот отражают вероятности разных символов, а также отражает количество бит, необходимых для декодирования последовательности символов. Изменяя сводную таблицу частот в зависимости от контекста, т.е. в зависимости от ранее декодированных символов (или спектральных значений), например, путем выбора разных сводных таблиц частот в зависимости от контекста, могут быть использованы стохастические зависимости между разными символами, что обеспечит особенно битрейт-эффективное кодирование последующих (или смежных) символам.
Подводя итог вышесказанному, функция ″arith_decode ()″, которая была описана, ссылаясь на фиг.5g, вызывается сводной таблицей частот стол ″arith_cf_m[pki][]″, соответственно индексу ″pki″, возвращаемому функцией ″ arith_get_pk () ″, чтобы определить значение наиболее значимого бита плоскости m (которое может быть установлено в значение символа, представляемого возвращаемой переменной ″symbol″).
6.7 Механизм перехода
Хотя декодированное значение m наиболее значимого бита плоскости (которое возвращается как значение символа функцией ″arith_decode ()″ является символом перехода ″ARITH_ESCAPE″, дополнительное значение m наиболее значимого бита плоскости декодируется, и переменная ″lev″ увеличивается на 1. Таким образом, получается информация о числовой значимости значения m наиболее значимого бита плоскости, а также о количестве менее значимых бит плоскости для декодирования.
Если символ перехода ″ARITH_ESCAPE″ декодируется, переменная уровня ″lev″ увеличивается на 1. Соответственно, значение состояния, которое заложено в функцию ″arith_get_pk″, также изменяется, так что значение, представленное самыми высшими битами (биты 24 и выше), увеличивается для следующих итераций алгоритма 312ba.
6.8 Обновление контекста в соответствии с фиг.5h
После того как спектральное значение полностью декодировано (т.е. добавлены все наименее значимые биты плоскости), обновляются контекстные таблицы q и qs, вызывая функцию ″arith_update_context(a,i,lg))″. Далее будет подробно описана функция ″arith_update_context(a,i,lg)″, ссылаясь на фиг.5h, которая показывает псевдо программный код представления указанной функции.
Функция ″arith_update_context ()″ получает в качестве входных переменных декодированный квантованный спектральный коэффициент а, индекс i спектрального значения для декодирования (или декодированное спектральное значение), и количество lg спектральных значений (или коэффициентов), связанных с текущим аудио кадром.
В шаге 580 текущее декодированное квантованное спектральное значение (или коэффициент) а копируется в контекстную таблицу или контекстный массив q. Таким образом, запись q[l][i] контекстной таблицы q установлена в а. Кроме того, переменная ″а0″ установлена в значение ″а″.
В шаге 582 определяется значение уровня q[l][i].l контекстной таблицы q. По умолчанию, значение уровня q[l][i].l контекстной таблицы q равно нулю. Однако, если абсолютное значение текущего кодированного спектрального значения больше 4, значение уровня q[l][i]-l увеличивается. С каждым увеличением переменная ″а″ смещается вправо на один бит.Увеличение значения уровня q[l][i].l повторяется, пока абсолютное значение переменной а0 меньше или равно 4.
В шаге 584 устанавливается 2-битное контекстное значение q[l][i].c контекстной таблицы q. 2-битное контекстное значение q[l][i].c устанавливается в значение 0, если текущее декодированное спектральное значение равно нулю. В противном случае, если абсолютное значение декодированного спектрального значения а меньше или равно 1, 2-битное контекстное значение q[l][i].c устанавливается в значение 1. Или, если абсолютное значение текущего декодированного спектрального значения а меньше или равно 3, 2-битное контекстное значение q[l][i].c устанавливается в значение 2. Или, если, например, абсолютное значение текущего декодированного спектрального значения а больше 3, то 2-битное контекстное значение q[l][i].c устанавливается в значение 3. Таким-образом, 2 битное контекстное значение q[l][i].c получается именно с помощью крупно-модульного квантования текущего декодированного спектрального коэффициента а.
В следующем шаге 586, который производится, только если индекс i текущего декодированного спектрального значения равен количеству lg коэффициентов (спектральных значений) в кадре, то есть, если последнее спектральное значение кадра уже декодировано), и основной режим является основным режимом линейно предсказанной области, (которая указывается в ″core_mode==1″), записи q[l][)].c копируются в контекстную таблицу qs[k]. Копирование выполняется как показано на ссылке с номером 586, так, что количество lg спектральных значений в текущем кадре учитывается для копирования записей q[l]LJ].c в контекстную таблицу qs[k]. Кроме того, переменная ″previous_lg″ принимает значение 1024.
Или, однако, записи q[l][j].c контекстной таблицы q копируются в контекстную таблицу qs[j], если индекс i текущего декодированного спектрального коэффициента достигает значения lg, и основной режим является основным режимом с частотной областью (как указано в ″core_mode==0″).
В этом случае переменная ″previous_lg″ устанавливается на минимум между значением 1024 и количеством lg спектральных значений в кадре.
6.9 Обобщение процесса декодирования
Далее кратко описывается процесс декодирования. За более подробной информацией обратитесь к вышеизложенному описанию, а также к фиг.3,4 и 5а до 5i.
Квантованные спектральные коэффициенты бесшумно кодируются и передаются, начиная с самого низкого частотного коэффициента и увеличиваясь до самого высокого частотного коэффициента.
Коэффициенты перспективного звукового кодирования (ААС) хранятся в массиве ″x_ac_quant[g][win][sfb][bin]″, и порядок передачи кодовых слов бесшумного кодирования таков, что, когда они декодируются в порядок получения и хранения в массиве, ячейка является самым наиболее быстро увеличивающимся индексом, a g самым медленно увеличивающимся индексом. Индекс ячейки означает ячейки частоты. Индекс ″sib″ обозначает полосы коэффициента масштабирования. Индекс ″win″ обозначает окна. Индекс ″g″ обозначает аудио кадр.
Коэффициенты преобразования кодированного возбуждения хранятся непосредственно в массиве ″x_tcx_invquant[win][bin]″, и порядок передачи кодовых слов бесшумного кодирования таков, что, когда они декодируются в порядке получения и хранения в массиве, ″bin″ является самым наиболее быстро увеличивающимся индексом, и ″win″ является самым медленно увеличивающимся индексом.
Во-первых, отображение осуществляется между сохраненным прошлым контекстом в контекстной таблице или массиве ″qs″ и контекстом текущего кадра q (хранится в контекстной таблице или массиве q). Прошлый контекст ″qs″ хранится в 2 битах на линию частоты (или на ячейку частоты).
Отображение между сохраненным прошлым контекстом в контекстной таблице ″qs″ и контекстом текущего кадра в контекстной таблице ″q″ выполняется с помощью функции ″arith_map_context()″, представление псевдо программного кода, которое показано на фиг.5а.
Бесшумный декодер выводит подписанные квантованные спектральные коэффициенты ″а″.
Сначала состояние контекста рассчитывается на основе ранее декодированных спектральных коэффициентов, окружающих квантованные спектральные коэффициенты для декодирования. Состояние контекста s соответствует 24 первым битам значения, возвращаемого функцией ″arith_get_context()″. Биты после 24 го бита возвращаемого значения соответствуют прогнозируемому уровню битовой плоскости lev0. Переменная „lev″ установлена в исходное значение lev0. Представление псевдо программного кода функции ″arith_get_context″ показано на фиг.5b и 5с
Если состояние s и предсказанный уровень ″lev0″ известны, наиболее значимая 2-битная плоскость m декодируется с помощью функции ″arith_decode()″, подкрепленной соответствующей сводной таблицей частот, соответствующей вероятностной модели, соответствующей контекстному состоянию.
Соответствие осуществляется функцией ″arith_get_pk ()″.
Представление псевдо программного кода функции ″arith_get_pk ()″ показано на фиг.5е.
Псевдо программный код другой функции ″get_pk″, которая может заменить функцию ″arith_get_pk ()″, показан на фиг.5f. Псевдо программный код другой функции ″get_pk″, которая может заменить функцию ″arith_get_pk ()″, показан на фиг.5d.
Значение m декодируется с помощью функции ″arith_decode ()″, вызванной сводной таблицей частот, ″arith_cf_m[pki][], где „pki″ соответствует индексу, возвращаемому функцией ″arith_get_pk()″ (или же функцией ″get_pk ()″).
Арифметический кодер является целочисленным осуществлением с помощью способа генерации тэга с масштабированием (см., например, К.Sayood ″Introduction to Data Compression″ third edition, 2006, Elsevier Inc.) Псевдо-С код, изображенный на фиг.5g, описывает используемый алгоритм.
Когда декодированное значение m является символом перехода, ″ARITH_ESCAPE″, другое значение m декодируется, и переменная „lev″ увеличивается на 1. Если значение m не является символом перехода, ″ARITH_ESCAPE″, оставшиеся битовые плоскости затем декодируются от самого значимого до наименее значимого уровня, вызывая „lev″ раз функцию ″arith_decode ()″ с сводной таблицей частот ″arith_cf_r []″. Указанная сводная таблица частот ″arith_cf_r [] может, например, описывать равномерное распределение вероятностей.
Декодированные биты плоскости г обеспечивают уточнение ранее декодированного значения m следующим способом:
а = m;
for (i=0; i<lev;i++) {
r = arith_decode (arith_cf_r,2);
а = (а<<1) | (r&1);
}
Если спектральный квантованный коэффициент а полностью декодирован, контекстная таблица q, или сохраненный контекст qs обновляется функцией ″arith_update_context()″ для декодирования следующих квантованных спектральных коэффициентов.
Представление псевдо программного кода функции ″arith_update_context ()″ показано на фиг.5h.
Кроме того, условные обозначения определений показаны на фиг.5i. 7. Таблицы отображения
В одном из вариантов осуществления изобретения особенно эффективные таблицы ″ari_s_hash″ и ″ari_gs_hash″ и ″ari_cf_m″ используются для выполнения функции ″get_pk″, которая описывалась со ссылкой на фиг.5d, или для выполнения функции ″arith_get_pk″, которая описывалась со ссылкой на фиг.5е, или для выполнения функции ″get_pk″, которая описывалась со ссылкой на фиг.5f и для выполнения функции ″arith_decode″, которая описывалась со ссылкой на фиг.5g.
7.1. Таблица ″ari_s_hash [3871]″ в соответствии с фиг.17
Содержание особо эффективного применения таблицы ″ari_s_hash″, которая используется функцией ″get_pk″, описанной со ссылкой на фиг.5d, показано в таблице на фиг.17. Следует отметить, что таблица на фиг.17 содержит 387 записей таблицы ″ari_s_hash [387]″. Следует также отметить, что табличное представление на фиг.17 показывает элементы в порядке индексов элементов, так, что первое значение ″0x00000200″ соответствует записи таблицы ″ari_s_hash [0]″, имеющей индекс элемента (или табличный индекс) 0, так, что последнее значение ″0x03D0713D″ соответствует записи таблицы ″ari_s_hash [386]″, имеющей индекс элемента или табличный индекс 386. Далее следует отметить, что ″0х″ означает, что записи таблицы в таблице ″ari_s_hash″ представлены в шестнадцатеричном формате. Кроме того, записи таблицы в таблице ″ari_s_hash″ на фиг.17 расположены по числовому порядку, чтобы обеспечить выполнение первой оценочной таблицей 540 функции ″get_pk″.
Следует также отметить, что наиболее значимые 24 бит записи таблицы в таблице ″ari_s_hash″ представляет значения состояния, а наименее значимые 8 бит представляют собой значения индекса правила отображения pki.
Таким образом, записи таблицы ″ari_s_hash″ описывают отображение ″прямого попадания″ значения состояния в значении индекса правила отображения ″pki″.
7.2 _Таблица ″ari_gs_hash″ в соответствии с Фиг.18
Содержание особо эффективного выполнения таблицы ″ari_gs_hash″ показано в таблице на фиг.18. Следует отметить, что эта таблица из таблицы 18 содержит записи таблицы ″ari_gs_hash″. На указанные записи ссылается индекс одномерной записи целочисленного типа (также именуемая ″индекс элемента″ или ″индекс массива″ или ″табличный индекс″), которая, например, обозначается ″i″. Следует отметить, что таблица ″ari_gs_hash″, которая включает в себя всего 225 записей, хорошо подходит для использования второй оценочной таблицей 544 функции ″get_pk″, описанной на фиг.5d.
Следует отметить, что записи таблицы ″ari_gs_hash″ перечислены в порядке возрастания индекса табличного индекса i таблицы для значений табличного индекса i от нуля до 224. Термин ″0х″ означает, что записи в таблице приведены в шестнадцатеричном формате. Соответственно, первая запись таблицы ″0X00000401″ соответствует записи таблицы ″ari_gs_hash [0]″ с табличным индексом 0, и последняя запись таблицы ″0Xffffff3f″ соответствует записи таблицы ″ari_gs_hash [224]″ с табличным индексом 224.
Следует также отметить, что записи таблицы упорядочены в численно восходящем порядке, так, что записи таблицы хорошо подходят для второй оценочной таблицы 544 функции ″get_pk″. Наиболее значимые 24 бит записей таблицы в таблице ″ari_gs_hash″ описывают границы между диапазонами значений состояния, и 8 наименее значимых бит записей описывают значения индекса правила отображения ″pki″, связанный с диапазонами значений состояния, определенных наиболее значимыми 24 бит.
7.3 Таблица ″ari_cf_m″ в соответствии с Фиг.19
Фиг.19 показывает набор 64 сводных таблиц частот ″ari_cf_m[pki][9]″, одна из которых выбрана аудио кодером 100, 700, или аудио декодером 200, 800, например, для выполнения функции ″arith_decode″, то есть для декодирования значения наиболее значимой битовой плоскости. Выбранная одна из 64 сводных таблиц частот, показанная на фиг.19, выбирает функцию таблицы ″cumfreq []″ для выполнения функции ″arith_decode ()″.
Как видно из фиг.19, каждая строка представляет собой сводную таблицу частот с 9 записями. Например, первая строка 1910 представляет 9 записей сводной таблицы частот для ″pki=0″. Вторая строка 1912 представляет 9 записей сводной таблицы частот для ″pki=1″. Наконец, 64-я строка 1964 представляет 9 записей сводной таблицы частот для ″pki=63″. Таким образом, фиг.19 фактически представляет 64 разных сводных таблиц частоты для ″pki=0″ до ″pki=63″, где каждая из 64 сводных таблиц частот представлена одной строкой, и где каждая из указанных сводных таблиц частот включает 9 записей.
В строке (например, строке 1910, или строке1912, или строке 1964), самое левое значение описывает первую запись сводной таблицы частот, и самое правое значение описывает последнюю запись сводной таблицы частот.
Таким образом, каждая строка 1910, 1912, 1964 представления таблицы на фиг.19, представляет записи сводной таблицы частот для использования функцией ″arith_decode″ как на фиг.5g. Входная переменная ″cum_freq []″ функции ″arith_decode″ описывает, какая из 64 сводных таблиц частот (представлены отдельными строками из 9 записей) таблицы ″ari_cf_m″ должна быть использована для декодирования текущих спектральных коэффициентов.
7.4 Таблица ″ari s hash″ в соответствии с Фиг.20
Фиг.20 показывает альтернативную возможность для таблицы ″arishash″, которая может быть использована в сочетании с альтернативной функцией ″arith_get_pk ()″ или ″getjpk ()″ в соответствии с фиг.5е или 5f.
Таблица ″ari_s_hash″ в соответствии с фиг.20 содержит 386 записей, которые приведены на фиг.20 в порядке возрастания табличного индекса. Таким образом, первое значение таблицы ″0x0090D52E″ соответствует записи таблицы ″ari_s_hash [0]″ с табличным индексом 0, а последняя запись таблицы ″0x03D0513C″ соответствует записи таблицы "ari_s_hash [386]″ с табличным индексом 386.
″0х″ означает, что записи таблицы представлены в шестнадцатеричном формате. Наиболее значимые 24 бит записей таблицы ″ari_s_hash″ описывают значимые состояния, и наименее значимые 8 бит записей таблицы ″ari_s_hash″ описывают значения индекса правила отображения.
Соответственно, записи таблицы ″ari_s_hash″ описывают отображение значимых состояний на значения индекса правила отображения ″pki″.
8. Оценка функционирования и преимущества
Вариант осуществления в соответствии с изобретением использует обновленные функции (или алгоритмы) и обновленный набор таблиц, как отмечалось выше, чтобы получить улучшенный выбор оптимального соотношения между сложностью вычислений, требованиями к памяти, а также эффективностью кодирования.
В общих чертах, вариант осуществления в соответствии с изобретением создает улучшенное спектральное бесшумное кодирование.
Настоящее описание характеризует вариант осуществления для СЕ на улучшения спектрального бесшумного кодирования спектральных коэффициентов. Предложенная схема основана на ″оригинальной″ схеме арифметического кодирования на основе контекста, как описано в рабочем проекте 4 проекта стандарта USAC, но существенно снижает требования к памяти (RAM, ROM), в то же время сохраняя бесшумное кодирование. Перекодирование без потери информации WD3 (т.е. выход аудио кодера, обеспечивающего битовый поток в соответствии с рабочим проектом 3 проекта стандарта USAC) является доказанным. При этом описанная схема в общем изменяема, позволяет дальнейший выбор оптимального соотношения между требованием к памяти и выполнению кодирования. Вариант осуществления в соответствии с изобретением стремится заменить спектральную бесшумную схему кодирования, как использовано в рабочем проекте 4 проекта стандарта USAC.
Описанная схема арифметического кодирования основана на схеме как в эталонной модели 0 (RM0) или рабочем проекте 4 (WD4) проекта стандарта USAC. Спектральные коэффициенты, расположенные ранее по частоте или по времени, представляют собой модель контекста. Этот контекст используется для выбора сводных таблиц частот для арифметического кодера (кодера или декодера). По сравнению с вариантом осуществления в соответствии с WD4 контекстное моделирование еще более усовершенствовано и таблицы, содержащие вероятности символа, были усовершенствованы. Число различных вероятностных моделей увеличилось с 32 до 64.
Варианты осуществления в соответствии с изобретением уменьшают размеры таблицы (запрос на данные ROM) до 900 слов длиной 32 бит или 3600 байт. Напротив, вариант осуществления в соответствии с WD4 проекта стандарта USAC требует 16894,5 слов или 76 578 байт. Статический запрос RAM снижается, в некоторых вариантах осуществления в соответствии с изобретением, с 666 слов (2664 байт) до 72 (288 байт) на основной канал кодера. В то же время, он полностью сохраняет выполнение кодирования и может даже достичь прироста приблизительно от 1,04% до 1,39%, по сравнению с общей скоростью передачи данных по всем 9 рабочим точкам. Все битовые потоки рабочего проекта 3 (WD3) могут быть перекодированы без потерь, не влияя на ограничения резервуара бит.
Предложенная схема в соответствии с вариантом осуществления изобретения изменяема: возможен гибкий выбор оптимального соотношения между требованиями памяти и выполнением кодирования. Увеличивая размеры таблиц для кодирования, прирост может быть в дальнейшем увеличен.
Далее будет приведено краткое обсуждение концепции кодирования в соответствии с WD4 проекта стандарта USAC для облегчения понимания преимуществ концепции, описанной в этом документе. В USAC WD4, схема контекстно-зависимого арифметического кодирования используется для бесшумного кодирования квантованных спектральных коэффициентов. В качестве контекста используются декодированные спектральные коэффициенты, которые были раньше по частоте и времени. В соответствии с WD4 максимальное число 16-ти спектральных коэффициентов используются в качестве контекста, 12 из которых были раньше по времени. Спектральные коэффициенты, используемые для контекста и для декодирования, сгруппированы в 4-кортежи (т.е. четыре спектральных коэффициента, соседних по частоте, см. фиг.10а). Контекст сокращается и отображается на сводной таблице частот, которая затем используется для декодирования следующего 4-кортежа спектральных коэффициентов.
Для полной схемы бесшумного схемы кодирования WD4 требуется запрос памяти (ROM) из 16894,5 слов (67 578 байт). Кроме того, 666 слов (2664 байт) статической ROM на основной канал кодера требуются для хранения состояний для следующего кадра.
Табличное представление на фиг.11а описывает таблицы, используемые в схеме арифметического кодирования USAC WD4.
Общий запрос памяти полного декодера USAC WD4 оценивается в 37 000 слов (148 000 байт) для данных ROM без программного кода, и от 10000 до 17000 слов для статической RAM. Ясно видно, что таблицы бесшумного кодера потребляют около 45% общего запроса данных ROM. Самая крупная отдельная таблица уже потребляет 4096 слов (16384 байт).
Было установлено, что и размер сочетания всех таблиц и отдельные крупные таблицы превышают типичные размеры кэша, которые содержатся в фиксированных точечных чипах для малобюджетных портативных устройств, которые находятся в обычном диапазоне 8-32 кбайт (например, ARM9E, ТIС64хх и т.д.). Это означает, что набор таблиц, вероятно, не может сохраняться в быстрых данных RAM, что позволяет быстрый произвольный доступ к данным. Это приводит к тому, что весь процесс декодирования замедляется.
Далее будет кратко описана новая предлагаемая схема.
Для преодоления проблем, упомянутых выше, предлагается заменить схему WD4 проекта стандарта USAC на улучшенную схему бесшумного кодирования. Являясь схемой контекстно-зависимого арифметического кодирования, она основана на схеме WD4 проекта стандарта USAC, но имеет модифицированную схему вывода сводных таблиц частот из контекста. Далее, вывод контекста и кодирование символа осуществляется на детализации одного спектрального коэффициента (в отличие от 4-кортежей, как в WD4 проекта стандарта USAC). В общей сложности, 7 спектральных коэффициентов используются для контекста (по крайней мере в некоторых случаях). Сокращая отображение, выбирается одна из всех 64 вероятностных моделей или сводных таблиц частот (в WD4:32).
Фиг.10b показывает графическое представление контекста для расчета состояния, используемого в предлагаемой схеме (при этом контекст, используемый для обнаружения нулевой области, не показан на фиг.10b).
Далее предлагается краткое описание, касающееся сокращения требования памяти, что может быть достигнуто с помощью предлагаемой схемы кодирования. Предлагаемая новая схема показывает общий запрос ROM 900 слов (3600 байт) (см. таблицу на фиг.11b, которая описывает таблицы, используемые в предлагаемой схеме кодирования).
По сравнению с запросом ROM схемы бесшумного кодирования в WD4 проекта стандарта USAC, запрос ROM сокращается на 15994,5 слов (64 978 байт) (см. также фиг.12а, которая показывает графическое представление запроса ROM предложенной схемы бесшумного кодирования, и бесшумной схемы кодирования в WD4 проекта стандарта USAC). Это сокращает общий запрос ROM полного декодера USAC от примерно 37 000 слов до примерно 21 000 слов, или более чем на 43% (см. фиг.12b, которая дает графическое представление общего декодера USAC запроса на данные ROM в соответствии с WD4 проекта стандарта USAC, а также в соответствии с настоящим предложением).
Далее, количество информации, необходимой для вывода контекста в следующем кадре (статическая RAM), также уменьшается. В соответствии с WD4, полный набор коэффициентов (максимально 1152) с разрешением 16 бит дополнительно к индексу группы индексов на 4-кортеж разрешения 10 бит, необходимых для хранения, которое насчитывает 666 слов (2664 байт) на основной канал кодера (полный декодер USAC WD4:приблизительно от 10000 до 17000 слов).
Новая схема, которая используется в способах осуществления в соответствии с изобретением, сокращает постоянную информацию к всего 2 бит на спектральный коэффициент, который насчитывает до 72 слов (288 байт) в общем на основной канал кодера. Запрос на статическую память может быть сокращен на 594 слова(2376 байт).
Далее описываются некоторые подробности, касающиеся возможного повышения эффективности кодирования. Эффективность кодирования способа осуществления в соответствии с новым предложением сравнивалась с битовыми потоками эталонного качества в соответствии с WD3 проекта стандарта USAC. Сравнение проводилось с помощью транскодера, на основе эталонного программного декодера. Для дополнительной информации относительно сравнения бесшумного кодирования в соответствии с WD3 проекта стандарта USAC и предлагаемой схемы кодирования есть ссылка на фиг.9, которая показывает схематичное представление тестирования.
Хотя запрос памяти резко снижается в вариантах в соответствии с изобретением, при сравнении с вариантами в соответствии с WD3 или WD4 проекта стандарта USAC эффективность кодирования не только сохраняется, но и немного увеличивается. Эффективность кодирования в среднем увеличилась на 1,04% до 1,39%. Для получения дополнительной информации есть ссылка на таблицу на фиг.13 а, которая показывает табличное представление среднего битрейта, произведенного кодером USAC с помощью рабочего проекта арифметического кодера и аудио кодера (например, аудио кодер USAC) в соответствии с вариантом осуществления изобретения.
Измеряя уровень заполнения резервуара бит, было показано, что предлагаемое бесшумное кодирование может без потерь перекодировать битовый поток WD3 для каждой рабочей точки. Для получения дополнительной информации есть ссылка на таблицу на фиг.13b, которая показывает табличное представление контроля резервуара бит для аудио кодера в соответствии с USAC WD3 и аудио кодера в соответствии с вариантом осуществления настоящего изобретения.
Подробная информация о среднем битрейте на режим обработки, минимальном, максимальном и среднем битрейтах на базе кадра и рабочих характеристиках в самых благоприятных/неблагоприятных условиях на базе кадра можно найти в таблицах на фиг.14, 15 и 16, где таблица на фиг.14 показывает табличное представление средних битрейтов для аудио кодера в соответствии с USAC WD3 и для аудио кодера в соответствии с вариантом осуществления настоящего изобретения, где таблица на фиг.15 показывает табличное представление минимального, максимального и среднего битрейтов аудио кодера USAC на базе кадра, где таблица на фиг.16 показывает табличное представление лучших и худших рабочих характеристик на базе кадра.
Кроме того, следует отметить, что варианты в соответствии с настоящим изобретением обеспечивает хорошую масштабируемость. Адаптируя размер таблицы, выбор оптимального соотношения между требования к памяти, вычислительной сложностью и эффективностью кодирования могут быть скорректированы в соответствии с требованиями.
9. Синтаксис битового потока
9.1. Полезная нагрузка спектрального бесшумного кодера
Далее описываются некоторые подробности, касающиеся полезной нагрузки спектрального бесшумного кодера. В некоторых вариантах есть множество различных режимов кодирования, таких как, например, так называемый режим линейного прогнозирования области, ″режим кодирования″ и режим кодирования ″частотной области″. В режиме кодирования линейного прогнозирования области ограничение шума производится на основе анализа с линейным предсказанием аудио, и шумоподобный сигнал кодируется в частотной области. В режиме частотной области ограничение шума осуществляется на основе психоакустического анализа и шумоподобная версия аудио-контента кодируется в частотной области.
Спектральные коэффициенты кодированного сигнала ″линейного предсказания области″ и кодированного сигнала ″частотной области″ скалярно квантуются, а затем бесшумно кодируются адаптивным контекстно-зависимым арифметическим кодированием. Квантованные коэффициенты передаются от самых низких частот к самым высоким частотам. Каждый отдельный квантованный коэффициент делится на наиболее значимые 2 бит плоскости m и остальные менее значимые плоскости бит r. Значение м кодируется в соответствии с окрестностями коэффициента. Остальные менее значимые биты плоскости r энтропийно кодируются без учета контекста. Значения r и m образуют символы арифметического кодера.
Подробная процедура арифметического декодирования описана здесь.
9.2. Элементы синтаксиса
Далее описывается синтаксис битового потока битового потока, несущего арифметически кодированную спектральную информацию, со ссылкой на фиг.6a-6h.
Фиг.6а показывает синтаксическое представление так называемого блока необработанных данных USAC (″usac_raw_data_block ()″).
Блок необработанных данных USAC состоит из одного или более одноканальных элементов (″single_channel_element ()″) и/или одного или более двухканальных элементов (″channel_pair_element ()″).
Теперь перейдем к фиг.6b, где описывается синтаксис одноканального элемента. Одноканальный элемент состоит из потока канала линейного предсказания области (″lpd_channel_stream ()″) или потока канала частотной области (″fd_channel_stream ()″) в зависимости от основного способа.
Фиг.6с показывает синтаксическое представление двухканального элемента. Двухканальный элемент включает в себя информацию об основном режиме (″core_mode0″, ″core_mode1″). Кроме того, двухканальный элемент может включать в себя конфигурационные данные ″ics_info ()″. Кроме того, в зависимости от информации об основном режиме двухканальный элемент состоит из потока канала линейного предсказания области или потока канала частотной области, связанного с первым из каналов, и двухканальный элемент также включает в себя поток канала линейного предсказания области или поток канала частотной области, связанный со вторым из каналов.
Конфигурационные данные ″ics_info ()″, синтаксическое представление которых показано на фиг.6d, содержит множество различных элементов конфигурационных данных, которые не представляют особого интереса для настоящего изобретения.
Поток канала частотной области (″fd_channel_stream ()″), синтаксическое представление которого показано на фиг.6е, включает в себя получение информации (″global_gain″) и конфигурационные данные (″ics_info ()″). Кроме того, поток канала частотной области содержит данные коэффициента масштабирования (″scale_factor_data ()″), которые описывают коэффициенты масштабирования, используемые для масштабирования спектральных значений разных полос коэффициентов масштабирования, и который применяется, например, масштабирующим устройством 150 и рескейлером 240. Поток канала частотной области также включает в себя арифметически кодированные спектральные данные (″ac_spectral_data ()″), который представляет арифметически кодированные спектральные значения.
Арифметически кодированные спектральные данные (″ac_spectral_data ()″), синтаксическое представление которых показано на фиг.6f, включают в себя дополнительный флаг арифметического сброса (″arith_reset_flag″), который используется для выборочного сброса контекста, как описано выше. Кроме того, арифметически кодированные спектральные данные включают в себя множество блоков арифметических данных (″arith_data″), которые несут арифметически кодированные спектральные значения. Структура блоков арифметически кодированных данных зависит от числа частотных полос (представленных переменной ″num_bands″), а также от состояния флага арифметического сброса, о чем будет рассказано далее.
Структура арифметически кодированных блоков данных будет описана со ссылкой на фиг.6g, которая показывает синтаксическое представление указанных блоков арифметически кодированных данных. Представление данных в арифметически кодированных блоках данных зависит от числа lg спектральных значений для кодирования, статуса флага арифметического сброса, а также от контекста, то есть ранее кодированных спектральных значений.
Контекст для кодирования текущего набора спектральных значений определяется в соответствии с алгоритмом определения контекста, показанным со ссылкой на номер 660. Подробности относительно алгоритма определения контекста были рассмотрены выше (фиг.5а). Блок арифметически кодированных данных включает в себя наборы lg кодовых слов, каждый набор кодовых слов представляет спектральное значение. Набор кодовых слов включает в себя арифметическое кодовое слово ″acod_m [pki][m]″, представляющее собой значение наиболее значимого бит плоскости m спектрального значения с помощью от 1 до 20 бит.Кроме того, набор кодовых слов включает в себя одно или больше кодовых слов ″acod_r [г]″, если спектральное значение требует больше битовых плоскостей, чем более значимая битовая плоскость для правильного представления. Кодовое слово ″acod_r [г]″ представляет собой менее значимую битовую плоскость, используя от 1 до 20 бит.
Однако, если требуется одна или больше менее значимых битовых плоскостей (в дополнение к более значимым битовым плоскостям) для правильного представления спектрального значения, то это сигнализируется с помощью одного или более арифметических кодовых слов перехода (″ARITH_ESCAPE″). Таким образом, в целом можно сказать, что для спектрального значения определяется, как много требуется битовых плоскостей (наиболее значимая бит плоскость и, возможно, одна или более дополнительных менее значимых бит плоскостей). Если требуется одна или больше менее значимых бит плоскостей, то это сигнализируется одним или более арифметическими кодовыми словами перехода ″acod_m [pki][ARITH_ESCAPE]″, которые кодируются в соответствии с текущей выбранной сводной таблицей частот, индекс сводной таблицы частот которой задается переменной pki. Кроме того, контекст адаптирован, как можно увидеть на ссылках 664, 662, если одно или более арифметических кодовых слов перехода включены в битовый поток. Следуя за одним или несколькими арифметическими кодовыми словами перехода, арифметическое кодовое слово ″acodm [pki][m]″ включается в битовый поток, как показано на ссылке 663, где pki определяет текущий действующий индекс вероятностной модели (учитывая адаптацию контекста, вызванную включением арифметических кодовых слов перехода), и где m обозначает значение наиболее значимой битовой плоскости спектрального значения для кодирования или декодирования.
Как уже говорилось выше, наличие любой менее значимой битовой плоскости приводит к наличию одного или более кодовых слов ″acod_r [г]″, каждое из которых представляет один бит наименее значимой битовой плоскости. Одно или более кодовых слов ″acod_r[r]″ кодируется в соответствии с соответствующей сводной таблицей частот, которая является постоянной или независимой от контекста.
Кроме того, следует отметить, что контекст обновляется после кодирования каждого спектрального значения, как показано на ссылке 668, так что контекст, как правило, различен для кодирования двух последующих спектральных значений.
Фиг.6h показывает условные обозначения определений и вспомогательных элементов, определяющих синтаксис арифметически кодированного блока данных.
Подводя итог вышесказанному, был описан формат битового потока, который может быть обеспечен аудио кодером 100, и который может быть оценен аудио декодером 200. Битовый поток арифметически кодированных спектральных значений кодируется так, что он подходит алгоритму декодирования, описанному выше.
Кроме того, в целом следует отметить, кодирование является обратной операцией декодирования, так, что в целом можно предположить, что декодер выполняет поиск в таблице, используя рассмотренные выше таблицы, что примерно обратно поиску в таблице, выполняемому декодером. Вообще, можно сказать, что специалист в данной области, который знает алгоритм декодирования и/или синтаксис желаемого битового потока, с легкостью сможет разрабатывать арифметический кодер, который обеспечивает данные, определенные в синтаксисе битового потока, и требуемые арифметическим декодером.
10. Альтернативные варианты использования
Хотя некоторые аспекты уже были описаны в контексте аппарата, ясно, что эти аспекты также представляют собой описание соответствующего способа, где блок или устройство соответствуют шагу способа или черте шага способа. Аналогично, аспекты, изложенные в контексте шага способа, также представляют собой описание соответствующего блока или элемента или черты соответствующего аппарата. Некоторые или все шаги способов могут быть выполнены (с помощью) аппаратного обеспечения, как, например, микропроцессор, программируемый компьютер или электронная схема. В некоторых вариантах один или несколько из самых важных шагов способа могут быть выполнены таким аппаратным обеспечением.
Изобретенный кодированный аудио сигнал может быть сохранен на цифровом носителе или может быть передан с помощью передающего средства, такого как беспроводное средство передачи или проводное средство передачи, например Интернет.
В зависимости от требований определенных реализаций, воплощения изобретения могут быть реализованы в виде аппаратного обеспечения или программного обеспечения. Воплощение может быть осуществлено с помощью цифрового носителя, например дискеты, DVD, Blue-Ray, CD, ROM, PROM, EPROM, EEPROM или флэш-памяти, имеющего сохраненные на нем электронно-читаемые контролирующие сигналы, которые сотрудничают (или способны работать вместе) с программируемой компьютерной системой так, что соответствующий способ выполняется. Таким образом, цифровой носитель может быть машиночитаемым.
Некоторые воплощения в соответствии с изобретением содержат носитель данных, имеющий электронно-читаемые контролирующие сигналы, которые способны сотрудничать с программируемой компьютерной системой так, что выполняется одним из способов, описанных в данном документе.
Как правило, варианты осуществления настоящего изобретения могут быть реализованы в виде программного продукта с программным кодом, который задействован для осуществления одного из способов, когда компьютерный программный продукт работает на компьютере. Программный код, например, может быть сохранен на машиночитаемом носителе.
Другие варианты включают компьютерную программу для выполнения одного из способов, описанных в данном документе, хранящуюся на машиночитаемом носителе.
Иными словами, воплощением изобретенного способа, следовательно, является компьютерная программа, имеющая программный код для выполнения одного из способов, описанных в данном документе, когда компьютерная программа работает на компьютере.
Еще одним вариантом использования изобретенных способов, таким образом, является носитель информации (или цифровой носитель, или машиночитаемый носитель), включающий записанную на нем компьютерную программу для выполнения одного из способов, описанных в данном документе.
Еще одним вариантом использования изобретенного способа является, таким образом, поток данных или последовательность сигналов, представляющих компьютерную программу для выполнения одного из способов, описанных в данном документе. Поток данных или последовательность сигналов, например, может быть настроена для передачи через соединение передачи данных, например, через Интернет.
Еще один вариант использования включает в себя средства обработки, например, компьютер или программируемое логическое устройство, настроенное или адаптированное для выполнения одного из способов, описанных в данном документе.
Еще один вариант использования включает компьютер, с установленной на нем компьютерной программой для выполнения одного из способов, описанных в данном документе.
В некоторых вариантах использования программируемое логическое устройство (например, поле-программируемая вентильная матрица) может быть использовано для выполнения некоторых или всех функциональных возможностей способов, описанных в данном документе. В некоторых вариантах поле-программируемая вентильная матрица может сотрудничать с микропроцессором для выполнения одного из способов, описанных в данном документе. Как правило, способы предпочтительно выполнять с помощью аппаратных средств.
Описанные выше варианты осуществления изобретения являются только иллюстрацией принципов данного изобретения. Подразумевается, что модификации и вариации механизмов и деталей, описанных в данном документе, будут очевидны для других специалистов в данной области. Таким образом, данный документ ограничивается только областью предстоящих патентных притязаний, а не конкретными деталями, представленными в виде описания и объяснения использования изобретения в настоящем документе.
В то время как все вышеописанное было показано и описано со ссылкой на конкретные варианты осуществления, для специалистов в данной области будет понятно, что различные изменения в форме и деталях могут быть сделаны без отступления от сущности и объема изобретения. Следует понимать, что различные изменения могут быть сделаны в процессе адаптации к различным вариантам, не отходя от более широкой концепции, описанной здесь и подтвержденной патентными притязаниями далее.
11. Заключение
В заключении можно отметить, что варианты в соответствии с изобретением создают улучшенную схему спектрального бесшумного кодирования. Варианты в соответствии с новым предложением делают возможным значительное сокращение запроса памяти с 16894,5 слов до 900 слов (ROM) и с 666 до 72 слов (статической RAM на основной канал кодера). Это создает возможность для сокращения запроса на данные ROM всей системы примерно на 43% в одном варианте. Одновременно выполнение кодирования не только полностью сохраняется, но в среднем даже увеличивается. Перекодирование без потерь WD3 (или битового потока в соответствии с WD3 проекта стандарта USAC) признано возможным. Таким образом, вариант в соответствии с изобретением получается благодаря внедрению бесшумного декодирования, описанного здесь, в предстоящий рабочий проект стандарта USAC.
Итак, в варианте изобретения предлагаемое новое бесшумное кодирование может вызвать изменения в рабочем проекте MPEG USAC относительно синтаксиса элемента битового потока ″arith_data ()″ (как показано на фиг.6g), относительно полезной нагрузки спектрального бесшумного кодера (как описано выше и показано на фиг.5h), относительно спектрального бесшумного кодирования как описано выше, относительно контекста для расчета состояния (как показано на фиг.4), относительно определений (как показано на фиг.5i), относительно процесса декодирования (как описано выше, ссылаясь на фиг.5а, 5b, 5с, 5е, 5g, 5h), и относительно таблиц (как показано на фиг.17, 18, 20), и относительно функции ″get_pk″ (как показано на фиг.5d). Кроме того, тем не менее, таблица ″ari_s_hash″ в соответствии с фиг.20 может быть использована вместо таблицы ″ari_s_hash″ на фиг.17, а функция ″get_pk″ на фиг.5f может быть использована вместо функции ″get_pk″ в соответствии с фиг.5d.
Claims (19)
1. Аудио декодер (200, 800) для обеспечения декодированной аудио информации (212, 812) на основе кодированной аудио информации (210, 810), включающий:
арифметический декодер (230; 820) для обеспечения множества декодированных спектральных значений (232, 822) на основе арифметически кодированного представления (222; 821) спектральных значений и
конвертер частотной области во временную область (260, 830) для обеспечения аудио представления временной области (262; 812), используя декодированные спектральные значения (232, 822), в целях получения декодированной аудио информации (212, 812);
где арифметический декодер (230, 820) настроен, чтобы выбрать правило отображения (297; cum_freq []), описывающее отображение значения кода (value) на код символа (symbol) в зависимости от состояния контекста (s); и
где арифметический декодер (230, 820) настроен, чтобы определить текущее состояние контекста (s) в зависимости от множества ранее декодированных спектральных значений,
где арифметический декодер настроен, чтобы обнаружить группу множества ранее декодированных спектральных значений, которые соответствуют по отдельности или вместе взятые заданному условию относительно их величины, а также определить или изменить текущее состояние контекста (s) в зависимости от результата обнаружения.
арифметический декодер (230; 820) для обеспечения множества декодированных спектральных значений (232, 822) на основе арифметически кодированного представления (222; 821) спектральных значений и
конвертер частотной области во временную область (260, 830) для обеспечения аудио представления временной области (262; 812), используя декодированные спектральные значения (232, 822), в целях получения декодированной аудио информации (212, 812);
где арифметический декодер (230, 820) настроен, чтобы выбрать правило отображения (297; cum_freq []), описывающее отображение значения кода (value) на код символа (symbol) в зависимости от состояния контекста (s); и
где арифметический декодер (230, 820) настроен, чтобы определить текущее состояние контекста (s) в зависимости от множества ранее декодированных спектральных значений,
где арифметический декодер настроен, чтобы обнаружить группу множества ранее декодированных спектральных значений, которые соответствуют по отдельности или вместе взятые заданному условию относительно их величины, а также определить или изменить текущее состояние контекста (s) в зависимости от результата обнаружения.
2. Аудио декодер (200, 800) по п. 1, где арифметический декодер настроен, чтобы определить или изменить текущее состояние контекста (s) независимого от ранее декодированных спектральных значений в ответ на обнаружение, что заданное условие выполнено.
3. Аудио декодер (200, 800) по п. 1, где арифметический декодер настроен обнаружить группу множества ранее декодированных смежных спектральных значений, которые соответствуют по отдельности или вместе взятые заданному условию относительно их величины.
4. Аудио декодер по п. 1, где арифметический декодер (230) настроен обнаружить группу множества ранее декодированных смежных спектральных значений, которые по отдельности или вместе взятые составляют величину, которая меньше, чем заданный порог величины, а также определить или изменить текущее состояние контекста (s) в зависимости от результата обнаружения.
5. Аудио декодер по п. 1, где арифметический декодер настроен обнаружить группу множества ранее декодированных смежных спектральных значений, в которой каждое из ранее декодированных спектральных значений имеет нулевое значение, а также определить или изменить состояние контекста (s) в зависимости от результата обнаружения.
6. Аудио декодер по п. 1, где арифметический декодер настроен обнаружить группу множества ранее декодированных смежных спектральных значений, которые имеют значение суммы, которое меньше заданного порога значения, а также определить или изменить текущее состояние (s) в зависимости от результата обнаружения.
7. Аудио декодер по. 1, где арифметический декодер настроен, чтобы установить текущее состояние контекста (s) на заданное значение в ответ на обнаружение, что группа множества ранее декодированных смежных спектральных значений выполняет по отдельности или вместе взятые заданное условие относительно их величины.
8. Аудио декодер по п. 7, где арифметический декодер (230) настроен выборочно пропускать расчет состояния контекста (s) в зависимости от числовых значений множества ранее декодированных спектральных значений в ответ на обнаружение, что группа из множества ранее декодированных смежных спектральных значений выполняет по отдельности или вместе взятые заданное условие относительно их величины.
9. Аудио декодер по п. 1, где арифметический декодер настроен, чтобы установить текущее состояние контекста (s) в пределах диапазона значений, который сигнализирует об обнаружении группы множества ранее декодированных смежных спектральных значений, которые выполняют по отдельности или вместе взятые заданное условие относительно их величины, в ответ на обнаружение.
10. Аудио декодер по п. 1, где арифметический декодер настроен отображать код символа (symbol; m) на декодированное спектральное значение (а).
11. Аудио декодер по п. 1, где арифметический декодер настроен оценить ранее декодированные спектральные значения первой частотно-временной области, чтобы обнаружить группу множества спектральных значений, которые выполняют по отдельности или вместе взятые заданное условие относительно их величины, и
где арифметический декодер настроен получить числовое значение, представляющее состояние контекста (s), если заданное условие не выполняется, в зависимости от ранее декодированных спектральных значений второй частотно-временной области, которая отличается от первой частотно-временной области.
где арифметический декодер настроен получить числовое значение, представляющее состояние контекста (s), если заданное условие не выполняется, в зависимости от ранее декодированных спектральных значений второй частотно-временной области, которая отличается от первой частотно-временной области.
12. Аудио декодер по п. 1, где арифметический декодер настроен оценить одну или более хеш-таблиц (ari_s_hash, ari_gs_hash), чтобы выбрать правило отображения (ari_cf_m[pki][9]) в зависимости от состояния контекста (s).
13. Аудио кодер (100, 700) для обеспечения кодированной аудио информации (112, 712) на основе входной аудио информации (110, 710), аудио кодер, включающий:
энергосберегающий конвертер от временной области к частотной области (130, 720) для обеспечения аудио представления частотной области (132, 722) на основе представления временной области (110, 710) входа аудио информации так, что аудио представление частотной области (132, 722) включает в себя набор спектральных значений, и
арифметический кодер (170; 730) настроен кодировать спектральное значение (а) или его предобработанную версию, используя кодовое слово переменной длины (acod_m, acod_r), в котором арифметический кодер (170) настроен отображать спектральное значение (а) или значение (m) наиболее значимой битовой плоскости спектрального значения (а) на значение кода (acod_m),
где арифметический кодер настроен, чтобы выбрать правило отображения, описывающее отображение спектрального значения или наиболее значимой битовой плоскости спектрального значения, на значение кода, в зависимости от состояния контекста (s), и
где арифметический кодер настроен определить текущее состояние контекста (s) в зависимости от множества ранее кодированных спектральных значений,
где арифметический кодер настроен обнаружить группу множества ранее кодированных спектральных значений, которые выполняют по отдельности или вместе взятые заданное условие относительно их величины, а также определить или изменить текущее состояние контекста (s) в зависимости от результата обнаружения.
энергосберегающий конвертер от временной области к частотной области (130, 720) для обеспечения аудио представления частотной области (132, 722) на основе представления временной области (110, 710) входа аудио информации так, что аудио представление частотной области (132, 722) включает в себя набор спектральных значений, и
арифметический кодер (170; 730) настроен кодировать спектральное значение (а) или его предобработанную версию, используя кодовое слово переменной длины (acod_m, acod_r), в котором арифметический кодер (170) настроен отображать спектральное значение (а) или значение (m) наиболее значимой битовой плоскости спектрального значения (а) на значение кода (acod_m),
где арифметический кодер настроен, чтобы выбрать правило отображения, описывающее отображение спектрального значения или наиболее значимой битовой плоскости спектрального значения, на значение кода, в зависимости от состояния контекста (s), и
где арифметический кодер настроен определить текущее состояние контекста (s) в зависимости от множества ранее кодированных спектральных значений,
где арифметический кодер настроен обнаружить группу множества ранее кодированных спектральных значений, которые выполняют по отдельности или вместе взятые заданное условие относительно их величины, а также определить или изменить текущее состояние контекста (s) в зависимости от результата обнаружения.
14. Аудио кодер (100, 700) по п. 13, в котором арифметический кодер настроен определить или изменить текущее состояние контекста (s) независимо от ранее кодированных спектральных значений в ответ на обнаружение того, что заданное условие выполнено.
15. Аудио кодер (100, 700) по п. 13, в котором арифметический кодер настроен обнаружить группу множества ранее кодированных смежных спектральных значений, которые выполняют по отдельности или вместе взятые заданное условие относительно их величины.
16. Способ предоставления декодированной аудио информации на основе кодированной аудио информации, включающий:
предоставление множества декодированных спектральных значений на основе арифметически кодированного представления спектральных значений и
обеспечение аудио представления временной области, используя декодированные спектральные значения, чтобы получить декодированную аудио информацию;
где предоставление множества декодированных спектральных значений включает выбор правила отображения, описывающего отображение значения кода (acod_m; value), представляющее спектральное значение или наиболее значимую битовую плоскость спектрального значения, в кодированном виде на код символа (symbol), представляющее спектральное значение или наиболее значимую битовую плоскость спектрального значения, в декодированном виде, в зависимости от состояния контекста, и
где текущее состояние контекста определяется в зависимости от множества ранее декодированных спектральных значений,
где группа множества ранее декодированных спектральных значений, которые выполняют по отдельности или вместе взятые заданное условие относительно их величины, обнаружена и где текущее состояние контекста определяется или изменяется в зависимости от результата обнаружения.
предоставление множества декодированных спектральных значений на основе арифметически кодированного представления спектральных значений и
обеспечение аудио представления временной области, используя декодированные спектральные значения, чтобы получить декодированную аудио информацию;
где предоставление множества декодированных спектральных значений включает выбор правила отображения, описывающего отображение значения кода (acod_m; value), представляющее спектральное значение или наиболее значимую битовую плоскость спектрального значения, в кодированном виде на код символа (symbol), представляющее спектральное значение или наиболее значимую битовую плоскость спектрального значения, в декодированном виде, в зависимости от состояния контекста, и
где текущее состояние контекста определяется в зависимости от множества ранее декодированных спектральных значений,
где группа множества ранее декодированных спектральных значений, которые выполняют по отдельности или вместе взятые заданное условие относительно их величины, обнаружена и где текущее состояние контекста определяется или изменяется в зависимости от результата обнаружения.
17. Способ предоставления кодированной аудио информации на основе входной аудио информации, включающий:
предоставление аудио представления частотной области на основе представления во временной области входной аудио информации, используя энергосберегающее преобразование из временной области в частотную, так, что аудио представление частотной области включает в себя набор спектральных значений, и
арифметическое кодирование спектрального значения или его предобработанной версии, используя кодовое слово переменной длины, где спектральное значение или значение более значимой битовой плоскости спектрального значения отображается на значении кода;
где правило отображения, описывающее отображение спектрального значения или более значимой битовой плоскости спектрального значения на значение кода, выбирается в зависимости от состояния контекста, и
где текущее состояние контекста определяется в зависимости от множества ранее кодированных смежных спектральных значений, и
где группа множества ранее декодированных спектральных значений, которые выполняют по отдельности или вместе заданное условие относительно их величины, обнаруживается, и текущее состояние контекста определяется или изменяется в зависимости от результата обнаружения.
предоставление аудио представления частотной области на основе представления во временной области входной аудио информации, используя энергосберегающее преобразование из временной области в частотную, так, что аудио представление частотной области включает в себя набор спектральных значений, и
арифметическое кодирование спектрального значения или его предобработанной версии, используя кодовое слово переменной длины, где спектральное значение или значение более значимой битовой плоскости спектрального значения отображается на значении кода;
где правило отображения, описывающее отображение спектрального значения или более значимой битовой плоскости спектрального значения на значение кода, выбирается в зависимости от состояния контекста, и
где текущее состояние контекста определяется в зависимости от множества ранее кодированных смежных спектральных значений, и
где группа множества ранее декодированных спектральных значений, которые выполняют по отдельности или вместе заданное условие относительно их величины, обнаруживается, и текущее состояние контекста определяется или изменяется в зависимости от результата обнаружения.
18. Машиночитаемый носитель, на котором хранится программный код для осуществления способа по п. 16, когда программа запускается на компьютере.
19. Машиночитаемый носитель, на котором хранится программный код для осуществления способа по п. 17, когда программа запускается на компьютере.
Applications Claiming Priority (3)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US25345909P | 2009-10-20 | 2009-10-20 | |
| US61/253,459 | 2009-10-20 | ||
| PCT/EP2010/065725 WO2011048098A1 (en) | 2009-10-20 | 2010-10-19 | Audio encoder, audio decoder, method for encoding an audio information, method for decoding an audio information and computer program using a detection of a group of previously-decoded spectral values |
Publications (2)
| Publication Number | Publication Date |
|---|---|
| RU2012122277A RU2012122277A (ru) | 2013-11-27 |
| RU2591663C2 true RU2591663C2 (ru) | 2016-07-20 |
Family
ID=43259832
Family Applications (3)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| RU2012122277/08A RU2591663C2 (ru) | 2009-10-20 | 2010-10-19 | Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая обнаружение группы ранее декодированных спектральных значений |
| RU2012122278/08A RU2596596C2 (ru) | 2009-10-20 | 2010-10-19 | Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая зависимое от диапазона арифметическое кодирующее правило отображения |
| RU2012122275/08A RU2605677C2 (ru) | 2009-10-20 | 2010-10-19 | Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая итеративное уменьшение размера интервала |
Family Applications After (2)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| RU2012122278/08A RU2596596C2 (ru) | 2009-10-20 | 2010-10-19 | Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая зависимое от диапазона арифметическое кодирующее правило отображения |
| RU2012122275/08A RU2605677C2 (ru) | 2009-10-20 | 2010-10-19 | Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая итеративное уменьшение размера интервала |
Country Status (18)
| Country | Link |
|---|---|
| US (10) | US8706510B2 (ru) |
| EP (3) | EP2491554B1 (ru) |
| JP (3) | JP5707410B2 (ru) |
| KR (3) | KR101419148B1 (ru) |
| CN (3) | CN102667922B (ru) |
| AR (3) | AR078705A1 (ru) |
| AU (1) | AU2010309820B2 (ru) |
| BR (5) | BR112012009446B1 (ru) |
| CA (4) | CA2778323C (ru) |
| ES (3) | ES2610163T3 (ru) |
| MX (3) | MX2012004569A (ru) |
| MY (3) | MY160807A (ru) |
| PL (3) | PL2491552T3 (ru) |
| PT (1) | PT2491553T (ru) |
| RU (3) | RU2591663C2 (ru) |
| TW (3) | TWI426504B (ru) |
| WO (3) | WO2011048100A1 (ru) |
| ZA (3) | ZA201203607B (ru) |
Families Citing this family (34)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| MX2011000379A (es) | 2008-07-11 | 2011-02-25 | Ten Forschung Ev Fraunhofer | Codificador de audio y decodificador de audio. |
| EP2315358A1 (en) * | 2009-10-09 | 2011-04-27 | Thomson Licensing | Method and device for arithmetic encoding or arithmetic decoding |
| BR112012009446B1 (pt) | 2009-10-20 | 2023-03-21 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V | Método e aparelho de armazenamento de dados |
| BR112012017256B1 (pt) | 2010-01-12 | 2021-08-31 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V | Codificador de áudio, decodificador de áudio, método de codificação e informação de áudio e método de decodificação de uma informação de áudio que utiliza uma tabela hash que descreve tanto valores de estado significativos como limites de intervalo |
| SG187164A1 (en) * | 2010-07-20 | 2013-02-28 | Fraunhofer Ges Forschung | Audio encoder, audio decoder, method for encoding an audio information, method for decoding an audio information and computer program using an optimized hash table |
| CN103368682B (zh) | 2012-03-29 | 2016-12-07 | 华为技术有限公司 | 信号编码和解码的方法和设备 |
| PL3361735T3 (pl) | 2012-07-02 | 2020-04-30 | Samsung Electronics Co., Ltd. | Entropijne kodowanie wideo i entropijne dekodowanie wideo |
| TWI557727B (zh) | 2013-04-05 | 2016-11-11 | 杜比國際公司 | 音訊處理系統、多媒體處理系統、處理音訊位元流的方法以及電腦程式產品 |
| EP2830055A1 (en) | 2013-07-22 | 2015-01-28 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Context-based entropy coding of sample values of a spectral envelope |
| KR102315920B1 (ko) * | 2013-09-16 | 2021-10-21 | 삼성전자주식회사 | 신호 부호화방법 및 장치와 신호 복호화방법 및 장치 |
| JP6243540B2 (ja) * | 2013-09-16 | 2017-12-06 | サムスン エレクトロニクス カンパニー リミテッド | スペクトル符号化方法及びスペクトル復号化方法 |
| JP6633547B2 (ja) * | 2014-02-17 | 2020-01-22 | サムスン エレクトロニクス カンパニー リミテッド | スペクトル符号化方法 |
| KR20250004113A (ko) | 2014-07-28 | 2025-01-07 | 삼성전자주식회사 | 신호 부호화방법 및 장치와 신호 복호화방법 및 장치 |
| CN106796793B (zh) * | 2014-09-04 | 2020-09-22 | 索尼公司 | 传输设备、传输方法、接收设备以及接收方法 |
| TWI732403B (zh) * | 2015-03-13 | 2021-07-01 | 瑞典商杜比國際公司 | 解碼具有增強頻譜帶複製元資料在至少一填充元素中的音訊位元流 |
| TWI771266B (zh) * | 2015-03-13 | 2022-07-11 | 瑞典商杜比國際公司 | 解碼具有增強頻譜帶複製元資料在至少一填充元素中的音訊位元流 |
| EP3107096A1 (en) * | 2015-06-16 | 2016-12-21 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Downscaled decoding |
| WO2017050398A1 (en) * | 2015-09-25 | 2017-03-30 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Encoder, decoder and methods for signal-adaptive switching of the overlap ratio in audio transform coding |
| US10812550B1 (en) * | 2016-08-03 | 2020-10-20 | Amazon Technologies, Inc. | Bitrate allocation for a multichannel media stream |
| CN116631417A (zh) | 2017-01-10 | 2023-08-22 | 弗劳恩霍夫应用研究促进协会 | 音频解码器、提供解码的音频信号的方法、和计算机程序 |
| EP3483880A1 (en) | 2017-11-10 | 2019-05-15 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Temporal noise shaping |
| EP3483883A1 (en) | 2017-11-10 | 2019-05-15 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Audio coding and decoding with selective postfiltering |
| EP3483878A1 (en) | 2017-11-10 | 2019-05-15 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Audio decoder supporting a set of different loss concealment tools |
| WO2019091576A1 (en) | 2017-11-10 | 2019-05-16 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Audio encoders, audio decoders, methods and computer programs adapting an encoding and decoding of least significant bits |
| WO2019091573A1 (en) | 2017-11-10 | 2019-05-16 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Apparatus and method for encoding and decoding an audio signal using downsampling or interpolation of scale parameters |
| EP3483879A1 (en) | 2017-11-10 | 2019-05-15 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Analysis/synthesis windowing function for modulated lapped transformation |
| EP3483886A1 (en) | 2017-11-10 | 2019-05-15 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Selecting pitch lag |
| EP3483884A1 (en) | 2017-11-10 | 2019-05-15 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Signal filtering |
| EP3483882A1 (en) | 2017-11-10 | 2019-05-15 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Controlling bandwidth in encoders and/or decoders |
| KR20200000649A (ko) * | 2018-06-25 | 2020-01-03 | 네이버 주식회사 | 오디오 병렬 트랜스코딩을 위한 방법 및 시스템 |
| TWI672911B (zh) * | 2019-03-06 | 2019-09-21 | 瑞昱半導體股份有限公司 | 解碼方法及相關電路 |
| CN111757168B (zh) * | 2019-03-29 | 2022-08-19 | 腾讯科技(深圳)有限公司 | 音频解码方法、装置、存储介质及设备 |
| US11024322B2 (en) * | 2019-05-31 | 2021-06-01 | Verizon Patent And Licensing Inc. | Methods and systems for encoding frequency-domain data |
| KR102841237B1 (ko) * | 2023-12-13 | 2025-08-05 | 정후근 | 후 알고리즘 |
Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| EP1883067A1 (en) * | 2006-07-24 | 2008-01-30 | Deutsche Thomson-Brandt Gmbh | Method and apparatus for lossless encoding of a source signal, using a lossy encoded data stream and a lossless extension data stream |
| RU2335809C2 (ru) * | 2004-02-13 | 2008-10-10 | Фраунхофер-Гезелльшафт Цур Фердерунг Дер Ангевандтен Форшунг Е.Ф. | Аудиокодирование |
| US7447631B2 (en) * | 2002-06-17 | 2008-11-04 | Dolby Laboratories Licensing Corporation | Audio coding system using spectral hole filling |
| EP1439524B1 (en) * | 2002-07-19 | 2009-04-08 | NEC Corporation | Audio decoding device, decoding method, and program |
| EP2077550A1 (en) * | 2008-01-04 | 2009-07-08 | Dolby Sweden AB | Audio encoder and decoder |
Family Cites Families (146)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US5222189A (en) | 1989-01-27 | 1993-06-22 | Dolby Laboratories Licensing Corporation | Low time-delay transform coder, decoder, and encoder/decoder for high-quality audio |
| US5388181A (en) * | 1990-05-29 | 1995-02-07 | Anderson; David J. | Digital audio compression system |
| US5835792A (en) | 1993-06-24 | 1998-11-10 | Discovision Associates | Token-based adaptive video processing arrangement |
| US5659659A (en) | 1993-07-26 | 1997-08-19 | Alaris, Inc. | Speech compressor using trellis encoding and linear prediction |
| WO1997029549A1 (en) * | 1996-02-08 | 1997-08-14 | Matsushita Electric Industrial Co., Ltd. | Wide band audio signal encoder, wide band audio signal decoder, wide band audio signal encoder/decoder and wide band audio signal recording medium |
| JP3305190B2 (ja) * | 1996-03-11 | 2002-07-22 | 富士通株式会社 | データ圧縮装置及びデータ復元装置 |
| US6269338B1 (en) | 1996-10-10 | 2001-07-31 | U.S. Philips Corporation | Data compression and expansion of an audio signal |
| JP3367370B2 (ja) | 1997-03-14 | 2003-01-14 | 三菱電機株式会社 | 適応符号化方法 |
| DE19730130C2 (de) | 1997-07-14 | 2002-02-28 | Fraunhofer Ges Forschung | Verfahren zum Codieren eines Audiosignals |
| US7197190B1 (en) * | 1997-09-29 | 2007-03-27 | Canon Kabushiki Kaisha | Method for digital data compression |
| RU2214047C2 (ru) * | 1997-11-19 | 2003-10-10 | Самсунг Электроникс Ко., Лтд. | Способ и устройство для масштабируемого кодирования/декодирования аудиосигналов |
| KR100335611B1 (ko) * | 1997-11-20 | 2002-10-09 | 삼성전자 주식회사 | 비트율 조절이 가능한 스테레오 오디오 부호화/복호화 방법 및 장치 |
| KR100335609B1 (ko) * | 1997-11-20 | 2002-10-04 | 삼성전자 주식회사 | 비트율조절이가능한오디오부호화/복호화방법및장치 |
| US6029126A (en) | 1998-06-30 | 2000-02-22 | Microsoft Corporation | Scalable audio coder and decoder |
| US6704705B1 (en) | 1998-09-04 | 2004-03-09 | Nortel Networks Limited | Perceptual audio coding |
| DE19840835C2 (de) | 1998-09-07 | 2003-01-09 | Fraunhofer Ges Forschung | Vorrichtung und Verfahren zum Entropiecodieren von Informationswörtern und Vorrichtung und Verfahren zum Decodieren von Entropie-codierten Informationswörtern |
| EP1062813A1 (en) | 1999-01-13 | 2000-12-27 | Koninklijke Philips Electronics N.V. | Embedding supplemental data in an encoded signal |
| DE19910621C2 (de) * | 1999-03-10 | 2001-01-25 | Thomas Poetter | Vorrichtung und Verfahren zum Verbergen von Informationen und Vorrichtung und Verfahren zum Extrahieren von Informationen |
| US6751641B1 (en) | 1999-08-17 | 2004-06-15 | Eric Swanson | Time domain data converter with output frequency domain conversion |
| US6978236B1 (en) | 1999-10-01 | 2005-12-20 | Coding Technologies Ab | Efficient spectral envelope coding using variable time/frequency resolution and time/frequency switching |
| JP2001119302A (ja) | 1999-10-15 | 2001-04-27 | Canon Inc | 符号化装置、復号装置、情報処理システム、情報処理方法、及び記憶媒体 |
| US7260523B2 (en) | 1999-12-21 | 2007-08-21 | Texas Instruments Incorporated | Sub-band speech coding system |
| US20020016161A1 (en) | 2000-02-10 | 2002-02-07 | Telefonaktiebolaget Lm Ericsson (Publ) | Method and apparatus for compression of speech encoded parameters |
| US6677869B2 (en) | 2001-02-22 | 2004-01-13 | Panasonic Communications Co., Ltd. | Arithmetic coding apparatus and image processing apparatus |
| US6538583B1 (en) * | 2001-03-16 | 2003-03-25 | Analog Devices, Inc. | Method and apparatus for context modeling |
| JP2004521394A (ja) | 2001-06-28 | 2004-07-15 | コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ | 広帯域信号伝送システム |
| US20030093451A1 (en) | 2001-09-21 | 2003-05-15 | International Business Machines Corporation | Reversible arithmetic coding for quantum data compression |
| DE10204617B4 (de) * | 2002-02-05 | 2005-02-03 | Siemens Ag | Verfahren und Vorrichtungen zur Kompression und Dekompression eines Videodatenstroms |
| JP2003255999A (ja) | 2002-03-06 | 2003-09-10 | Toshiba Corp | 符号化デジタルオーディオ信号の変速再生装置 |
| JP4090862B2 (ja) * | 2002-04-26 | 2008-05-28 | 松下電器産業株式会社 | 可変長符号化方法および可変長復号化方法 |
| EP1467491B1 (de) * | 2002-05-02 | 2007-01-24 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Arithmetische Codierung von Transformationskoeffizienten |
| US7242713B2 (en) | 2002-05-02 | 2007-07-10 | Microsoft Corporation | 2-D transforms for image and video coding |
| GB2388502A (en) | 2002-05-10 | 2003-11-12 | Chris Dunn | Compression of frequency domain audio signals |
| KR100462611B1 (ko) * | 2002-06-27 | 2004-12-20 | 삼성전자주식회사 | 하모닉 성분을 이용한 오디오 코딩방법 및 장치 |
| US7328150B2 (en) | 2002-09-04 | 2008-02-05 | Microsoft Corporation | Innovations in pure lossless audio compression |
| ATE449405T1 (de) * | 2002-09-04 | 2009-12-15 | Microsoft Corp | Entropische kodierung mittels anpassung des kodierungsmodus zwischen niveau- und lauflängenniveau-modus |
| US7433824B2 (en) * | 2002-09-04 | 2008-10-07 | Microsoft Corporation | Entropy coding by adapting coding between level and run-length/level modes |
| US7299190B2 (en) | 2002-09-04 | 2007-11-20 | Microsoft Corporation | Quantization and inverse quantization for audio |
| JP4859368B2 (ja) * | 2002-09-17 | 2012-01-25 | ウラディミール・ツェペルコヴィッツ | 高圧縮比を提供する要求資源最小の高速コーデック |
| FR2846179B1 (fr) | 2002-10-21 | 2005-02-04 | Medialive | Embrouillage adaptatif et progressif de flux audio |
| US6646578B1 (en) * | 2002-11-22 | 2003-11-11 | Ub Video Inc. | Context adaptive variable length decoding system and method |
| US7876966B2 (en) | 2003-03-11 | 2011-01-25 | Spyder Navigations L.L.C. | Switching between coding schemes |
| US6900748B2 (en) | 2003-07-17 | 2005-05-31 | Fraunhofer-Gesellschaft Zur Foerderung Der Angewandten Forschung E.V. | Method and apparatus for binarization and arithmetic coding of a data value |
| US7562145B2 (en) | 2003-08-28 | 2009-07-14 | International Business Machines Corporation | Application instance level workload distribution affinities |
| JP2005130099A (ja) | 2003-10-22 | 2005-05-19 | Matsushita Electric Ind Co Ltd | 算術復号装置、算術符号化装置、算術符号化・復号装置、携帯端末装置、動画像撮影装置、及び、動画像記録・再生装置 |
| JP2005184232A (ja) | 2003-12-17 | 2005-07-07 | Sony Corp | 符号化装置、プログラム、およびデータ処理方法 |
| JP2005184511A (ja) * | 2003-12-19 | 2005-07-07 | Nec Access Technica Ltd | デジタル画像符号化装置及びその方法並びにデジタル画像復号化装置及びその方法 |
| JP4241417B2 (ja) * | 2004-02-04 | 2009-03-18 | 日本ビクター株式会社 | 算術復号化装置、および算術復号化プログラム |
| CA2457988A1 (en) | 2004-02-18 | 2005-08-18 | Voiceage Corporation | Methods and devices for audio compression based on acelp/tcx coding and multi-rate lattice vector quantization |
| US7516064B2 (en) | 2004-02-19 | 2009-04-07 | Dolby Laboratories Licensing Corporation | Adaptive hybrid transform for signal analysis and synthesis |
| KR20050087956A (ko) | 2004-02-27 | 2005-09-01 | 삼성전자주식회사 | 무손실 오디오 부호화/복호화 방법 및 장치 |
| US20090299756A1 (en) | 2004-03-01 | 2009-12-03 | Dolby Laboratories Licensing Corporation | Ratio of speech to non-speech audio such as for elderly or hearing-impaired listeners |
| CN1926607B (zh) | 2004-03-01 | 2011-07-06 | 杜比实验室特许公司 | 多信道音频编码 |
| KR100561869B1 (ko) * | 2004-03-10 | 2006-03-17 | 삼성전자주식회사 | 무손실 오디오 부호화/복호화 방법 및 장치 |
| US7577844B2 (en) | 2004-03-17 | 2009-08-18 | Microsoft Corporation | Systems and methods for encoding randomly distributed features in an object |
| MX2007000459A (es) * | 2004-07-14 | 2007-07-25 | Agency Science Tech & Res | Codificacion y descodificacion de senales, basadas en contexto. |
| KR100624432B1 (ko) * | 2004-08-05 | 2006-09-19 | 삼성전자주식회사 | 내용 기반 적응적 이진 산술 복호화 방법 및 장치 |
| WO2006036442A2 (en) | 2004-08-31 | 2006-04-06 | Gopalakrishnan Kumar | Method and system for providing information services relevant to visual imagery |
| RU2387024C2 (ru) | 2004-11-05 | 2010-04-20 | Панасоник Корпорэйшн | Кодер, декодер, способ кодирования и способ декодирования |
| US7903824B2 (en) | 2005-01-10 | 2011-03-08 | Agere Systems Inc. | Compact side information for parametric coding of spatial audio |
| KR100829558B1 (ko) * | 2005-01-12 | 2008-05-14 | 삼성전자주식회사 | 스케일러블 오디오 데이터 산술 복호화 방법 및 장치와스케일러블 오디오 비트스트림 절단 방법 |
| WO2006075901A1 (en) | 2005-01-14 | 2006-07-20 | Sungkyunkwan University | Methods of and apparatuses for adaptive entropy encoding and adaptive entropy decoding for scalable video encoding |
| ES2636443T3 (es) | 2005-04-01 | 2017-10-05 | Qualcomm Incorporated | Sistemas, procedimientos y aparatos para codificación de voz de banda ancha |
| KR100694098B1 (ko) | 2005-04-04 | 2007-03-12 | 한국과학기술원 | 산술 복호 방법 및 그 장치 |
| KR100703773B1 (ko) | 2005-04-13 | 2007-04-06 | 삼성전자주식회사 | 향상된 코딩 효율을 갖는 엔트로피 코딩 및 디코딩 방법과이를 위한 장치, 이를 포함하는 비디오 코딩 및 디코딩방법과 이를 위한 장치 |
| US7196641B2 (en) | 2005-04-26 | 2007-03-27 | Gen Dow Huang | System and method for audio data compression and decompression using discrete wavelet transform (DWT) |
| ES2374309T3 (es) | 2005-07-14 | 2012-02-15 | Koninklijke Philips Electronics N.V. | Decodificación de audio. |
| KR100851970B1 (ko) * | 2005-07-15 | 2008-08-12 | 삼성전자주식회사 | 오디오 신호의 중요주파수 성분 추출방법 및 장치와 이를이용한 저비트율 오디오 신호 부호화/복호화 방법 및 장치 |
| US7546240B2 (en) | 2005-07-15 | 2009-06-09 | Microsoft Corporation | Coding with improved time resolution for selected segments via adaptive block transformation of a group of samples from a subband decomposition |
| US7539612B2 (en) | 2005-07-15 | 2009-05-26 | Microsoft Corporation | Coding and decoding scale factor information |
| US20070036228A1 (en) | 2005-08-12 | 2007-02-15 | Via Technologies Inc. | Method and apparatus for audio encoding and decoding |
| US20080221907A1 (en) | 2005-09-14 | 2008-09-11 | Lg Electronics, Inc. | Method and Apparatus for Decoding an Audio Signal |
| US20070126853A1 (en) * | 2005-10-03 | 2007-06-07 | Nokia Corporation | Variable length codes for scalable video coding |
| US20070094035A1 (en) | 2005-10-21 | 2007-04-26 | Nokia Corporation | Audio coding |
| KR100803206B1 (ko) | 2005-11-11 | 2008-02-14 | 삼성전자주식회사 | 오디오 지문 생성과 오디오 데이터 검색 장치 및 방법 |
| US7272504B2 (en) * | 2005-11-15 | 2007-09-18 | Baker Hughes Incorporated | Real-time imaging while drilling |
| WO2007065352A1 (fr) | 2005-12-05 | 2007-06-14 | Huawei Technologies Co., Ltd. | Procede et appareil permettant d'effectuer un codage/decodage arithmetique |
| KR101237413B1 (ko) | 2005-12-07 | 2013-02-26 | 삼성전자주식회사 | 오디오 신호의 부호화 및 복호화 방법, 오디오 신호의부호화 및 복호화 장치 |
| CN101133649B (zh) * | 2005-12-07 | 2010-08-25 | 索尼株式会社 | 编码装置、编码方法以及解码装置、解码方法 |
| US7283073B2 (en) | 2005-12-19 | 2007-10-16 | Primax Electronics Ltd. | System for speeding up the arithmetic coding processing and method thereof |
| WO2007080225A1 (en) | 2006-01-09 | 2007-07-19 | Nokia Corporation | Decoding of binaural audio signals |
| WO2007080211A1 (en) | 2006-01-09 | 2007-07-19 | Nokia Corporation | Decoding of binaural audio signals |
| US7983343B2 (en) * | 2006-01-12 | 2011-07-19 | Lsi Corporation | Context adaptive binary arithmetic decoding for high definition video |
| US7831434B2 (en) | 2006-01-20 | 2010-11-09 | Microsoft Corporation | Complex-transform channel coding with extended-band frequency coding |
| KR100774585B1 (ko) | 2006-02-10 | 2007-11-09 | 삼성전자주식회사 | 변조 스펙트럼을 이용한 음악 정보 검색 방법 및 그 장치 |
| US8027479B2 (en) | 2006-06-02 | 2011-09-27 | Coding Technologies Ab | Binaural multi-channel decoder in the context of non-energy conserving upmix rules |
| US7948409B2 (en) | 2006-06-05 | 2011-05-24 | Mediatek Inc. | Automatic power control system for optical disc drive and method thereof |
| US8306125B2 (en) * | 2006-06-21 | 2012-11-06 | Digital Video Systems, Inc. | 2-bin parallel decoder for advanced video processing |
| DE602007012116D1 (de) | 2006-08-15 | 2011-03-03 | Dolby Lab Licensing Corp | Arbiträre formung einer temporären rauschhüllkurve ohne nebeninformation |
| US7554468B2 (en) | 2006-08-25 | 2009-06-30 | Sony Computer Entertainment Inc, | Entropy decoding methods and apparatus using most probable and least probable signal cases |
| JP4785706B2 (ja) | 2006-11-01 | 2011-10-05 | キヤノン株式会社 | 復号装置及び復号方法 |
| US20080243518A1 (en) | 2006-11-16 | 2008-10-02 | Alexey Oraevsky | System And Method For Compressing And Reconstructing Audio Files |
| DE102007017254B4 (de) | 2006-11-16 | 2009-06-25 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Vorrichtung zum Kodieren und Dekodieren |
| KR100868763B1 (ko) | 2006-12-04 | 2008-11-13 | 삼성전자주식회사 | 오디오 신호의 중요 주파수 성분 추출 방법 및 장치와 이를이용한 오디오 신호의 부호화/복호화 방법 및 장치 |
| US7365659B1 (en) | 2006-12-06 | 2008-04-29 | Silicon Image Gmbh | Method of context adaptive binary arithmetic coding and coding apparatus using the same |
| AU2007332508B2 (en) | 2006-12-13 | 2012-08-16 | Iii Holdings 12, Llc | Encoding device, decoding device, and method thereof |
| US20100111432A1 (en) * | 2006-12-27 | 2010-05-06 | Joerg Mohr | Device and Method for Coding a Transformation Coefficient Block |
| CN101231850B (zh) | 2007-01-23 | 2012-02-29 | 华为技术有限公司 | 编解码方法及装置 |
| KR101365989B1 (ko) | 2007-03-08 | 2014-02-25 | 삼성전자주식회사 | 트리 구조를 기반으로 한 엔트로피 부호화 및 복호화 장치및 방법 |
| US7498960B2 (en) * | 2007-04-19 | 2009-03-03 | Analog Devices, Inc. | Programmable compute system for executing an H.264 binary decode symbol instruction |
| JP2008289125A (ja) | 2007-04-20 | 2008-11-27 | Panasonic Corp | 算術復号化装置及びその方法 |
| US7885473B2 (en) * | 2007-04-26 | 2011-02-08 | Texas Instruments Incorporated | Method of CABAC coefficient magnitude and sign decoding suitable for use on VLIW data processors |
| US8515759B2 (en) | 2007-04-26 | 2013-08-20 | Dolby International Ab | Apparatus and method for synthesizing an output signal |
| US7813567B2 (en) * | 2007-04-26 | 2010-10-12 | Texas Instruments Incorporated | Method of CABAC significance MAP decoding suitable for use on VLIW data processors |
| JP4748113B2 (ja) | 2007-06-04 | 2011-08-17 | ソニー株式会社 | 学習装置および学習方法、並びにプログラムおよび記録媒体 |
| ES2593822T3 (es) * | 2007-06-08 | 2016-12-13 | Lg Electronics Inc. | Método y aparato para procesar una señal de audio |
| JP5686369B2 (ja) | 2007-06-11 | 2015-03-18 | フラウンホッファー−ゲゼルシャフト ツァー フェーデルング デア アンゲバンテン フォルシュング エー ファー | インパルス状の部分と定常部分とを有するオーディオ信号を符号化するオーディオ符号器、符号化方法、復号器、および復号化方法 |
| US8521540B2 (en) | 2007-08-17 | 2013-08-27 | Qualcomm Incorporated | Encoding and/or decoding digital signals using a permutation value |
| US20110116542A1 (en) * | 2007-08-24 | 2011-05-19 | France Telecom | Symbol plane encoding/decoding with dynamic calculation of probability tables |
| US7839311B2 (en) | 2007-08-31 | 2010-11-23 | Qualcomm Incorporated | Architecture for multi-stage decoding of a CABAC bitstream |
| TWI351180B (en) * | 2007-09-29 | 2011-10-21 | Novatek Microelectronics Corp | Data encoding/decoding method and related apparatus capable of lowering signal power spectral density |
| US7777654B2 (en) | 2007-10-16 | 2010-08-17 | Industrial Technology Research Institute | System and method for context-based adaptive binary arithematic encoding and decoding |
| US8527265B2 (en) | 2007-10-22 | 2013-09-03 | Qualcomm Incorporated | Low-complexity encoding/decoding of quantized MDCT spectrum in scalable speech and audio codecs |
| US8515767B2 (en) | 2007-11-04 | 2013-08-20 | Qualcomm Incorporated | Technique for encoding/decoding of codebook indices for quantized MDCT spectrum in scalable speech and audio codecs |
| US7714753B2 (en) | 2007-12-11 | 2010-05-11 | Intel Corporation | Scalable context adaptive binary arithmetic coding |
| US8631060B2 (en) | 2007-12-13 | 2014-01-14 | Qualcomm Incorporated | Fast algorithms for computation of 5-point DCT-II, DCT-IV, and DST-IV, and architectures |
| US8560307B2 (en) | 2008-01-28 | 2013-10-15 | Qualcomm Incorporated | Systems, methods, and apparatus for context suppression using receivers |
| JP4893657B2 (ja) | 2008-02-29 | 2012-03-07 | ソニー株式会社 | 算術復号装置 |
| KR101221919B1 (ko) | 2008-03-03 | 2013-01-15 | 연세대학교 산학협력단 | 오디오 신호 처리 방법 및 장치 |
| BRPI0906142B1 (pt) | 2008-03-10 | 2020-10-20 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e. V. | dispositivo e método para a manipulação de um sinal de áudio tendo um evento transiente |
| EP2251861B1 (en) * | 2008-03-14 | 2017-11-22 | Panasonic Intellectual Property Corporation of America | Encoding device and method thereof |
| JP5294342B2 (ja) | 2008-04-28 | 2013-09-18 | 公立大学法人大阪府立大学 | 物体認識用画像データベースの作成方法、処理装置および処理用プログラム |
| US7864083B2 (en) | 2008-05-21 | 2011-01-04 | Ocarina Networks, Inc. | Efficient data compression and decompression of numeric sequences |
| MX2011000379A (es) | 2008-07-11 | 2011-02-25 | Ten Forschung Ev Fraunhofer | Codificador de audio y decodificador de audio. |
| PL2346030T3 (pl) * | 2008-07-11 | 2015-03-31 | Fraunhofer Ges Forschung | Koder audio, sposób kodowania sygnału audio oraz program komputerowy |
| US7714754B2 (en) * | 2008-07-14 | 2010-05-11 | Vixs Systems, Inc. | Entropy decoder with pipelined processing and methods for use therewith |
| ES2592416T3 (es) * | 2008-07-17 | 2016-11-30 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Esquema de codificación/decodificación de audio que tiene una derivación conmutable |
| JPWO2010016270A1 (ja) | 2008-08-08 | 2012-01-19 | パナソニック株式会社 | 量子化装置、符号化装置、量子化方法及び符号化方法 |
| US20100088090A1 (en) * | 2008-10-08 | 2010-04-08 | Motorola, Inc. | Arithmetic encoding for celp speech encoders |
| US7932843B2 (en) | 2008-10-17 | 2011-04-26 | Texas Instruments Incorporated | Parallel CABAC decoding for video decompression |
| US7982641B1 (en) | 2008-11-06 | 2011-07-19 | Marvell International Ltd. | Context-based adaptive binary arithmetic coding engine |
| GB2466666B (en) * | 2009-01-06 | 2013-01-23 | Skype | Speech coding |
| KR101622950B1 (ko) | 2009-01-28 | 2016-05-23 | 삼성전자주식회사 | 오디오 신호의 부호화 및 복호화 방법 및 그 장치 |
| US8457975B2 (en) | 2009-01-28 | 2013-06-04 | Fraunhofer-Gesellschaft Zur Foerderung Der Angewandten Forschung E.V. | Audio decoder, audio encoder, methods for decoding and encoding an audio signal and computer program |
| KR20100136890A (ko) * | 2009-06-19 | 2010-12-29 | 삼성전자주식회사 | 컨텍스트 기반의 산술 부호화 장치 및 방법과 산술 복호화 장치 및 방법 |
| EP2446539B1 (en) | 2009-06-23 | 2018-04-11 | Voiceage Corporation | Forward time-domain aliasing cancellation with application in weighted or original signal domain |
| RU2591661C2 (ru) | 2009-10-08 | 2016-07-20 | Фраунхофер-Гезелльшафт цур Фёрдерунг дер ангевандтен Форшунг Е.Ф. | Многорежимный декодировщик аудио сигнала, многорежимный кодировщик аудио сигналов, способы и компьютерные программы с использованием кодирования с линейным предсказанием на основе ограничения шума |
| EP2315358A1 (en) | 2009-10-09 | 2011-04-27 | Thomson Licensing | Method and device for arithmetic encoding or arithmetic decoding |
| BR112012009446B1 (pt) | 2009-10-20 | 2023-03-21 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V | Método e aparelho de armazenamento de dados |
| US8149144B2 (en) * | 2009-12-31 | 2012-04-03 | Motorola Mobility, Inc. | Hybrid arithmetic-combinatorial encoder |
| BR112012017256B1 (pt) * | 2010-01-12 | 2021-08-31 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V | Codificador de áudio, decodificador de áudio, método de codificação e informação de áudio e método de decodificação de uma informação de áudio que utiliza uma tabela hash que descreve tanto valores de estado significativos como limites de intervalo |
| CN102131081A (zh) | 2010-01-13 | 2011-07-20 | 华为技术有限公司 | 混合维度编解码方法和装置 |
| SG187164A1 (en) * | 2010-07-20 | 2013-02-28 | Fraunhofer Ges Forschung | Audio encoder, audio decoder, method for encoding an audio information, method for decoding an audio information and computer program using an optimized hash table |
| WO2012048472A1 (en) | 2010-10-15 | 2012-04-19 | Huawei Technologies Co., Ltd. | Signal analyzer, signal analyzing method, signal synthesizer, signal synthesizing method, windower, transformer and inverse transformer |
| US20120207400A1 (en) * | 2011-02-10 | 2012-08-16 | Hisao Sasai | Image coding method, image coding apparatus, image decoding method, image decoding apparatus, and image coding and decoding apparatus |
| US8170333B2 (en) * | 2011-10-13 | 2012-05-01 | University Of Dayton | Image processing systems employing image compression |
-
2010
- 2010-10-19 BR BR112012009446-7A patent/BR112012009446B1/pt active IP Right Grant
- 2010-10-19 CA CA2778323A patent/CA2778323C/en active Active
- 2010-10-19 CN CN201080058338.2A patent/CN102667922B/zh active Active
- 2010-10-19 PL PL10768018T patent/PL2491552T3/pl unknown
- 2010-10-19 TW TW099135558A patent/TWI426504B/zh active
- 2010-10-19 AU AU2010309820A patent/AU2010309820B2/en active Active
- 2010-10-19 CA CA2778368A patent/CA2778368C/en active Active
- 2010-10-19 CN CN201080058335.9A patent/CN102667921B/zh active Active
- 2010-10-19 BR BR122022013454-8A patent/BR122022013454B1/pt active IP Right Grant
- 2010-10-19 WO PCT/EP2010/065727 patent/WO2011048100A1/en not_active Ceased
- 2010-10-19 ES ES10768019.1T patent/ES2610163T3/es active Active
- 2010-10-19 BR BR122022013482-3A patent/BR122022013482B1/pt active IP Right Grant
- 2010-10-19 MX MX2012004569A patent/MX2012004569A/es active IP Right Grant
- 2010-10-19 MX MX2012004572A patent/MX2012004572A/es active IP Right Grant
- 2010-10-19 EP EP10773017.8A patent/EP2491554B1/en active Active
- 2010-10-19 JP JP2012534667A patent/JP5707410B2/ja active Active
- 2010-10-19 CA CA2778325A patent/CA2778325C/en active Active
- 2010-10-19 KR KR1020127012640A patent/KR101419148B1/ko active Active
- 2010-10-19 PT PT107680191T patent/PT2491553T/pt unknown
- 2010-10-19 WO PCT/EP2010/065726 patent/WO2011048099A1/en not_active Ceased
- 2010-10-19 EP EP10768018.3A patent/EP2491552B1/en active Active
- 2010-10-19 CA CA2907353A patent/CA2907353C/en active Active
- 2010-10-19 MY MYPI2012001732A patent/MY160807A/en unknown
- 2010-10-19 PL PL10768019T patent/PL2491553T3/pl unknown
- 2010-10-19 WO PCT/EP2010/065725 patent/WO2011048098A1/en not_active Ceased
- 2010-10-19 BR BR112012009445-9A patent/BR112012009445B1/pt active IP Right Grant
- 2010-10-19 CN CN201080058342.9A patent/CN102667923B/zh active Active
- 2010-10-19 JP JP2012534668A patent/JP5245014B2/ja active Active
- 2010-10-19 BR BR122022013496-3A patent/BR122022013496B1/pt active IP Right Grant
- 2010-10-19 MX MX2012004564A patent/MX2012004564A/es active IP Right Grant
- 2010-10-19 PL PL10773017T patent/PL2491554T3/pl unknown
- 2010-10-19 ES ES10768018T patent/ES2531013T3/es active Active
- 2010-10-19 EP EP10768019.1A patent/EP2491553B1/en active Active
- 2010-10-19 MY MYPI2012001731A patent/MY160813A/en unknown
- 2010-10-19 RU RU2012122277/08A patent/RU2591663C2/ru active
- 2010-10-19 JP JP2012534669A patent/JP5589084B2/ja active Active
- 2010-10-19 KR KR1020127012845A patent/KR101411780B1/ko active Active
- 2010-10-19 ES ES10773017.8T patent/ES2454020T3/es active Active
- 2010-10-19 TW TW099135555A patent/TWI451403B/zh active
- 2010-10-19 MY MYPI2012001730A patent/MY188408A/en unknown
- 2010-10-19 KR KR1020127012935A patent/KR101419151B1/ko active Active
- 2010-10-19 RU RU2012122278/08A patent/RU2596596C2/ru active
- 2010-10-19 RU RU2012122275/08A patent/RU2605677C2/ru not_active Application Discontinuation
- 2010-10-19 TW TW099135561A patent/TWI430262B/zh active
- 2010-10-20 AR ARP100103832A patent/AR078705A1/es unknown
- 2010-10-20 AR ARP100103834A patent/AR078707A1/es active IP Right Grant
- 2010-10-20 AR ARP100103833A patent/AR078706A1/es unknown
-
2012
- 2012-04-18 US US13/450,014 patent/US8706510B2/en active Active
- 2012-04-19 US US13/450,699 patent/US8612240B2/en active Active
- 2012-04-19 US US13/450,713 patent/US8655669B2/en active Active
- 2012-05-17 ZA ZA2012/03607A patent/ZA201203607B/en unknown
- 2012-05-17 ZA ZA2012/03610A patent/ZA201203610B/en unknown
- 2012-05-17 ZA ZA2012/03609A patent/ZA201203609B/en unknown
-
2013
- 2013-11-18 US US14/083,412 patent/US9978380B2/en active Active
-
2017
- 2017-12-18 US US15/845,616 patent/US11443752B2/en active Active
-
2022
- 2022-08-19 US US17/820,990 patent/US12080300B2/en active Active
-
2024
- 2024-08-20 US US18/810,401 patent/US20240412743A1/en active Pending
- 2024-08-20 US US18/810,318 patent/US20240412740A1/en active Pending
- 2024-08-20 US US18/810,370 patent/US20240412741A1/en active Pending
- 2024-08-20 US US18/810,383 patent/US20240412742A1/en active Pending
Patent Citations (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US7447631B2 (en) * | 2002-06-17 | 2008-11-04 | Dolby Laboratories Licensing Corporation | Audio coding system using spectral hole filling |
| EP1439524B1 (en) * | 2002-07-19 | 2009-04-08 | NEC Corporation | Audio decoding device, decoding method, and program |
| RU2335809C2 (ru) * | 2004-02-13 | 2008-10-10 | Фраунхофер-Гезелльшафт Цур Фердерунг Дер Ангевандтен Форшунг Е.Ф. | Аудиокодирование |
| EP1883067A1 (en) * | 2006-07-24 | 2008-01-30 | Deutsche Thomson-Brandt Gmbh | Method and apparatus for lossless encoding of a source signal, using a lossy encoded data stream and a lossless extension data stream |
| EP2077550A1 (en) * | 2008-01-04 | 2009-07-08 | Dolby Sweden AB | Audio encoder and decoder |
Also Published As
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| RU2591663C2 (ru) | Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая обнаружение группы ранее декодированных спектральных значений | |
| RU2628162C2 (ru) | Аудио кодер, аудио декодер, способ кодирования и декодирования аудио информации и компьютерная программа, определяющая значение поддиапазона контекста на основе нормы ранее декодированных спектральных значений | |
| US9959879B2 (en) | Context-based arithmetic encoding apparatus and method and context-based arithmetic decoding apparatus and method | |
| KR20130054993A (ko) | 오디오 인코더, 오디오 디코더, 오디오 정보를 인코딩하기 위한 방법, 오디오 정보를 디코딩하기 위한 방법 및 최적화된 해시 테이블을 사용하는 컴퓨터 프로그램 | |
| RU2574848C2 (ru) | Аудио кодер, аудио декодер, способ кодирования аудио информации, способ декодирования аудио информации и компьютерная программа, использующая хэш-таблицу, которая описывает значимые значения состояния и границы интервала | |
| AU2010309821B2 (en) | Audio encoder, audio decoder, method for encoding an audio information, method for decoding an audio information and computer program using an iterative interval size reduction | |
| HK1175291B (en) | Audio encoder, audio decoder, method for encoding an audio information, method for decoding an audio information and computer program using an iterative interval size reduction |