KR20150126858A - 엔트로피 변형기 및 방법 - Google Patents
엔트로피 변형기 및 방법 Download PDFInfo
- Publication number
- KR20150126858A KR20150126858A KR1020157024996A KR20157024996A KR20150126858A KR 20150126858 A KR20150126858 A KR 20150126858A KR 1020157024996 A KR1020157024996 A KR 1020157024996A KR 20157024996 A KR20157024996 A KR 20157024996A KR 20150126858 A KR20150126858 A KR 20150126858A
- Authority
- KR
- South Korea
- Prior art keywords
- entropy
- data
- input data
- transformer
- bits
- Prior art date
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/85—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M7/00—Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
- H03M7/30—Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T9/00—Image coding
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M7/00—Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
- H03M7/30—Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
- H03M7/3068—Precoding preceding compression, e.g. Burrows-Wheeler transformation
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M7/00—Conversion of a code where information is represented by a given sequence or number of digits to a code where the same, similar or subset of information is represented by a different sequence or number of digits
- H03M7/30—Compression; Expansion; Suppression of unnecessary data, e.g. redundancy reduction
- H03M7/46—Conversion to or from run-length codes, i.e. by representing the number of consecutive digits, or groups of digits, of the same kind by a code word and a digit indicative of that kind
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/04—Protocols for data compression, e.g. ROHC
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/40—Network security protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/90—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
- H04N19/93—Run-length coding
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Signal Processing (AREA)
- Multimedia (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
제2 엔트로피를 갖는 대응 엔트로피 변형 출력 데이터를 생성하기 위한 제1 엔트로피를 갖는 입력 데이터 비트 스트림을 인코딩 또는 디코딩하도록 동작 가능한 엔트로피 변형기(10, 60)가 제공되는데, 여기서 엔트로피 변형기는 상호 유사 비트들의 그룹들 및 제1 비트의 값을 처리하기 위해 입력 데이터 비트 스트림을 프로세싱하고, 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이를 프로세싱하도록 동작 가능하다. 선택적으로, 엔트로피 변형기(10, 60)는 적어도 하나의 이스케이프 코드(escape code)를 이용함으로써 상호 유사 비트들의 그룹의 하나 이상의 최대 런 길이를 제어하도록 동작 가능하다.
Description
본 발명은 예를 들어, 데이터 압축 및/또는 데이터 압축 해제 목적으로, 입력 데이터를 수신하고, 입력 데이터에 대해 엔트로피가 변형된 대응하는 출력 데이터를 생성하도록 동작 가능한 엔트로피 변형기에 관한 것으로서, 엔트로피 변형기들은, 기계 판독 가능 데이터 저장 매체에 저장되고, 컴퓨팅 하드웨어에서 실행 가능한 전자 하드웨어 및/또는 소프트웨어 제품들을 이용하여 구현 가능하다. 더구나, 본 발명은 또한 입력 데이터에 대해 변형된 정도의 엔트로피를 갖는 대응 출력 데이터를 생성하기 위해 입력 데이터의 엔트로피를 변형하는 방법에 관한 것이다. 게다가, 본 발명은 기계 판독 가능 데이터 저장 매체에 기록된 소프트웨어 제품들에 관한 것으로서, 여기서 소프트웨어 제품들은 후술하는 방법들을 실행하기 위한 컴퓨팅 하드웨어에서 실행 가능하다. 예를 들어, 엔트로피 변형기들은 데이터 통신 시스템들 및 데이터 공급 시스템들, 예를 들어 미디어 공급 시스템들의 컴포넌트 부분들로서 사용 가능하다.
개괄적으로 설명하면, 정보 이론에서, 엔트로피(entropy)는 랜덤 변수에서의 불확실성의 측정치로서, 정보 시스템, 예를 들어 데이터 통신 시스템뿐 아니라 열역학에서와 같이 물리적 연속 시스템에 관한 것이다. 더구나, 데이터 통신 시스템의 상황에서, 엔트로피는 더 적절하게는 샤논 엔트로피(Shannon entropy)라고 지칭되며, 참조로서 여기에 통합된 Claude E. Shannon의 1948년 과학 논문 "A Mathematical Theory of Communication"를 참조하고, 샤논 엔트로피는 소정의 메시지에 포함된 예측 정보 값을 정량화하기 위해 사용될 수 있다. 더구나, 샤논 엔트로피는 비트들뿐 아니라 내트(nat) 및 반(ban)의 측면에서 표현 가능하다.
샤논 엔트로피는 임의의 통신의 최선의 가능한 무손실 인코딩 또는 압축에 관한 절대적 한계를 제공하는데, 이때 소정의 통신이, 독립적이고 동일하게 분포된 랜덤 변수들의 시퀀스로서 용이하게 나타낼 수 있다고 가정한다. 더구나, 샤논의 이론은, 소정의 알파벳으로 된 소정의 메시지를 인코딩하기 위해 가장 짧은 가능한 표현의 평균 길이(L)가 그 알파벳에 존재하는 심볼 N의 개수의 로그에 의해 나누어진 엔트로피(E)라는 것을 확인하였는데, 즉 수학식 1에 정의된 바와 같다.
이로 인해, 엔트로피(E)는 예측 불가능성 또는 정보 내용의 척도이다. 무손실 데이터 압축 방법에서, 대응하는 입력 데이터에 이 방법을 적용함으로써 생성되는 압축 출력 데이터는 입력 데이터와 유사한 양의 정보를 갖지만, 출력 데이터는 입력 데이터에 비해 더 적은 데이터 비트를 포함한다. 그 결과, 압축 출력 데이터는 더 적은 정보 리던던시(redundancy of information)를 포함하기 때문에 더 예측 불가능하다.
샤논의 이론(Shannon's theory)은 공지된 데이터 인코딩 장치의 설계 시에 고려되어 왔다. 예를 들어, 공개된 국제 특허 출원 제WO2010/050157A1호(PCT/JP2009/005548, "Image encoding apparatus, image encoding method, and image encoding program", 출원인 - Thomson Licensing)에는, 이미지 인코딩 장치, 이미지 인코딩 방법, 및 이미지 인코딩 프로그램이 기술되어 있는데, 이들은 인코딩 효율을 낮추지 않고 전체적으로 이미지의 이미지 품질을 균일하게 하도록 동작 가능하며, 고속으로 동작 가능하고, 슬라이스 구조를 변경하지 않고서 매크로블록 셔플링(macroblock shuffling)을 수행함으로써 회로 스케일의 사이즈를 축소시킬 수 있다. 더구나,
(i) 이미지 내의 각각의 위치들로부터 이미지 데이터를 구성하는 복수의 매크로블록을 수집 및 셔플링하는 셔플링 부분;
(ii) 셔플링 부분에 의해 수집 및 셔플링된 복수의 매크로블록에 대한 공간 주파수 변환 및 엔트로피 인코딩을 수행하는 인코딩 부분; 및
(iii) 인코딩이 실행된 이후 복수의 매크로블록의 레이트를 조정하도록 인코딩 부분을 제어하는 레이트 제어 부분을 포함하는 이미지 인코딩 장치 또한 제공된다.
데이터의 타입과 무관하게, 데이터는 하나의 공간 위치로부터 다른 위치로 이동하는 경우 데이터 저장 공간 및 통신 네트워크 용량의 대역폭을 필요로 한다. 이러한 대역폭은 실제로 에너지의 활용 및 통신 인프라구조의 투자에 대응한다. 데이터 통신 양이 장래에 증가할 것으로 예측됨에 따라, 더 많은 데이터 저장 공간 및 더 많은 통신 시스템 용량이 필요할 것이고, 종종 더 많은 에너지가 필요할 것이다. 동시대의 인터넷에서, 종종 다수의 사본에 막대한 양의 데이터를 저장하고 있다. 이로 인해, 데이터를 압축할 수 있는 임의의 접근법은, 특히 이러한 압축이 무손실인 경우 잠재적 그리고 기술적 경제적 측면에서 크게 유리하다. 현재, 데이터 세트를 압축하기 위해 데이터 세트 내의 엔트로피를 감소시키기 위한 여러 공지의 방법들이 존재한다. 더구나, 데이터 세트, 예를 들어 델타 코딩(Delta coding) 및 런 길이 인코딩(Run-Length-Encoding, RLE)에 존재하는 엔트로피를 변형하는 공지의 방법들이 존재하지만, 더 효과적인 데이터 압축을 제공하는 새로운 방법들이 여전히 요구된다.
이에 따라, 소정의 데이터에 존재하는 엔트로피를 감소시킴으로써 소정의 데이터를 압축하기 위해 채택 가능한 여러 상이한 압축 방법들, 예를 들어 전술한 RLE 코딩, 전술한 VLC 코딩, 허프만 코딩(Huffman coding), 델타 코딩(Delta coding), 산술 코딩(Arithmetic coding) 및 레인지 코딩(Range coding)이 존재한다. 이들 방법은 통상적으로 알파벳, 숫자, 바이트, 및 워드를 압축하도록 설계된다. 그러나 이러한 방법들은 개별 비트를 압축하기에 특히 적합하지 않고, 이러한 이유로 이상적으로, 비트별 방식으로 변할 수 있는 데이터, 예를 들어, 데이터 비트 스트림들을 압축하는데 적합하지 않다.
종래의 RLE 코딩의 경우, 소정의 값( 비트), 또는 그 값의 2배( 비트), 그 다음 다수의 유사 값( 비트들)이 저장된다. RLE는 선택적으로 적용될 수 있는데, 예를 들어, 즉 그 코딩은 다수의 유사한 값들에 대해 공지의 비트량을 포함하는 런(run)을 코딩하기 위해서만 예약될 수 있다. RLE의 이러한 선택적 적용은, 각각의 새로운 런을 가진 소정의 데이터 스트림에 동일한 값이 한번씩 또는 두번씩 다시 포함되는 것을 필요로 한다. 그러나 데이터의 타입과 무관하게, 데이터 세트에서의 엔트리를 감소시키는, 데이터 압축에 대한 더 나은 접근법들이 현재 요구된다.
본 발명의 제1 목적은 예를 들어, 개선된 데이터 압축을 제공하기 위해 개선된 엔트로피 변형기를 제공하는 것이다.
본 발명의 제2 목적은 예를 들어, 개선된 데이터 압축을 제공하기 위해 개선된 엔트로피 변형 방법을 제공하는 것이다.
본 발명의 제1 양태에 따르면, 제1항에 청구된 바와 같은 엔트로피 변형기가 제공되는데, 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D2)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D1)의 스트림을 인코딩하도록 동작 가능한 엔트로피 변형기가 제공되는데,
(a) 엔트로피 변형기(10)는 출력 데이터(D2)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 포함하기 위해 출력 데이터(D2)를 생성하도록 동작 가능하며;
(b) 출력 데이터(D2)는 입력 데이터 비트(D1)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 데이터를 더 포함하고, 상호 유사 비트들의 런 길이들은 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되며;
(c) 최대 런 길이 값을 실질적으로 초과하는 입력 데이터(D1)에서의 런 길이들의 하나 이상의 생성은 출력 데이터(D2)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시된다.
본 발명은 데이터의 런 길이 표현의 선택적 사용으로, 향상된 엔트로피 변형, 예를 들어, 향상된 데이터 압축을 제공할 수 있다는 점에서 이점을 갖는다.
선택적으로, 엔트로피 변형기는 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이가 복수의 이스케이프 코드에 의해 제어되도록 구현된다.
채택된 일 종류의 이스케이프 코드 솔루션은 최대 런 길이 값, 및 소정 양의 유사 비트들이 연속된다는 표시를 이용한다. 이러한 종류의 솔루션에서, 모든 심볼들은 하나의 데이터 스트림으로서 코딩될 수 있다. 다른 종류의 이스케이프 코드는 코딩된 심볼들과 별도의 여러 상이한 솔루션들의 활용을 가능하게 하고, 최대 런 길이 값보다 큰 유사 비트 값의 연속 량을 나타낸다. 이러한 종류의 솔루션은 2개의 별도의 스트림으로서 처리되거나, 그 수를 나타내는 임의의 값이 최대 런보다 더 크지 않도록 설계될 수 있으며, 이로써 이들 솔루션은 또한 다른 심볼들의 동일한 스트림을 이용하여 코딩될 수 있다. 또한, 다른 이스케이프 방법들이 선택적으로 채택된다.
선택적으로, 엔트로피 변형기는 입력 데이터(D1)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 최대 런 길이를 이용하여 입력 데이터(D1)의 스트림을 처리하도록 동작 가능하다.
선택적으로, 엔트로피 변형기는, 압축 데이터(D3)를 생성하기 위한 하나 이상의 코딩 배열들에서의 후속 압축을 위해 입력 데이터(D1)를 출력 데이터(D2)로 포맷화하기 위한 데이터 사전 프로세서로서 기능하도록 동작 가능하다.
선택적으로, 적어도 하나의 이스케이프 코드는 엔트로피 변형기에 의해 생성된 출력 데이터(D2) 내에 "0" 값으로서 구현되도록 엔트로피 변형기가 구현된다.
선택적으로, 하나 이상의 코딩 배열들은 오델타(ODelta) 코더, RLE 코딩, VLC 코딩, 허프만 코딩, 델타 코딩, 산술 코딩, 레인지 코딩 중 하나 이상을 포함한다.
선택적으로, 엔트로피 변형기는 별도로 프로세싱되는 복수의 부분에서 입력 데이터 비트(D1)의 스트림을 처리하도록 동작 가능하다. 추가 선택적으로, 엔트로피 변형기는 시간 병렬 방식으로, 즉 병렬 실행을 통해 복수의 부분들을 처리하도록 동작 가능하다. 추가 선택적으로, 엔트로피 변형기는 복수의 부분 중 하나 이상에 대해 상호 상이한 최대 런 길이들을 이용함으로써 복수의 부분들을 처리하도록 동작 가능하다.
제1 비트의 정보는 자기 자신의 데이터 스트림으로 인코딩되거나, 런 길이 정보를 이용하여 동일한 데이터 스트림으로 인코딩될 수 있으며, 사용된 코딩 방법의 정보와 함께 제1 비트의 정보가 포함될 수 있음은 물론이다.
선택적으로, 엔트로피 변형기는 입력 데이터(D1)의 스트림을 압축하여 엔트로피 변형 출력(D2, D3)을 생성하기 위한 인코더로서 기능하도록 구현된다.
선택적으로, 엔트로피 변형기는 입력 데이터(D1)에 존재하는 비트 스트링을 엔트로피 변형 출력 데이터(D2)에 존재하는 심볼들로 변환하는 것을 보조하도록 동작 가능하다.
선택적으로, 엔트로피 변형기는 컴퓨팅 하드웨어를 포함하고, 컴퓨팅 하드웨어는 입력 데이터(D1)의 스트림을 프로세싱하여 출력 데이터(D2)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능하다.
본 발명의 제2 양태에 따르면, 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D5)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D3 또는 D4)의 스트림을 디코딩하도록 동작 가능한 엔트로피 변형기가 제공되는데,
(a) 엔트로피 변형기(60)는 입력 데이터(D3 또는 D4)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 이용함으로써 입력 데이터(D3 또는 D4)를 프로세싱하도록 동작 가능하며;
(b) 엔트로피 변형기(60)는 입력 데이터 비트(D3 또는 D4)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 입력 데이터(D3 또는 D4)에 존재하는 데이터를 프로세싱하도록 동작 가능하며, 상호 유사 비트의 최대 길이는 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되며;
(c) 엔트로피 변형기(60)는 입력 데이터(D3 또는 D4)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시되는 것인, 최대 런 길이 값을 실질적으로 초과하는 입력 데이터(D3 또는 D4)에서의 런 길이들의 하나 이상의 생성을 검출하도록 동작 가능하다.
선택적으로, 엔트로피 변형기는 적어도 하나의 이스케이프 코드를 이용함으로써 상호 유사 비트들의 그룹의 하나 이상의 최대 런 길이를 프로세싱하도록 동작 가능하다. 추가 선택적으로, 엔트로피 변형기는 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이가 복수의 이스케이프 코드를 이용함으로써 프로세싱되도록 구현된다.
채택된 일 종류의 이스케이프 코드 솔루션은 최대 런 길이 값, 및 소정 양의 유사 비트들이 연속된다는 표시를 이용한다. 이러한 종류의 솔루션에서, 모든 심볼들은 하나의 데이터 스트림으로서 코딩될 수 있으며, 마찬가지로 하나의 데이터 스트림으로 디코딩된다. 다른 종류의 이스케이프 코드는 코딩된 심볼들과 별도의 여러 상이한 솔루션들의 활용을 가능하게 하고, 최대 런 길이 값보다 큰 유사 비트 값의 연속 량을 나타낸다. 이러한 종류의 솔루션은 2개의 별도의 스트림으로서 처리되거나, 그 수를 나타내는 임의의 값이 최대 런보다 더 크지 않도록 설계될 수 있으며, 이로써 이들 솔루션은 또한 다른 심볼들의 동일한 스트림을 이용하여 코딩될 수 있다. 또한, 다른 이스케이프 방법들이 선택적으로 채택된다.
선택적으로, 엔트로피 변형기는 입력 데이터(D3 또는 D4)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 최대 런 길이를 이용하여 입력 데이터(D3 또는 D4)의 스트림을 처리하도록 동작 가능하다.
선택적으로, 엔트로피 변형기는 데이터 비트 시퀀스와 별도로 입력 데이터(D3 또는 D4)의 스트림에서 제1 비트 값의 정보를 처리하도록 동작 가능하다. 추가 선택적으로, 엔트로피 변형기는 연속적인 유사 비트들의 양을 나타내는 데이터 값들의 시퀀스에 관해 별도로 인코딩되는 것으로서 제1 비트의 값을 처리하도록 동작 가능하다. 추가 선택적으로, 적어도 하나의 이스케이프 코드가 엔트로피 변형기 내에 "0" 값으로서 구현되도록 엔트로피 변형기가 구현된다.
선택적으로, 엔트로피 변형기는 입력 데이터(D3 또는 D4)에 존재하는 데이터 요소들을 디코딩하고, 디코딩된 비트 스트림으로서 출력 데이터(D5)를 생성하도록 인버스 엔트로피 변형을 적용하도록 동작 가능하다.
선택적으로, 엔트로피 변형기는 입력 데이터 비트(D3)의 스트림을 처리하기 위한 하나 이상의 코딩 배열과 함께 사후 프로세싱하는데 활용되며, 하나 이상의 코딩 배열들은 오델타 코딩, RLE 코딩, VLC 코딩, 허프만 코딩, 델타 코딩, 산술 코딩, 레인지 코딩 중 하나 이상을 포함한다.
선택적으로, 엔트로피 변형기는 별도로 인코딩 또는 디코딩되는 복수의 부분에서 입력 데이터 비트(D3 또는 D4)의 스트림을 처리하도록 동작 가능하다. 추가 선택적으로, 엔트로피 변형기는 시간 병렬 방식으로, 즉 병렬 실행을 통해 복수의 부분들을 처리하도록 동작 가능하다. 추가 선택적으로, 엔트로피 변형기는 복수의 부분 중 하나 이상에 대해 상호 상이한 최대 런 길이들을 이용함으로써 복수의 부분들을 처리하도록 동작 가능하다.
선택적으로, 엔트로피 변형기는 엔트로피 변형된 출력(D5)을 생성하기 위해 디코딩한 이후 입력 데이터(D3 또는 D4)의 스트림을 엔트로피 변형하기 위한 사후 프로세서로서 기능하도록 구현된다.
선택적으로, 엔트로피 변형기는 입력 데이터(D3 또는 D4)에 존재하는 심볼들을 출력 데이터(D5)에 존재하는 비트 스트링으로 변환하는 것을 보조하도록 동작 가능하다.
선택적으로, 엔트로피 변형기는 컴퓨팅 하드웨어를 포함하고, 컴퓨팅 하드웨어는 입력 데이터(D3 또는 D4)의 스트림을 프로세싱하여 출력 데이터(D5)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능하다.
본 발명의 제3 양태에 따르면, 엔트로피 변형기를 이용하여 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D2)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D1)의 스트림을 인코딩하는 방법이 제공되는데, 이 방법은,
(a) 출력 데이터(D2)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 포함하기 위해 엔트로피 변형기(10)를 동작시켜서 출력 데이터(D2)를 생성하는 단계;
(b) 출력 데이터(D2)에, 입력 데이터 비트(D1)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 데이터를 더 포함시키는 단계로서, 상호 유사 비트들의 런 길이들은 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되는 것인 상기 단계; 및
(c) 최대 런 길이 값을 실질적으로 초과하는 입력 데이터(D1)에서의 런 길이들의 하나 이상의 생성을 출력 데이터(D2)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시하는 단계를 포함한다.
선택적으로, 그 방법은 적어도 하나의 이스케이프 코드를 이용함으로써 엔트로피 변형기를 사용하여, 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이를 제어하는 단계를 포함한다. 추가 선택적으로, 그 방법은 복수의 이스케이프 코드를 이용하여 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이를 제어하는 단계를 포함한다. 추가 선택적으로, 그 방법은 입력 데이터(D1)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 최대 런 길이를 이용함으로써 엔트로피 변형기를 사용하여 입력 데이터(D1)의 스트림을 처리하는 단계를 포함한다.
선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 데이터 비트 시퀀스와 별도로 입력 데이터(D1)의 스트림에서 제1 비트의 값의 정보를 처리하는 단계를 포함한다. 추가 선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 유사 비트들의 연속 양을 나타내는 데이터 값들의 시퀀스에 관해 별도로 인코딩되는 것으로서 제1 비트의 값을 처리하는 단계를 포함한다.
선택적으로, 그 방법은 적어도 하나의 이스케이프 코드가 엔트로피 변형기 내에 "0" 값으로서 구현되도록 구현된다.
선택적으로, 그 방법은 입력 데이터 비트(D1)의 스트림을 처리하기 위한 하나 이상의 코딩 배열과 함께 사후 프로세싱하기 위해 엔트로피 변형기를 사용하는 단계를 포함하며, 하나 이상의 코딩 배열들은 오델타 코딩, RLE 코딩, VLC 코딩, 허프만 코딩, 델타 코딩, 산술 코딩, 레인지 코딩 중 하나 이상을 포함한다.
선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 별도로 인코딩 또는 디코딩되는 복수의 부분에서 입력 데이터 비트(D1)의 스트림을 처리하는 단계를 포함한다.
선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 시간 병렬 방식으로, 즉 병렬 실행을 통해 복수의 부분들을 처리하는 단계를 포함한다.
선택적으로, 그 방법은 복수의 부분 중 하나 이상에 대해 상호 상이한 최대 런 길이들을 이용함으로써 엔트로피 변형기를 사용하여 복수의 부분들을 처리하는 단계를 포함한다.
선택적으로, 그 방법은 입력 데이터(D1)의 스트림을 압축하여 엔트로피 변형 출력(D2, D3)을 생성하기 위한 인코더로서 기능하도록 엔트로피 변형기를 구현하는 단계를 포함한다. 추가 선택적으로, 그 방법은 엔트로피 변형기를 사용하여 입력 데이터(D1)에 존재하는 비트 스트링을 엔트로피 변형 출력 데이터(D2)에 존재하는 심볼들로 변환하는 것을 보조하는 단계를 포함한다. 추가 선택적으로, 그 방법은 컴퓨팅 하드웨어를 포함하도록 엔트로피 변형기를 구현하는 단계를 포함하고, 여기서 컴퓨팅 하드웨어는 입력 데이터(D1)의 스트림을 프로세싱하여 출력 데이터(D2)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능하다.
본 발명의 제4 양태에 따르면, 엔트로피 변형기를 사용하여, 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D5)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D3 또는 D4)의 스트림을 디코딩하는 방법이 제공되는데, 이 방법은,
(a) 입력 데이터(D3 또는 D3)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 이용함으로써 엔트로피 변형기(60)를 사용하여 입력 데이터(D3 또는 D4)를 프로세싱하는 단계;
(b) 엔트로피 변형기(60)를 사용하여, 입력 데이터 비트(D3 또는 D4)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 입력 데이터(D3 또는 D4)에 존재하는 데이터를 프로세싱하는 단계로서, 상호 유사 비트들의 런 길이들은 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되는 것인 상기 단계; 및
(c) 엔트로피 변형기(60)를 사용하여, 입력 데이터(D3 또는 D4)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시되는 것인, 최대 런 길이 값을 실질적으로 초과하는 입력 데이터(D1)에서의 런 길이들의 하나 이상의 생성을 검출하는 단계를 포함한다.
선택적으로, 그 방법은 적어도 하나의 이스케이프 코드를 이용함으로써 엔트로피 변형기를 사용하여, 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이를 프로세싱하는 단계를 포함한다. 추가 선택적으로, 그 방법은 복수의 이스케이프 코드를 이용함으로써 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이를 프로세싱하는 단계를 포함한다.
선택적으로, 그 방법은 입력 데이터(D3 또는 D4)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 최대 런 길이를 이용함으로써 엔트로피 변형기를 사용하여 입력 데이터(D3 또는 D4)의 스트림을 처리하는 단계를 포함한다.
선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 데이터 비트 시퀀스와 별도로 입력 데이터(D3 또는 D4)의 스트림에서 제1 비트의 값의 정보를 처리하는 단계를 포함한다. 추가 선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 연속적인 유사 비트들의 양을 나타내는 데이터 값들의 시퀀스에 관해 별도로 인코딩되는 바와 같이 제1 비트의 값을 처리하는 단계를 포함한다. 추가 선택적으로, 그 방법은 적어도 하나의 이스케이프 코드가 엔트로피 변형기 내에 "0" 값으로서 구현되도록 구현된다.
선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 입력 데이터(D3 또는 D4)에 존재하는 데이터 요소들을 디코딩하고, 디코딩된 비트 스트림으로서 출력 데이터(D5)를 생성하도록 인버스 엔트로피 변형을 적용하는 단계를 포함한다.
선택적으로, 그 방법은 입력 데이터 비트(D3)의 스트림을 처리하기 위한 하나 이상의 코딩 배열과 함께 사후 프로세싱하기 위해 엔트로피 변형기를 사용하는 단계를 포함하며, 하나 이상의 코딩 배열들은 오델타 코딩, RLE 코딩, VLC 코딩, 허프만 코딩, 델타 코딩, 산술 코딩, 레인지 코딩 중 하나 이상을 포함한다.
선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 별도로 프로세싱되는 복수의 부분에서 입력 데이터 비트(D3 또는 D4)의 스트림을 처리하는 단계를 포함한다. 추가 선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 시간 병렬 방식으로, 즉 병렬 실행을 통해 복수의 부분들을 처리하는 단계를 포함한다.
디코더는 런 길이 정보를 이용하여 자신의 데이터 스트림 또는 동일한 데이터 스트림으로부터 제1 비트(값)의 정보를 얻거나, 이 정보는 사용된 코딩 배열(들)의 정보와 함께 포함될 수 있음은 물론이다. 선택적으로, 그 방법은 복수의 부분 중 하나 이상에 대해 상호 상이한 최대 런 길이들을 이용함으로써 엔트로피 변형기를 사용하여 복수의 부분들을 처리하는 단계를 포함한다.
선택적으로, 그 방법은 입력 데이터(D3 또는 D4)의 스트림을 압축 해제하여 엔트로피 변형 출력(D5)을 생성하기 위한 디코더로서 기능하도록 상기 엔트로피 변형기를 사용하는 단계를 포함한다.
선택적으로, 그 방법은 엔트로피 변형기를 사용하여, 입력 데이터(D3 또는 D4)에 존재하는 심볼들을 출력 데이터(D5)에 존재하는 비트 스트링으로 변환하는 것을 보조하는 단계를 포함한다.
선택적으로, 그 방법은 컴퓨팅 하드웨어를 포함하도록 엔트로피 변형기를 구현하는 단계를 포함하고, 컴퓨팅 하드웨어는 입력 데이터(D3 또는 D4)의 스트림을 프로세싱하여 출력 데이터(D5)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능하다.
본 발명의 제5 양태에 따르면, 기계 판독 가능 데이터 저장 매체에 기록된 소프트웨어 제품이 제공되는데, 여기서 소프트웨어 제품은 본 발명의 제3 양태에 따른 방법을 실행하기 위한 컴퓨팅 하드웨어에서 실행 가능하다.
본 발명의 제6 양태에 따르면, 기계 판독 가능 데이터 저장 매체에 기록된 소프트웨어 제품이 제공되는데, 여기서 소프트웨어 제품은 본 발명의 제4 양태에 따른 방법을 실행하기 위한 컴퓨팅 하드웨어에서 실행 가능하다.
본 발명의 특징들이 첨부된 청구범위에 의해 정의된 바와 같이 본 발명의 범위로부터 벗어나지 않고 다양한 조합으로 용이하게 결합될 수 있음은 물론이다.
본 발명의 실시예들은 단지 일례로서 다음의 첨부 도면을 참조하여 이하 설명될 것이다.
도 1은 본 발명에 따른 엔트로피 변형기(entropy modifier)들을 포함하는 코덱 시스템의 예시이다.
첨부 도면에서, 밑줄 있는 번호는 밑줄 있는 번호가 위치하는 아이템 또는 밑줄 있는 번호가 인접한 아이템을 나타내기 위해 채택된다. 밑줄 없는 번호는 밑줄 없는 번호를 아이템에 링크하는 라인에 의해 식별된 아이템에 관한 것이다. 번호가 밑줄 없이 관련 화살표에 의해 수반되는 경우, 밑줄 없는 번호는 화살표가 가리키는 일반적인 아이템을 식별하기 위해 사용된다.
도 1은 본 발명에 따른 엔트로피 변형기(entropy modifier)들을 포함하는 코덱 시스템의 예시이다.
첨부 도면에서, 밑줄 있는 번호는 밑줄 있는 번호가 위치하는 아이템 또는 밑줄 있는 번호가 인접한 아이템을 나타내기 위해 채택된다. 밑줄 없는 번호는 밑줄 없는 번호를 아이템에 링크하는 라인에 의해 식별된 아이템에 관한 것이다. 번호가 밑줄 없이 관련 화살표에 의해 수반되는 경우, 밑줄 없는 번호는 화살표가 가리키는 일반적인 아이템을 식별하기 위해 사용된다.
개괄적으로 설명하면, 본 발명은 엔트로피 변형기에 관한 것이다. 도 1을 참조하면, 입력 데이터(D1)는 입력 데이터를 변환하여 대응하는 변환 데이터(D2)를 생성하는 제1 엔트로피 변형기(10)에 공급되고, 선택적으로 데이터(D2)는 제1 엔트로피 변형기(10)에 채택된 변환의 특성에 따라 데이터(D1)에 대해 서로 사이즈가 상이하고, 데이터(D1)에 비해 감소된 엔트로피를 갖는다. 선택적으로 데이터(D2)는 인코딩 스테이지(20)를 통해 더 코딩되어 최종 인코딩 출력 데이터(D3)를 생성하는데, 인코딩 스테이지(20)가 채택되는 않은 경우, 데이터(D2 및 D3)는 서로 유사하다. 인코딩된 출력 데이터(D3)는 데이터 메모리(30)에 저장되고/되거나 데이터 통신 네트워크(40)를 통해 송신된다. 더구나, 데이터(D4)가 데이터(D2)와 실질적으로 유사하도록 전술한 인코딩 스테이지(20)가 채택되는 경우, 출력 데이터(D3)는 제2 엔트로피 변형기(60)에 직접 전달되거나, 디코딩 스테이지(50)를 통해 제2 엔트로피 변형기(60)에 전달된다. 제2 엔트로피 변형기(60)는 입력 데이터와 실질적으로 유사한 디코딩 출력 데이터(D5)를 생성한다. 이로써, 제1 엔트로피 변형기(10) 및 제2 엔트로피 변형기(60)는 예를 들어 코덱 구성에서와 같이, 상호 인버스(inverse) 엔트로피 변형 동작들을 수행한다.
선택적으로, 제1 및 제2 엔트로피 변형기(10, 60)는 고속 엔트로피 변형, 예를 들어, 고속 인코딩 및/또는 디코딩을 달성하기 위한 복수의 병렬 데이터 스트림으로서 데이터를 프로세싱하도록 동작 가능하다. 대량의 데이터, 예를 들어, 데이터 서버들, 예를 들어 케이블 TV 서비스들을 제공하는 인터넷 기반 서버들부터의 스트리밍 비디오 콘텐츠를 처리하는 경우, 복수의 병렬 데이터 스트림을 이용하는 이러한 고속 프로세싱이 유리하다.
그러므로 제1 엔트로피 변형기(10)는 데이터(D1)에 존재하는 비트 스트림을 소비하고, 그로부터 입력 데이터(D1)의 엔트로피에 비해 엔트로피가 감소된 데이터 요소들을 생성한다. 선택적으로, 이들 변형된 데이터 요소는 가변 길이 코딩(Variable-Length-Coding, VLC), 허프만 코딩(Huffman coding), 산술 코딩, 레인지 코딩, 런 길이 인코딩(Run-Length-Encoding, RLE) 등과 같은 방법들을 채택함으로써 인코딩 스테이지(30)에서 추가로 인코딩된다. 제1 엔트로피 변형기(10) 내에서 실행되는 엔트로피 변형은 가역적이고, 바람직하게는 무손실적이며, 필요한 부분만 약간 변형되어 제2 엔트로피 변형기(6)에서도 실행된다. 게다가, 제1 엔트로피 변형기(10) 내에서 실행되는 엔트로피 변형은 비트 값의 매 변경 이후 연속적인 유사 비트의 양을 포함하는 새로운 데이터 요소를 적어도 저장한다.
전술한 바와 같이 엔트로피 감소를 실행할 때, 임의의 소정의 시퀀스로 제1 비트의 표시가 제공되어야 한다. 게다가, 데이터 요소들이 압축될 때 데이터 요소들을 나타내기 위한 제한적 수의 코드들, 즉 최대 런(maximum run)이 채택되게 하는 이스케이프 코드가 제공되어야 한다. 선택적으로, 이스케이프 코드는 디지트 "0"에 의해 표현되고, 이스케이프 코드는 데이터 요소가 나타낼 수 있는 최고 값, 즉 최대 런을 표시하고, 그리고 비트 값이 계속되는 정보를 추가적으로 전달한다. 바람직하게는, 본 발명의 실시예들을 구현하는 경우, 최대 비트 런에 대응하는 하나 이상의 코드는 데이터 및 그 특성에 따라 달라지는데, 즉 최대 런에 대응하는 하나 이상의 코드는 압축될 데이터에 따라 적응적으로 달라진다. 선택적으로, 엔트로피 변형기(10, 60)는 사전 및/또는 사후 프로세싱 방법들, 예를 들어 1 비트 데이터에 대해 동작하는 오델타 오퍼레이터(ODelta operator)를 활용한다. 그러나 엔트로피 변형기들(10, 60)의 경우, 이를 통해 프로세싱되는 데이터는 임의의 종류, 예를 들어, 이미지 데이터, 비디오 데이터, 오디오 데이터, 참조 데이터, 마스크들, 분할 비트들, 부호 비트들, 및 압축 데이터, 즉 비트로 프로세싱될 수 있는 임의의 부류의 데이터일 수 있다. 선택적으로, 임의의 데이터의 바이트 또는 워드들이 비트들을 포함하는 스트림으로 삽입될 수 있고, 엔트로피 변형기(10, 60)를 통해 프로세싱될 수 있다. 다음으로, "엔트로피 변형기" 및 "인버스 엔트로피 변형기"는 각각 EM 및 IEM으로 축약될 것이며, 즉 제1 및 제2 엔트로피 변형기(10, 60)를 통해 실행되는 데이터 압축 및 데이터 압축 해제를 제공하는데 사용하기 위한 것이다.
선택적으로, 엔트로피 변형기(10, 60)는 본 발명에 따른 방법들을 구현하기 위한 기계 판독 가능 데이터 저장 매체(90)에 기록된 하나 이상의 소프트웨어 제품(80)을 실행하도록 동작 가능한 컴퓨팅 하드웨어(CPU; 70)를 이용하여 구현된다.
이하, 본 발명의 실시예들에 대해 더 상세히 설명할 것이다. 엔트로피 변형기(10, 60)는 예를 들어, 데이터 비트 스트림에 존재하는 0 또는 1의 최대 런 개수를 정의하는 하나의 파라미터를 채택한다. 게다가, 엔트로피 변형기(10, 60)는 또한 비트 스트림 내의 비트들의 런이 비트 스트림 내의 최대 런보다 더 큰 경우에 사용되는 이스케이프 요소를 채택한다. 바람직하게는, 최대 런 길이(L)는 다음의 시리즈에서 하나 이상으로 설정된다.
여기서, n은 n = 2, 3,...의 값을 갖는 정수이다.
이는 시리즈 L = 3, 7, 15, 31에 대응하지만, 바람직하게는 1보다 큰 임의의 수이다. 바람직하게는, 이스케이프 요소는 "0"의 값으로서 선택되는데, 그 이유는 복수의 제로(0) 유사 비트가 본 발명을 구현할 때 가능하지 않기 때문이다. 유사 비트의 개수가 전술한 바와 같이 1 카운트씩 감소되면, 바람직하게는 이스케이프 요소가 최대 런인 것이 이해될 것이다. 엔트로피 변형기(10)는 비트 스트림의 압축을 바람직한 경우, 그 스트림에서의 제1 비트가 공지될 것을 요구하며, 이로써 대응하는 압축 비트 스트림이 후속으로 디코딩, 즉 엔트로피 변형기(60)에서 가역적으로 압축 해제될 수 있다.
본 발명의 실시예들을 더 설명하기 위해, 이하 일례가 설명될 것이다. 이하, 본 발명에 따른 엔트로피 인코딩이, 최대 런 길이가 3 비트이고 이스케이프 코드가 "0"인 경우에 기능하는 방식의 제1 예시가 제시된다.
원 비트 스트림(original stream of bits)은 다음과 같다.
0 1 1 0 0 1 1 1 1 1 1 1 0 0 0 0 1 0 0 0 1 1 1 1 1 1
이 스트림에는 총 26개의 비트가 포함되는데 16개의 1과 10개의 0이 있다.
원 비트 스트림과 관련된 엔트로피(E)는 다음과 같이 계산된다.
수학식 3으로부터, 이러한 관련 엔트로피(E)를 갖는 원 비트 스트림을 인코딩하는데 필요한 비트의 최소 개수(MB)는 다음과 같이 소스 코딩 이론에 따라 계산 가능하다.
전술한 원 비트 스트림은 대응하는 코드 시퀀스를 생성하기 위해 본 발명에 따른 방법을 적용함으로써 인코딩 가능하다.
제1 비트 값은 "0"이고, 연속적인 유사 비트들(= 엔트로피 변형 심볼들)의 양은 다음과 같다.
1 2 2 7 4 1 3 6
이스케이프 심볼 "0"이, 상이한 심볼의 개수를 0(이스케이프) 내지 3(최대 런 길이)인 4개의 상이한 값으로 한정하기 위해 사용되고, 또한 제1 비트 값이 제1 심볼로서 스트림에 추가되면, 다음과 같다.
0 1 2 2 0 0 1 0 1 1 3 0 3
이 스트림에는 총 13개의 코드가 포함되는데, 5개의 0, 4개의 1, 2개의 2, 및 2개의 3이 존재한다.
이러한 코드 스트림과 관련된 엔트로피(E)는 다음과 같이 계산 가능하다.
이로부터, 무손실 방식으로 이러한 엔트로피(E)를 표현하기 위해 비트의 최소 개수(MB)는 다음과 같이 계산 가능하다.
이 예시로부터, 일련의 코드에서의 엔트로피가 원 비트 스트림보다 작고, 더 적은 비트들이 일련의 코드를 나타내는데 필요함은 물론이다. 선택적으로, 엔트로피 변형된 일련의 코드는 표 1에서 개요로 나타내는 바와 같이 생성된다.
표 1: 엔트로피 변형 코드들의 인버스
표 1은 단지 일례일 뿐이며, 본 발명의 실시예들의 구현은 여러 대체적인 예시들을 생성할 수 있다. 예를 들어, 다른 최대 런 값들 및 다른 이스케이프 코드들이 채택될 수 있다. 더구나, 제1 비트는 선택적으로 별도로 삽입되고, 채택된 실제 코드들 및 이들의 관련 압축에 어떤 유효한 정도로도 영향을 미치지 않는다.
선택적으로, 엔트로피 변형기(10, 60)는 소정의 상황에 있어서 엔트로피를 증가시키도록 동작 가능하며, 그렇기 때문에, 채택된 코딩 레짐(coding regime)이 원하는 정도의 데이터 압축을 제공하는지 여부를 결정하기 위해, 예를 들어 신호 모니터링 배열(arrangement)을 이용하여 엔트로피 변형기(10, 60)로부터의 출력 데이터가 모니터링되는 것이 바람직하다. 전달될 소정의 타입의 데이터에 대해 엔트로피가 증가하는 이벤트에서, 신호 모니터링 배열은 엔트로피에서의 원하는 변형이 동작 중에 달성되는 것을 보장하도록 적응형 방식으로 엔트로피 변형기(10, 60)의 동작을 제어하기 위해 채택될 수 있다. 예를 들어, 소정 타입의 데이터의 경우, 최대 런의 최적 값을 검색하여 최적 데이터 압축을 획득하도록 채택하기 위해 데이터 스트림의 인코딩을 개시할 때 하나 이상의 테스트 코딩 레짐들을 적용하기 위해 사용되는 것이 바람직하며, 여기서 최대 런은 엔트로피(E)에 주요한 영향을 미칠 수 있다. 추가적으로, 소정의 데이터 스트림의 길이가 상대적으로 짧은 경우, 예를 들어, 제1 비트 값이 바람직하게는 소정의 데이터 스트림을 나타내는데 사용되는 다른 코드 워드들과 별도로 송신되는 경우, 소정의 데이터 스트림에서 제1 비트 값과 관련된 엔트로피(E)는 엔트로피(E)에 주요한 영향을 미친다.
도 1에 예시된 바와 같이, 가변 길이 코딩(Variable-Length-Coding, VLC), 허프만 코딩(Huffman coding), 런 길이 인코딩(Run-Length-Encoding, RLE) 등과 같은 엔트로피 코딩 방법들과 함께 엔트로피 변형기(10, 60)가 채택되는 것이 바람직하다. 다른 방법으로, 바람직하게는, 델타 코딩(Delta coding)과 같은 다른 타입의 엔트로피 변형기들이 이들과 함께 채택된다. 바람직하게는, 이러한 엔트로피 코딩 방법은 엔트로피 변형기(10) 다음 그리고 엔트로피 변형기(60) 앞에 채택되는데, 다른 방법으로 또는 추가적으로, 이러한 엔트로피 코딩 방법들은 엔트로피 변형기(10) 앞에 그리고 엔트로피 변형기(60) 다음에 채택되며, 예를 들어, 인코딩될 원 데이터가 영숫자, 숫자, 바이트, 또는 워드가 이벤트에서, 원 데이터는 표 2에 제공되는 바와 같이 추가 코딩을 이용하여 효율적으로 코딩된다.
표 2: 본 발명에 따른 엔트로피 변형기를 이용하여 채택 가능한 추가 코딩
선택적으로, 엔트로피 변형기(10, 60)는 반복적 방식으로 채택된다.
전술한 바와 같이, 바람직하게는, 본 발명에 따른 엔트로피 변형기들이 다른 타입의 엔트로피 변형기들과 함께 채택되며, 여기서 선택적으로 다른 타입의 엔트로피 변형기들은 공지된 타입이다. 예를 들어, 공지 타입들은 델타(Delta) 코딩을 포함한다. 통상적으로, 델타 코딩은 바이트들 또는 워드들의 포맷으로 제공되는 수치 값들을 프로세싱하기 위해 채택된다. 다음으로, 델타 코딩과 함께 채택되는 본 발명의 엔트로피 변형기의 일례가 설명될 것이다.
본 발명을 더 설명하기 위해, 두 가지 예시가 설명될 것이며, 일례는 본 발명에 따른 엔트로피 변형기의 사용하지 않고, 다른 예는 본 발명에 따른 엔트로피 변형기를 활용한다. 이 예시에서, 7 비트의 최대 런 길이를, "0"인 관련 이스케이프 코드와 함께 채택한다. 1 비트 오델타 타입 오퍼레이터를 채택하는 경우, 인코딩된 시퀀스에서의 제1 비트는 인코딩될 원 데이터 스트림에 존재하는 대응하는 원 데이터 비트와 동일하다. 선택적으로, 1 비트 오델타 연산이 반복적으로 실행될 수 있다.
예시 1:
원 데이터 비트 스트림에서, 총 37개의 비트, 즉 17개의 1 및 20개의 0이 포함된다.
0 1 0 1 0 1 1 0 0 1 0 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1
여기서, 대응하는 관련 엔트로피(E)는 다음과 같이 계산 가능하다.
계산된 MB를 위한 36.82개의 비트, 즉 앞서 제공된 바와 같이 실질적으로 37개의 비트에 대응한다. 수학식 7이 원 비트 스트림에서의 비트량에 대응함은 물론이다.
등가의 엔트로피 변형(EM) 코드는, 표 1을 생성하기 위해 채택된 것과 일반적으로 유사한 방식으로 다음과 같다.
0 1 1 1 1 1 2 2 1 3 1 1 1 0 4 0 3
여기서, 관련 엔트로피(E)는 다음과 같이 계산 가능하다.
수학식 8이 엔트로피 변형 이후의 비트량에 대응한다는 점은 물론이다. 게다가, 이 비트량이 수학식 7과 관련된 비트량 미만임은 물론이다.
그러나, 전술한 원 비트 스트림이 오델타 연산의 대상인 경우, 37개의 비트를 포함하는 대응하는 변형 비트 스트림이 생성되는데, 여기서 13개의 "1" 및 24개의 "0"이 존재한다.
0 1 1 1 1 1 0 1 0 1 1 0 0 1 1 1 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0
여기서, 대응하는 엔트로피(E)는 다음과 같이 계산 가능하다.
즉, 원 비트 스트림과 관련된 엔트로피(E)(도 7)보다 더 작다. 전술한 이 오델타 프로세싱된 데이트 비트 스트림이 본 발명에 따른 엔트로피 변형의 대상이면, 이로써 아래와 같이 대응하는 인코딩된 코드 시퀀스가 획득된다.
0 1 5 1 1 1 2 2 4 0 3 1 0 2
여기서, 대응하는 엔트로피(E)는 다음과 같이 계산 가능하다.
총 37개의 비트를 포함하는 원 데이터 비트 스트림(수학식 7)의 엔트로피(E) 미만이다. 게다가, 이러한 비트량이 수학식 8 또는 수학식 9과 관련된 비트량 미만임은 물론이다.
이 예시는 원 데이터 스트림이 1 비트 오델타 오퍼레이터를 이용하여 먼저 압축되어 본 발명에 따른 엔트로피 변형기를 이용하여 압축되는 경우 원 데이터 비트 스트림을 효율적으로 압축하는 것이 가능하다는 것을 나타낸다.
예시 2:
예시 1에서의 전술한 원 비트 스트림은 2개의 부분으로 분할되고, 본 발명에 따른 엔트로피 변형의 이점들은 이들 2개의 최종 데이터 스트림의 최상 조합을 선택함으로써 최적화된다. 엔트로피 변형기의 제1 비트의 값은 별도로 송신되며, 결과적인 엔트로피 감소한 일련의 코드로 삽입되지 않는다. 획득 가능한 제1 엔트로피 변형 결과는 예시 1과 유사하며, 여기서 제1 비트 또한 "1" 코드 워드라고 설정된다. 표 3에 제공된 바와 같이, 7개의 비트의 유사 최대 런이 채택되고, "0"이 이스케이프 코드에 채택된다.
표 3: 예시 2 엔트로피 변형
표 3으로부터, 엔트로피 감소가 달성되며, 이것이 데이터 압축이 달성될 때 유리한 것은 물론이다. 데이터의 제1 부분 스트림이 엔트로피 변형된, 즉 13.49개의 비트를 이용하여 나타낸 원 데이터 스트림으로부터 생성된 데이터로부터 엔트로피 코딩되는 경우 데이터의 최선 압축이 달성되고, 제2 부분은 요구되는 원래 37개의 비트와 비교해 19.29개의 비트를 이용하여 표현 가능하도록 1 비트 오델타 코딩을 통해 엔트로피 변형되는데, 즉 5.80개의 비트를 이용하여 나타내진다. 제2 데이터 스트림이 코딩되는 경우, 제1 비트의 값을 전송할 필요가 없는데, 그 이유는 제1 데이터 스트림에 기반하여 공지될 수 있다. 이 때문에, "/"에 의해 구분된 표 3에 도시된 2개의 상이한 값들이 존재하는 경우, 제1 값은 연속 상황(즉, 전송되지 않은 제1 비트 값)을 위한 것이고, 제2 값은 이러한 종류의 비트 조합에서 데이터 스트림이 개시된 경우에 관한 것이다. 이 예시에서, 오델타 코딩만이 데이터의 엔트로피를 즉 대개 데이터의 제2 부분을 위해, 감소시킴에도 불구하고, 엔트로피 변형기(10, 60)와 함께 바람직한 엔트로피 감소를 제공함은 물론이다. 여기에서, 엔트로피 변형된 원 데이터는 오델타 코딩을 이용하여 먼저 프로세싱되는 엔트로피 변형된 데이터보다 작은 엔트로피, 즉 6.00 개의 비트들 < 9.61 개의 비트들을 초래한다. 실제 코딩 솔루션에서, 선택적으로, 오델타 코딩 데이터의 엔트로피가 더 작음에도 불구하고, 바람직하게는 엔트로피 변형된 원 데이터는 오델타 코딩 데이터보다 더 효율적으로 압축되는데; 무엇보다 산술 코딩이 바람직하게는 1 비트 데이터를 압축하기 위해 채택됨에도, 1 비트 데이터는 엔트로피 인코더들의 구현을 위해 실용적인 것은 아니다. 선택적으로, 데이터 압축을 달성하기 위한 엔트로피 변형 프로세스들의 대상이 되기 이전에, 원 비트 스트림이 3개의 부분 이상으로 분할된다.
선택적으로, 원 데이터 비트 스트림을 하나 이상의 스트림, 즉 부분으로 분할하는 것은,
(a) 원 데이터 비트 스트림과 관련된 엔트로피를 분석하는 단계;
(b) 원 데이터 비트 스트림의 분석된 엔트로피의 함수에 따라 원 데이터 스트림을 2개 이상의 부분으로 분할하는 단계;
(c) 하나 이상의 엔트로피 변형 연산을 2 이상의 부분에 적용하여 하나 이상의 대응하는 엔트로피 변형 부분을 생성하는 단계; 및
(d) 하나 이상의 엔트로피 변형 부분을 결합하여 압축된 인코딩 출력 데이터를 생성하는 단계를 포함하는 방법에 의해 자동 실행될 수 있다.
본 발명은 또한 인코딩된 출력 데이터를 디코딩하는 방법에 관한 것으로서, 단계들 (a) 내지 (d)의 인버스가 활용된다. 선택적으로, 이 방법은 원 비트 스트림에 존재하는 데이터 블록들을 분할 또는 결합하는 단계를 포함하는데, 이로써 예를 들어 향상된 압축비를 달성하고/하거나 실질적으로 무손실 압축을 달성하기 위해 인코딩이 더 효율적으로 구현된다.
선택적으로, 단계 (b)는 조악한 방식으로 구현되는데, 즉 다수의 롱(long) 런 섹션들이 원 데이터 비트 스트림에서 마주치는 경우, 즉 데이터 비트가 급속한 방식으로 순차적으로 달라지는 데이터 비트 스트림의 충분히 큰 영역이 존재하는 원 데이터 비트 스트림의 영역 이후 또는 그 사이에, 원 데이터 비트 스트림을 단지 분할한다.
선택적으로, 본 발명에 따른 인코딩된 비트 스트림을 생성하기 위해, 원 데이터 비트 스트림이 예를 들어, 엔트로피가 압축 및 감소된 출력 인코딩 데이터를 생성하기 위한 본 발명에 따른 엔트로피 변형의 대상이 되는 VLC, 산술 또는 레인지 코딩 및/또는 RLE의 적용을 통해 중간 인코딩 데이터를 제공하도록 프로세싱된다. 이로써, 데이터 압축 중의 상당한 속도 최적화가 달성되는데, 이는 본 발명이 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품에 의해 구현되는 경우 필요한 더 적은 컴퓨팅 전력에 대응하며, 여기서 하나 이상의 소프트웨어 제품은 엔트로피 변형 인코더를 구현하고, 필요한 부분만 약간 변형되어 엔트로피 변형 디코더를 구현하기 위한 컴퓨팅 하드웨어에서 실행 가능하다. 선택적으로, 원 데이터 비트 스트림에서의 원 비트, 알파벳, 숫자, 바이트, 워드가 일부 다른 방법을 이용하여 먼저 코딩되고, 그 후 본 발명에 따른 엔트로피 변형이 인코딩된 출력 데이터를 생성하도록 엔트로피 최적화가 구현된다.
동시대의 공지된 런 길이 인코딩(RLE) 방법들에서, 소정의 값이 생성되고, 다른 후속 값이 따르기 전에, 그 후 이러한 소정의 값의 생성 횟수를 나타내는 대응 데이터가 생성된다. 인코딩될 입력 데이터가 이용 가능한 한 이러한 RLE 방법이 계속되는데, 즉 다른 값 이후의 하나의 값이 순차적으로 인코딩된다. 대조적으로, 본 발명은 단지 1 비트 값들이 채택되면, 이들 값이 차례로 번갈아 일어나기 때문에 인코딩될 데이터 스트림으로 "0" 및 "1" 데이터 값들을 추가할 필요가 없다는 관측으로부터 도출되며, 이로써 인코딩 데이터의 전송 시에 소정의 시퀀스에서의 제1 값만이 표현되면 충분하다. 이로 인해, 본 발명은 RLE 코딩과 유사하지만, 전술한 바와 같이 1 비트 데이터 스트림을 채택한다.
본 발명의 실시예들을 구현하는 경우, 이스케이프 코드는 실제 인코딩 방법들의 더 효율적인 사용이 채택될 수 있게 하는 부가물이다. 바람직하게는, 본 발명의 실시예들은 인코더로부터 대응하는 디코더로 하나 이상의 코딩 테이블을 전송하여 인코더로부터 전송되어 디코더에서 수신된 인코딩 데이터의 디코딩을 보조하는 단계를 포함한다. 이러한 코딩 테이블들을 전달하는 일부 매우 유리한 방법들은, 예를 들어 여기에 참조로서 통합된 2014년 2월 20일에 출원인에 의해 출원된 특허출원 제GB1403039.9호에 개시되어 있다. 또한, 참조로서 통합된 2014년 2월 20일에 출원인에 의해 출원된 특허출원 제GB403038.1호에 개시되어 있다. 앞서 개시된 양자의 방법은 본 발명의 실시예들과 함께 사용하기에 잘 어울리며, 엔트로피 코딩에 필요한 추가 인코딩 데이터를 최소화하는 것을 보조한다.
본 발명의 실시예들을 구현하기 위해 채택된 이스케이프 코드들은 여러 상이한 방식으로 용이하게 구현될 수 있다. 예를 들어, "0" 값이 계속되는 런-길이 심볼 또는 디지트의 경우, 만족스러운 인코딩이 달성 가능하다. 그러나 이들 양의 값들이 작은 상황들이 잠재적으로 일어나는데, 반대로 이들 상황에서 매우 큰 값들이 가끔 발생할 수 있으며, 바람직하게는, 이스케이프 코드가, 아직 사용되지 않거나, 코드 워드로서 사용하기 위해 할당된 다음 값으로 설정된다. 예를 들어, 채택된 최대 런-길이가 7개의 비트 또는 요소인 경우, 및 이스케이프 코드가 "0"이면, 코드 워드 "8"는 인코딩된 데이터 스트림의 생성 중에 사용되는데, 이는 새로운 이스케이프 코드는 하나의 새로운 코드 워드만을 추가하고, 그 후 심볼의 실제 개수는 예를 들어, 1, 2, 및/또는 3 바이트에서의 임의의 방법을 이용하거나, 하프 바이트(즉, 니블(nibble))를 이용하여 표현 가능하다. 선택적으로, 심볼들의 실제 개수는 압축되지 않고 송신된다. 선택적으로, 심볼들의 실제 개수는 최대 런 길이 값과 조합된 다음, 엔트로피 압축기, 즉 엔트로피 변형기 내의 다른 데이터 값과 함께 압축된다.
본 발명의 실시예들에서 사용하기 위한 적절한 이스케이프 값을 선택하는 경우, 일단 총 개수의 인접 요소들을 표현하는 것이 바람직하며, 이로써 이러한 이스케이프 값을 불러온 이후, 동일 비트가 이스케이프 값의 사용과 대조적으로 후속해서 연속되지 않는다. 이러한 새로운 종결 형태는 전술한 바와 같은 연속적인 이스케이프 방법뿐 아니라 사용 가능한 이스케이프, 즉 코드 워드를 제공하며, 다른 방법으로서, 이러한 새로운 이스케이프 코드가 하나의 대안으로서 사용 가능하며, 이 경우 자신의 코드 워드는 바람직하게는 "0"으로 설정 가능하다. 이와 유사하게, 이러한 종결 코드의 소정의 데이터 값이 종종 작지만, 가끔 크면, 교번하는 개수의 바이트 또는 니블들을 이용하여 데이터에 존재하는 연속적인 유사한 심볼들의 개수를 표현하는 것이 바람직하다. 이러한 바이트 중 하나의 비트, 예를 들어, 최하위 비트(least significant bit, LSB) 또는 최상위 비트(most significant bit, MSB)는 그 수, 즉 비트 스트링의 종결을 지시하기 위해 바람직하게는 예약되며, 이로써 값이 종료된 경우, 또는 다른 경우에 값이 계속되는 경우 자신의 코드 워드가 값 "0" 또는 "1"로 설정된다.
전술한 내용을 설명하기 위해, 다음으로, 이스케이프 코드의 기능성의 일례를, 양쪽 타입의 이스케이프가 활용되는 상황에서 설명할 것이다. 일례에서, 14개의 요소의 최대 런이 채택되는데, 연속적인 이스케이프를 위한 코드 워드가 15에 의해 표시되고, 여기서 종결 이스케이프를 위한 코드는 0이다. 게다가, 연속적인 유사 심볼 또는 비트들의 양에 대한 값들은 다음과 같다.
9, 1024, 16, 9, 12, 2000, 7, 20, 21, 6, 8, 120, 12,...
또한, 이 예시는 값 "1"의 최상위 비트(MSB)가 그 수, 즉 비트 스트림의 종결을 지시하기 위해 채택된 하프 바이트들(예를 들어, 니블들)을 활용한다. 바람직하게는, 종결 이스케이프가 채택되면, 그 수, 즉 비트 스트림으로부터 차감하는 것이 다음과 같이 실행 가능하다.
( 비트 스트링) - (MAXRUN + 1)
예를 들어:
이로써, 이 예시는 다음과 같이 코딩될 수 있다.
9 0 1 6 7 9 1 5 2 9 12 0 1 0 7 11 7 1 5 6 15 7 6 8 0 1 5 9 12
이 예시에서, 엔트로피 변형기(10, 60)는 0 내지 15 범위의 값을 갖는 코드 워드들을 해석할 수 있어야 한다. 단일 이스케이프 코드만을 이용함으로써 이러한 예시를 표현하는 것이 실행 가능하며, 여기서 코드 워드 "0"는 또한 종결 이스케이프를 지시하는 이스케이프 코드에 대응하는데, 단일 타입의 이스케이프 코드의 이러한 대체 예시에서, 연속적인 이스케이프가 사용되지 않고, 다른 파라미터들은 전술한 바와 같이, 즉 다음과 같다.
9 0 1 6 7 9 0 9 9 12 0 1 0 7 11 7 0 13 0 14 6 8 0 1 5 9 12
여기서, 엔트로피 변형기(10, 60)는 0 내지 14의 범위에 있는 코드 워드들을 인식하는 것이 요구된다. 대체 예는 코드 워드 "0"에 의해 표현된 연속적인 이스케이프만을 활용하고, 14의 최대 런 길이를 채택함으로써 선택적으로 표현되며, 이로써 결과적으로 다음 형태의 코드 시퀀스를 초래한다.
9 73x0
2 0 2 9
12 142x0
12 7 0 6 7 6
8 8x0
8 12
최선 코딩 솔루션은 3개의 모든 솔루션에 대해 별도로 계산되는 엔트로피에 기반하여 선택될 수 있다.
엔트로피 변형(EM) 및 인버스 엔트로피 변형(IEM)을 제공하기 위한 본 발명의 실시예들은 다음에 설명될 것이다. 그러나, 다른 실시예들, 예를 들어, 가변 상태 기계, ASIC 등과 같은 디지털 하드웨어에 기반한 대응하는 엔트로피 변형기들은 또한 본 발명의 범위 내에서 실행 가능하다. 다음의 예시들에서 "GetBit", "SetBit" 및 "ClearBit" 명령어들은 항상 "HeaderBits" 값들을 업데이트하는 기능을 한다. 더구나, 다음 비트가 다음 바이트에 있을 경우 "Headerlndex" 값 또한 업데이트된다. 소프트웨어 제품에 기반한 다음의 예시들에서, 제1 비트는 하나의 코드로서 저장된다. 선택적으로, 더 나은 구현예들에서, 제1 비트 값은 예를 들어, 도 3을 참조하여 전술한 바와 같이 코드들로부터 분리된다. 바람직하게는, 디코딩된 출력 데이터에 기여한 목적지 바이트에 다수의 비트를 함께 기입함으로써 대응하는 디코더가 최적화된다. 다음의 예시적인 실시예들에서 제공되는 "MaxRun"가 (최대 런 길이 + 1)와 유사함은 물론이며, 예를 들어, 7 비트의 최대 런 길이가 채택되는 경우, 8의 값이 다음 실시예들에서 함수 파라미터 "AMaxRun"로서 주어진다.
예를 들어, VLC, 허프만 코딩, 산술 코딩, 레인지 코딩, RLE 코딩 등과 같은 엔트로피 코딩 방법이 즉, 예측 또는 다른 추가 정보의 형태를 이용하지 않거나, 정보의 손실이 일어나지 않고, 자신의 엔트로피 허용치보다 더 작은 사이즈로 데이터를 압축하는 것이 가능하지 않음에도 불구하고, 이는 모든 경우에 실제로 최대 데이터 압축이 최소 엔트로피에 대응하는 것을 의미하지 않는데, 다시 말하면, 실제로 엔트로피 및 데이터 압축은 정확하게 동일한 개념은 아니다. 인코딩 데이터를 자신의 대응하는 원 형태로 다시 디코딩하는 것은 일부 추가 정보를 항상 요구하지 않고, 때때로 이들 추가 정보의 전송은 압축될 실제 데이터뿐 아니라 불합리한 양의 여분 정보를 요구한다. 대량의 데이터가 처리될 경우, 가장 작은 엔트로피가 최선의 데이터 압축에 대응하지만, 작은 양의 데이터가 처리될 때, 데이터를 압축하는 것은 항상 그렇게 직접적인 것은 아니며, 예를 들어, 1 비트 데이터는 대개 효율적으로 압축하는 것이 어렵고, 그러므로 1 비트 정보를 처리하도록 동작 가능한 엔트로피 변형기(10, 60)는 잠재적 그리고 상업적으로 매우 가치 있는 발명이다. 더구나, 더 쉽게 압축 가능한 포맷으로 데이터를 프로세싱하는 것은 종종, 프로세스들을 포맷화하는 것이 적용되기 이전에 대응하는 원 데이터에 비해 포맷화된 데이터의 엔트로피의 감소를 초래한다.
전술한 바와 같이, 인코딩 데이터를 나타내는 코드 워드들의 시퀀스에서의 제1 비트 값이 연속 심볼 또는 비트의 개수를 나타내는 이들 값과 별도로 전송되면, 종종 효율적이다. 그러나, 이러한 별도의 전송은 완전히 별도의 통신에 대응할 필요가 없다. 다음의 예시에서, 제1 비트의 별도의 처리에도 불구하고, 연속 요소들의 총량에 제1 비트량을 추가할 필요가 여전히 존재하는데, 그 이유는 다음 예시들을 구별하는 것이 가능하지 않을 수 있기 때문이다.
0 0 1 및 0 1 또는
1 1 0 및 1 0,
제1 요소의 개수를 0으로 설정하지 않고, 전술한 이스케이프 코드를 구현하기 위해 채택될 수 있으면, 즉 연속적인 유사 신호들의 개수가 예시들에서 최대 런 길이를 초과할 때 사용하기 위해 채택될 수 있으면 바람직하지 않을 수 있다.
도 1에서, 데이터(D2)의 사이즈는 데이터(D1)의 사이즈보다 필수적으로 더 작은 것은 아니지만, 데이터(D1 및 D2)가 상호 유사한 정보를 포함한 경우에도 데이터(D2)의 엔트로피가 더 작다. 데이터(D2)의 사이즈는 채택된 런 길이에 종속적이다. 예를 들어, 데이터(D1)에서, 데이터 요소들의 사이즈는 1 비트인 반면, 데이터(D2)의 사이즈는 채택된 런 길이들의 사이즈에 의존한다. 예를 들어, 데이터(D1)가 104 비트의 사이즈를 갖고, 엔트로피(E) = 80이면, 데이터(D1)는 데이터(D2) 내의 7개의 요소들의 최대 런 길이를 이용함으로써 엔트로피 변형기(10)에 의해 변환될 수 있으며, 여기서 데이터(D2)는 40개의 요소, 즉 0 내지 7의 범위에 있는 값을 갖는 3 비트 요소를 갖고, 엔트로피(E) = 50이며, 그 후 데이터(D2)는 40*3 비트 = 120 비트의 사이즈를 갖는데; 이러한 예시에서, 데이터(D2)는 데이터(D1)보다 사이즈가 크다. 바람직하게는, 인코딩 스테이지(20)는 데이터(D2)를 52 비트로 압축하여 데이터(D3)를 제공할 수 있는 VLC 변환을 채택한다. 이에 따라, 엔트로피 변형기(10, 60)는 각각 데이터 압축 및 압축 해제를 항상 제공하지 않지만, 다른 인코딩 스테이지들을 이용하여 채택되는 경우 데이터 압축 및 압축 해제를 제공할 수 있음은 물론이다.
바람직하게는, 본 발명의 실시예들은 몇몇 예시들을 언급하기 위해 통신 시스템들, 시청각 소비자 제품들, 과학적 이미지 프로세싱 장비, 컴퓨팅 디바이스들, 스마트폰과 같은 무선 가능 통신 디바이스들, 디지털 카메라, 디지털 감시 장비, 및 쌍방향 컴퓨터 게임의 컴포넌트 부분들로서 포함된다. 데이터 압축이 증가하면 데이터 저장 요건들을 감축시키고, 에너지를 절감할 수 있으며, 고속 통신이 달성될 수 있게 하는데, 이들 모두는 예를 들어, 산업에서 채택 가능한 유리한 기술적 효과들로서 간주될 것이다. 더구나, 실시예들은 소프트웨어 제품들, 하드웨어, 또는 이들의 임의의 조합으로 구현 가능하다. 선택적으로, 소프트웨어 제품들은 소프트웨어 애플리케이션, 즉 "소프트웨어 앱"으로서 다운로드 가능하다.
전술한 본 발명의 실시예들에 대한 변형은 다음의 청구범위에 의해 정의된 본 발명의 범위에서 벗어나지 않고 가능하다. 본 발명을 설명하고 주장하는데 사용되는 "포함하는(including)", "포함하지만 이로 제한되지 않는(comprising)", "통합하는(incorporating)", "구성되는(consisting of)", "갖다(have)", "이다(is)"와 같은 표현들은 비-배타적인 방식으로 간주되는 것을 의도하는데, 즉 명확히 설명되지 않은 아이템들, 컴포넌트들, 또는 요소들이 제시되는 것을 가능하게 한다. 단수에 대한 참조는 또한 복수에 관한 것으로 간주될 수 있다. 첨부된 청구범위에서 괄호 내에 포함된 숫자들은 청구범위의 이해를 보조하기 위한 것으로서, 이 청구범위에 의해 주장되는 주제를 한정하는 것으로 임의의 간주되지 않아야 한다.
Claims (57)
- 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D2)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D1)의 스트림을 인코딩하도록 동작 가능한 엔트로피 변형기(10)에 있어서,
(a) 상기 엔트로피 변형기(10)는 상기 출력 데이터(D2)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 포함하기 위해 상기 출력 데이터(D2)를 생성하도록 동작 가능하며;
(b) 상기 출력 데이터(D2)는 상기 입력 데이터 비트(D1)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 데이터를 더 포함하고, 상기 상호 유사 비트들의 런 길이들은 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되며;
(c) 상기 최대 런 길이 값을 실질적으로 초과하는 상기 입력 데이터(D1)에서의 상기 런 길이들의 하나 이상의 생성은 상기 출력 데이터(D2)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시되는 것을 특징으로 하는 엔트로피 변형기(10). - 제1항에 있어서, 상기 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이(MaxRun)는 복수의 이스케이프 코드에 의해 제어되는 것을 특징으로 하는 엔트로피 변형기(10).
- 제1항 또는 제2항에 있어서, 상기 엔트로피 변형기(10)는 "0" 데이터 값을 통해 상기 출력 데이터(D2)에 상기 적어도 하나의 이스케이프 코드를 포함하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(10).
- 제1항 내지 제3항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(10)는, 상기 입력 데이터(D1)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 상기 최대 런 길이(MaxRun)를 이용하여 상기 입력 데이터(D1)의 스트림을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(10).
- 제1항 내지 제4항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(10)는 압축 데이터(D3)를 생성하기 위한 하나 이상의 코딩 배열들(20)에서의 후속 압축을 위해 상기 입력 데이터(D1)를 상기 출력 데이터(D2)로 포맷화하기 위한 데이터 사전 프로세서로서 기능하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(10).
- 제1항 내지 제5항 중 어느 한 항에 있어서, 상기 적어도 하나의 이스케이프 코드는 상기 엔트로피 변형기(10)에 의해 생성된 상기 출력 데이터(D2) 내에 "0" 값으로서 구현되는 것을 특징으로 하는 엔트로피 변형기(10).
- 제6항에 있어서, 상기 하나 이상의 코딩 배열들은 오델타 코더, RLE 코더, VLC 코더, 허프만 코더, 델타 코더, 산술 코더, 레인지 코더 중 하나 이상을 포함하는 것을 특징으로 하는 엔트로피 변형기(10).
- 제1항 내지 제7항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(10)는 별도로 프로세싱되는 복수의 부분에서 상기 입력 데이터 비트(D1)의 스트림을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(10).
- 제8항에 있어서, 상기 엔트로피 변형기(10)는 시간 병렬 방식으로, 즉 병렬 실행을 통해 상기 복수의 부분들을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(10).
- 제8항 또는 제9항에 있어서, 상기 엔트로피 변형기(10)는 상기 복수의 부분 중 하나 이상에 대해 서로 상이한 최대 런 길이들(MaxRun)을 이용함으로써 상기 복수의 부분을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(10).
- 제1항 내지 제10항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(10)는 컴퓨팅 하드웨어를 포함하고, 상기 컴퓨팅 하드웨어는 상기 입력 데이터(D1)의 스트림을 프로세싱하여 상기 출력 데이터(D2)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(10).
- 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D5)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D3 또는 D4)의 스트림을 디코딩하도록 동작 가능한 엔트로피 변형기(60)에 있어서,
(a) 상기 엔트로피 변형기(60)는 상기 입력 데이터(D3 또는 D4)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 이용함으로써 상기 입력 데이터(D3 또는 D4)를 프로세싱하도록 동작 가능하며;
(b) 상기 엔트로피 변형기(60)는 상기 입력 데이터 비트(D3 또는 D4)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 상기 입력 데이터(D3 또는 D4)에 존재하는 데이터를 프로세싱하도록 동작 가능하며, 상기 상호 유사 비트의 최대 길이는 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되고;
(c) 상기 엔트로피 변형기(60)는, 상기 입력 데이터(D3 또는 D4)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시되는 것인, 상기 최대 런 길이 값을 실질적으로 초과하는 상기 입력 데이터(D3 또는 D4)에서의 상기 런 길이들의 하나 이상의 생성을 검출하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60). - 제12항에 있어서, 상기 엔트로피 변형기(60)는 적어도 하나의 이스케이프 코드를 이용함으로써 상기 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이(MaxRun)를 프로세싱하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제13항에 있어서, 상기 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이(MaxRun)는 복수의 이스케이프 코드를 이용함으로써 프로세싱되는 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제14항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는, 상기 입력 데이터(D3 또는 D4)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 상기 최대 런 길이(MaxRun)를 이용하여 상기 입력 데이터(D3 또는 D4)의 스트림을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제15항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는 데이터 비트 시퀀스와 별도로 상기 입력 데이터(D3 또는 D4)의 스트림에서 제1 비트의 값의 정보를 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제16항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는 상기 입력 데이터(D3 또는 D4)에 존재하는 데이터 요소들을 디코딩하고, 디코딩된 비트 스트림으로서 상기 출력 데이터(D5)를 생성하기 위해 인버스 엔트로피 변형을 적용하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제17항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는, 연속적인 유사 비트들의 양을 나타내는 데이터 값들의 시퀀스에 관해 별도로 인코딩되는 것으로서 상기 제1 비트의 값을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제13항에 있어서, 상기 적어도 하나의 이스케이프 코드는 상기 엔트로피 변형기(60) 내에 "0" 값으로서 구현되는 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제19항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는 상기 입력 데이터 비트(D3)의 스트림을 처리하기 위한 하나 이상의 코딩 배열과 함께 사후 프로세싱하는데 활용되며, 상기 하나 이상의 코딩 배열들은 오델타 코딩, RLE 코딩, VLC 코딩, 허프만 코딩, 델타 코딩, 산술 코딩, 레인지 코딩 중 하나 이상을 포함하는 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제20항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는 별도로 인코딩되거나 디코딩되는 복수의 부분에서 상기 입력 데이터 비트(D3 또는 D4)의 스트림을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제21항에 있어서, 상기 엔트로피 변형기(60)는 시간 병렬 방식으로, 즉 병렬 실행을 통해 상기 복수의 부분들을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제21항 또는 제22항에 있어서, 상기 엔트로피 변형기(60)는 상기 복수의 부분 중 하나 이상에 대해 서로 상이한 최대 런 길이들(MaxRun)을 이용함으로써 상기 복수의 부분을 처리하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제23항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는 엔트로피 변형된 출력(D5)을 생성하기 위해 디코딩한 이후 상기 입력 데이터(D3 또는 D4)의 스트림을 엔트로피 변형하기 위한 사후 프로세서로서 기능하도록 구현되는 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제24항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는 상기 입력 데이터(D3 또는 D4)에 존재하는 심볼들을 상기 출력 데이터(D5)에 존재하는 비트 스트링으로 변환하는 것을 보조하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 제12항 내지 제25항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)는 컴퓨팅 하드웨어를 포함하고, 상기 컴퓨팅 하드웨어는 상기 입력 데이터(D3 또는 D4)의 스트림을 프로세싱하여 상기 출력 데이터(D5)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능한 것을 특징으로 하는 엔트로피 변형기(60).
- 엔트로피 변형기(10)를 사용하여, 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D2)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D1)의 스트림을 인코딩하는 방법에 있어서,
(a) 상기 출력 데이터(D2)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 포함하기 위해 상기 엔트로피 변형기(10)를 동작시켜서 상기 출력 데이터(D2)를 생성하는 단계;
(b) 상기 출력 데이터(D2)에, 상기 입력 데이터 비트(D1)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 데이터를 포함시키는 단계로서, 상기 상호 유사 비트들의 런 길이들은 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되는 것인 상기 단계; 및
(c) 상기 최대 런 길이 값을 실질적으로 초과하는 상기 입력 데이터(D1)에서의 상기 런 길이들의 하나 이상의 생성을, 상기 출력 데이터(D2)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시하는 단계를 포함하는 것을 특징으로 하는 방법. - 제27항에 있어서, 상기 적어도 하나의 이스케이프 코드를 이용함으로써 상기 엔트로피 변형기(10)를 사용하여 상기 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이(MaxRun)를 제어하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제28항에 있어서, 상기 복수의 이스케이프 코드를 이용하여 상기 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이(MaxRun)를 제어하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제27항 내지 제29항 중 어느 한 항에 있어서, 상기 입력 데이터(D1)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 상기 최대 런 길이(MaxRun)를 이용함으로써 상기 엔트로피 변형기(10)를 사용하여 상기 입력 데이터(D1)의 스트림을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제27항 내지 제30항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(10)를 사용하여, 데이터 비트 시퀀스와 별도로 상기 입력 데이터(D1)의 스트림에서 제1 비트의 값의 정보를 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제31항에 있어서, 상기 엔트로피 변형기(10)를 사용하여, 연속적인 유사 비트들의 양을 나타내는 데이터 값들의 시퀀스에 관해 별도로 인코딩되는 것으로서 상기 제1 비트의 값을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제28항에 있어서, 상기 적어도 하나의 이스케이프 코드는 상기 엔트로피 변형기(10) 내에 "0" 값으로서 구현되는 것을 특징으로 하는 방법.
- 제27항 내지 제33항 중 어느 한 항에 있어서, 상기 입력 데이터 비트(D1)의 스트림을 처리하기 위한 하나 이상의 코딩 배열과 함께 사후 프로세싱하기 위해 상기 엔트로피 변형기(10)를 사용하는 단계를 포함하며, 상기 하나 이상의 코딩 배열들은 오델타 코딩, RLE 코딩, VLC 코딩, 허프만 코딩, 델타 코딩, 산술 코딩, 레인지 코딩 중 하나 이상을 포함하는 것을 특징으로 하는 방법.
- 제27항 내지 제34항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(10)를 사용하여, 별도로 인코딩되거나 디코딩되는 복수의 부분에서 상기 입력 데이터 비트(D1)의 스트림을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제35항에 있어서, 상기 엔트로피 변형기(10)를 사용하여 시간 병렬 방식으로, 즉 병렬 실행을 통해 상기 복수의 부분들을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제35항 또는 제36항에 있어서, 상기 복수의 부분 중 하나 이상에 대해 서로 상이한 최대 런 길이들을 이용함으로써 상기 엔트로피 변형기(10)를 사용하여 상기 복수의 부분을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제27항 내지 제37항 중 어느 한 항에 있어서, 상기 입력 데이터(D1) 스트림을 압축하여 상기 엔트로피 변형 출력(D2, D3)을 생성하기 위한 인코더(10, 20)로서 기능하도록 상기 엔트로피 변형기(10)를 구현하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제27항 내지 제38항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(10)를 사용하여 상기 입력 데이터(D1)에 존재하는 비트 스트링을 상기 엔트로피 변형 출력 데이터(D2)에 존재하는 심볼들로 변환하는 것을 보조하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제27항 내지 제39항 중 어느 한 항에 있어서, 컴퓨팅 하드웨어를 포함하도록 상기 엔트로피 변형기(10)를 구현하는 단계를 포함하며, 상기 컴퓨팅 하드웨어는 상기 입력 데이터(D1)의 스트림을 프로세싱하여 상기 출력 데이터(D2)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능한 것을 특징으로 하는 방법.
- 엔트로피 변형기(60)를 사용하여, 제2 엔트로피를 갖는 대응하는 엔트로피 변형 출력 데이터(D5)를 생성하기 위해 제1 엔트로피를 갖는 입력 데이터 비트(D3 또는 D4)의 스트림을 디코딩하는 방법에 있어서,
(a) 상기 입력 데이터(D3 또는 D4)에 포함된 후속 데이터를 위한 참조 값으로서 기능하는 제1 비트의 정보를 이용함으로써 상기 엔트로피 변형기(10)를 사용하여, 상기 입력 데이터(D3 또는 D4)를 프로세싱하는 단계;
(b) 상기 엔트로피 변형기(60)를 사용하여, 상기 입력 데이터 비트(D3 또는 D4)에 존재하는 상호 유사 비트들의 런 길이들을 나타내는 상기 입력 데이터(D3 또는 D4)에 존재하는 데이터를 프로세싱하는 단계로서, 상기 상호 유사 비트들의 런 길이들은 최대 런 길이 값(MaxRun)을 초과하지 않도록 사이즈가 실질적으로 한정되는 것인 상기 단계; 및
(c) 상기 엔트로피 변형기(60)를 사용하여, 상기 입력 데이터(D3 또는 D4)에 포함된 적어도 하나의 이스케이프 코드에 의해 표시되는 것인, 상기 최대 런 길이 값을 실질적으로 초과하는 상기 입력 데이터(D3 또는 D4)에서의 상기 런 길이들의 하나 이상의 생성을 검출하는 단계를 포함하는 것을 특징으로 하는 방법. - 제41항에 있어서, 상기 적어도 하나의 이스케이프 코드를 이용함으로써 상기 엔트로피 변형기(60)를 사용하여 상기 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이를 프로세싱하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제42항에 있어서, 상기 복수의 이스케이프 코드를 이용함으로써 상기 상호 유사 비트들의 그룹들의 하나 이상의 최대 런 길이를 프로세싱하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제41항 내지 제43항에 있어서, 상기 입력 데이터(D3 또는 D4)의 스트림의 특성의 함수에 따라 동적으로 달라지는 방식으로 상기 최대 런 길이를 이용함으로써 상기 엔트로피 변형기(60)를 사용하여 상기 입력 데이터(D3 또는 D4)의 스트림을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제41항 내지 제44항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)를 사용하여 데이터 비트 시퀀스와 별도로 상기 입력 데이터(D3 또는 D4)의 스트림에서 제1 비트의 값의 정보를 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제41항 내지 제45항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)를 사용하여, 상기 입력 데이터(D3 또는 D4)에 존재하는 데이터 요소들을 디코딩하고, 디코딩된 비트 스트림으로서 상기 출력 데이터(D5)를 생성하기 위해 인버스 엔트로피 변형을 적용하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제45항 또는 제46항에 있어서, 상기 엔트로피 변형기(60)를 사용하여, 연속적인 유사 비트들의 양을 나타내는 데이터 값들의 시퀀스에 관해 별도로 인코딩되는 것으로서 상기 제1 비트의 값을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제42항에 있어서, 상기 적어도 하나의 이스케이프 코드는 상기 엔트로피 변형기(60) 내에 "0" 값으로서 구현되는 것을 특징으로 하는 방법.
- 제41항 내지 제48항 중 어느 한 항에 있어서, 상기 입력 데이터 비트(D3)의 스트림을 처리하기 위한 하나 이상의 코딩 배열과 함께 상기 엔트로피 변형기(60)를 사용하는 단계를 포함하며, 상기 하나 이상의 코딩 배열들은 오델타 코딩, RLE 코딩, VLC 코딩, 허프만 코딩, 델타 코딩, 산술 코딩, 레인지 코딩 중 하나 이상을 포함하는 것을 특징으로 하는 방법.
- 제41항 내지 제49항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)를 사용하여 별도로 인코딩되거나 디코딩되는 복수의 부분에서 상기 입력 데이터 비트(D3 또는 D4)의 스트림을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제50항에 있어서, 엔트로피 변형기(60)를 사용하여 시간 병렬 방식으로, 즉 병렬 실행을 통해 상기 복수의 부분들을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제50항 또는 제51항에 있어서, 상기 복수의 부분 중 하나 이상에 대해 서로 상이한 최대 런 길이들을 이용함으로써 상기 엔트로피 변형기(60)를 사용하여 상기 복수의 부분을 처리하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제41항 내지 제52항 중 어느 한 항에 있어서, 상기 입력 데이터(D3 또는 D4)의 스트림을 압축 해제하여 상기 엔트로피 변형 출력(D5)을 생성하기 위한 디코더로서 기능하도록 상기 엔트로피 변형기(60)를 사용하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제41항 내지 제53항 중 어느 한 항에 있어서, 상기 엔트로피 변형기(60)를 사용하여, 상기 입력 데이터(D3 또는 D4)에 존재하는 심볼들을 상기 출력 데이터(D5)에 존재하는 비트 스트링으로 변환하는 것을 보조하는 단계를 포함하는 것을 특징으로 하는 방법.
- 제41항 내지 제54항 중 어느 한 항에 있어서, 컴퓨팅 하드웨어를 포함하도록 상기 엔트로피 변형기(60)를 구현하는 단계를 포함하며, 상기 컴퓨팅 하드웨어는 상기 입력 데이터(D3 또는 D4)의 스트림을 프로세싱하여 상기 출력 데이터(D5)를 생성하기 위해 기계 판독 가능 데이터 저장 매체에 기록된 하나 이상의 소프트웨어 제품을 실행하도록 동작 가능한 것을 특징으로 하는 방법.
- 기계 판독 가능 데이터 저장 매체에 기록된 소프트웨어 제품에 있어서, 상기 소프트웨어 제품은 제27항에 기재된 방법을 실행하기 위한 컴퓨팅 하드웨어에서 실행 가능한 것을 특징으로 하는 소프트웨어 제품.
- 기계 판독 가능 데이터 저장 매체에 기록된 소프트웨어 제품에 있어서, 상기 소프트웨어 제품은 제41항에 기재된 방법을 실행하기 위한 컴퓨팅 하드웨어에서 실행 가능한 것을 특징으로 하는 소프트웨어 제품.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB1303658.7A GB2511493B (en) | 2013-03-01 | 2013-03-01 | Entropy modifier and method |
GB1303658.7 | 2013-03-01 | ||
PCT/EP2014/000529 WO2014131526A1 (en) | 2013-03-01 | 2014-03-01 | Entropy modifier and method |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20150126858A true KR20150126858A (ko) | 2015-11-13 |
KR102068383B1 KR102068383B1 (ko) | 2020-02-11 |
Family
ID=48142235
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020157024996A KR102068383B1 (ko) | 2013-03-01 | 2014-03-01 | 엔트로피 변형기 및 방법 |
Country Status (7)
Country | Link |
---|---|
EP (2) | EP2962397A1 (ko) |
JP (1) | JP6073506B2 (ko) |
KR (1) | KR102068383B1 (ko) |
CN (2) | CN105409129B (ko) |
GB (1) | GB2511493B (ko) |
RU (1) | RU2611249C1 (ko) |
WO (2) | WO2014131528A1 (ko) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2523347B (en) | 2014-02-20 | 2016-01-13 | Gurulogic Microsystems Oy | Encoder, decoder and method |
GB2527588B (en) | 2014-06-27 | 2016-05-18 | Gurulogic Microsystems Oy | Encoder and decoder |
US20190195742A1 (en) * | 2017-12-22 | 2019-06-27 | Schneider Electric Software, Llc | Automated detection of anomalous industrial process operation |
CN108737976B (zh) * | 2018-05-22 | 2021-05-04 | 南京大学 | 一种基于北斗短报文的压缩传输方法 |
FR3105660B1 (fr) * | 2019-12-18 | 2022-10-14 | Commissariat Energie Atomique | Procédé et dispositif de codage additif de signaux pour implémenter des opérations MAC numériques à précision dynamique |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20110094046A (ko) * | 2008-11-10 | 2011-08-19 | 애플 인크. | 정수-값 데이터의 스트림을 압축하는 시스템 및 방법 |
KR20130006689A (ko) * | 2010-04-09 | 2013-01-17 | 퀄컴 인코포레이티드 | 비디오 데이터의 코딩을 위한 가변 길이 코드들 |
Family Cites Families (22)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS5550777A (en) * | 1979-05-21 | 1980-04-12 | Toshiba Corp | Information compression device |
JPS5621483A (en) * | 1979-07-31 | 1981-02-27 | Fuji Photo Film Co Ltd | Encoding system of picture signal |
JP3010631B2 (ja) * | 1989-02-14 | 2000-02-21 | ソニー株式会社 | ランレングス符号化方式 |
JPH036924A (ja) * | 1989-06-05 | 1991-01-14 | Hitachi Ltd | 端末装置 |
US5627534A (en) * | 1995-03-23 | 1997-05-06 | International Business Machines Corporation | Dual stage compression of bit mapped image data using refined run length and LZ compression |
JPH08294142A (ja) * | 1995-04-24 | 1996-11-05 | Omron Corp | 画像情報圧縮方法、及びこの方法を使用した画像表示装置 |
GB2301252A (en) * | 1995-05-23 | 1996-11-27 | Ibm | Run length data compression |
US5710561A (en) * | 1996-01-02 | 1998-01-20 | Peerless Systems Corporation | Method and apparatus for double run-length encoding of binary data |
US6269338B1 (en) * | 1996-10-10 | 2001-07-31 | U.S. Philips Corporation | Data compression and expansion of an audio signal |
JP4260908B2 (ja) * | 1997-06-25 | 2009-04-30 | 株式会社日本デジタル研究所 | ランレングス符号化方法および画像処理装置 |
JP2001136524A (ja) * | 1999-11-02 | 2001-05-18 | Ricoh Co Ltd | 圧縮伸長装置 |
US6359548B1 (en) * | 2000-10-16 | 2002-03-19 | Unisys Corporation | Data compression and decompression method and apparatus with embedded filtering of infrequently encountered strings |
US6384751B1 (en) * | 2000-12-22 | 2002-05-07 | Unisys Corporation | Data compression/decompression circuit and method |
US6719689B2 (en) * | 2001-04-30 | 2004-04-13 | Medtronic, Inc. | Method and system for compressing and storing data in a medical device having limited storage |
JP2005503695A (ja) * | 2001-05-29 | 2005-02-03 | コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ | ビデオトランスコード方法及び装置 |
JP2007511938A (ja) * | 2003-10-31 | 2007-05-10 | コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ | ビデオ信号の符号化方法 |
US7205912B1 (en) * | 2005-10-31 | 2007-04-17 | Seagate Technology Llc | Structured set partitioning and multilevel coding for partial response channels |
RU2426227C2 (ru) * | 2006-11-14 | 2011-08-10 | Квэлкомм Инкорпорейтед | Кодирование кодов переменной длины с эффективным использованием памяти |
KR101454167B1 (ko) * | 2007-09-07 | 2014-10-27 | 삼성전자주식회사 | 데이터 압축 및 복원 장치 및 방법 |
EP2131501A1 (en) * | 2008-06-06 | 2009-12-09 | Harman Becker Automotive Systems GmbH | Data compression and decompression method and data processing apparatus |
JP2010245938A (ja) * | 2009-04-08 | 2010-10-28 | Sony Corp | 信号処理装置、信号処理方法、プログラム |
CN102474270A (zh) * | 2009-08-06 | 2012-05-23 | 松下电器产业株式会社 | 编码方法、解码方法、编码装置及解码装置 |
-
2013
- 2013-03-01 GB GB1303658.7A patent/GB2511493B/en active Active
-
2014
- 2014-03-01 WO PCT/EP2014/000531 patent/WO2014131528A1/en active Application Filing
- 2014-03-01 CN CN201480024696.XA patent/CN105409129B/zh active Active
- 2014-03-01 JP JP2015559443A patent/JP6073506B2/ja active Active
- 2014-03-01 RU RU2015132038A patent/RU2611249C1/ru active
- 2014-03-01 CN CN201480024777.XA patent/CN105164923B/zh active Active
- 2014-03-01 WO PCT/EP2014/000529 patent/WO2014131526A1/en active Application Filing
- 2014-03-01 EP EP14715207.8A patent/EP2962397A1/en not_active Withdrawn
- 2014-03-01 EP EP14713379.7A patent/EP2962396A1/en not_active Ceased
- 2014-03-01 KR KR1020157024996A patent/KR102068383B1/ko active IP Right Grant
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20110094046A (ko) * | 2008-11-10 | 2011-08-19 | 애플 인크. | 정수-값 데이터의 스트림을 압축하는 시스템 및 방법 |
KR20130006689A (ko) * | 2010-04-09 | 2013-01-17 | 퀄컴 인코포레이티드 | 비디오 데이터의 코딩을 위한 가변 길이 코드들 |
Also Published As
Publication number | Publication date |
---|---|
RU2611249C1 (ru) | 2017-02-21 |
CN105164923B (zh) | 2018-10-23 |
CN105164923A (zh) | 2015-12-16 |
WO2014131526A1 (en) | 2014-09-04 |
JP2016514404A (ja) | 2016-05-19 |
JP6073506B2 (ja) | 2017-02-01 |
GB2511493B (en) | 2017-04-05 |
EP2962397A1 (en) | 2016-01-06 |
KR102068383B1 (ko) | 2020-02-11 |
CN105409129A (zh) | 2016-03-16 |
GB2511493A (en) | 2014-09-10 |
EP2962396A1 (en) | 2016-01-06 |
WO2014131528A1 (en) | 2014-09-04 |
GB201303658D0 (en) | 2013-04-17 |
CN105409129B (zh) | 2018-11-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR101737294B1 (ko) | 심볼 압축을 수반하는 데이터의 소스 코딩 및 디코딩을 위한 방법들 및 디바이스들 | |
US11044495B1 (en) | Systems and methods for variable length codeword based data encoding and decoding using dynamic memory allocation | |
JP5602440B2 (ja) | ビットシーケンスを符号化するための方法及び装置 | |
RU2417518C2 (ru) | Эффективное кодирование и декодирование блоков преобразования | |
RU2630750C1 (ru) | Устройство и способ для кодирования и декодирования исходных данных | |
KR101610610B1 (ko) | 인코더, 디코더 및 방법 | |
JP2017507590A5 (ko) | ||
JP6431487B2 (ja) | データエンコーダ、データデコーダ及び方法 | |
KR102068383B1 (ko) | 엔트로피 변형기 및 방법 | |
JP2016512004A5 (ko) | ||
KR102393743B1 (ko) | 모드 심볼들을 사용하는 인코더, 디코더 및 방법 | |
JP2006174489A (ja) | 符号化装置および方法 | |
KR101667989B1 (ko) | 입력 비트 시퀀스를 인코딩하는 방법과 디바이스 및 대응하는 디코딩 방법 및 디바이스 | |
US8754791B1 (en) | Entropy modifier and method | |
JP2006246500A (ja) | 符号化装置および方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant |