WO2000036752A1 - Variable to variable length entropy encoding - Google Patents
Variable to variable length entropy encoding Download PDFInfo
- Publication number
- WO2000036752A1 WO2000036752A1 PCT/US1999/029108 US9929108W WO0036752A1 WO 2000036752 A1 WO2000036752 A1 WO 2000036752A1 US 9929108 W US9929108 W US 9929108W WO 0036752 A1 WO0036752 A1 WO 0036752A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- symbols
- code
- variable length
- input
- series
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Ceased
Links
Classifications
-
- 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/40—Conversion to or from variable length codes, e.g. Shannon-Fano code, Huffman code, Morse code
- H03M7/42—Conversion to or from variable length codes, e.g. Shannon-Fano code, Huffman code, Morse code using table look-up for the coding or decoding process, e.g. using read-only memory
Definitions
- the invention generally relates to data compression, and more specifically relates to a form of entropy coding.
- data is represented as a long sequence of symbols which is input to an encoder.
- the input data is encoded by an encoder, transmitted over a communication channel (or simply stored), and decoded by a decoder.
- the input is pre-processed, sampled, converted, compressed or otherwise manipulated into a form for transmission or storage. After transmission or storage, the decoder attempts to reconstruct the original input.
- Audio coding techniques can be generally categorized into two classes, namely the time-domain techniques and frequency-domain ones.
- Time-domain techniques e.g., ADPCM, LPC
- the frequency-domain techniques transform the audio signals into the frequency domain where the actual compression happens.
- the frequency-domain codecs can be further separated into either subband or transform coders although the distinction between the two is not always clear.
- Processing an audio signal in the frequency domain is motivated by both classical signal processing theories and human perception models (e.g., psychoaoustics).
- the inner ear specifically the basilar membrane, behaves like a spectral analyzer and transforms the audio signal into spectral data before further neural processing proceeds.
- the frequency-domain audio codecs often take advantage of many kinds of auditory masking that are going on with the human hear system to modify the original signal and eliminate a great many details/redundancies. Since the human ears are not capable of perceiving these modifications, efficient compression is achieved.
- Masking is usually conducted in conjunction with quantization so that quantization noise can be conveniently "masked.”
- the quantized spectral data are usually further compressed by applying entropy coding, e.g., Huffman coding. Compression is required because a fundamental limitation of the communication model is that transmission channels usually have limited capacity or bandwidth. Consequently, it is frequently necessary to reduce the information content of input data in order to allow it to be reliably transmitted, if at all, over the communication channel.
- Huffman encoding which is a particular form of entropy encoding.
- Entropy coding assigns code words to different input sequences, and stores all input sequences in a code book.
- the complexity of entropy encoding depends on the number m of possible values an input sequence X may take. For small m, there are few possible input combinations, and therefore the code book for the messages can be very small (e.g., only a few bits are needed to unambiguously represent all possible input sequences).
- the code alphabet is most likely a series of binary digits ⁇ 0, 1 ⁇ , and code word lengths are measured in bits.
- variable length sequences are assigned fixed length codes (or conversely, variable length sequences are assigned fixed length codes).
- variable-to-variable entropy encoder codes variable length input sequences with variable length codes.
- entropy-type codes may be assigned to only probable inputs, and alternate codes used to identify less probable sequences.
- each section may further be sorted according to the probability associated with the entry. For example, each section may be sorted with highest probable inputs located first in the section, thus increasing the likelihood that a match will be found quickly.
- Matching code cook entries depends on the internal representation of the book. For example, in a tree structure, nodes may represent each character of the input such that reaching a leaf signifies the end and identification of a particular grouping of input symbols.
- a pattern matching algorithm can be applied to each table entry within the appropriate section.
- searching may be facilitated by recognition that only as many input symbols as the longest grouping in the code book section need to be considered.
- the corresponding entropy-type code can be output and the search repeated with the next symbol following the matched input.
- the input stream is expected to be any data stream, such as numbers, characters, or a binary data which encodes audio, video or other types of data.
- the input stream is referenced herein as a series of symbols, where each "symbol” refers to the appropriate measurement unit for the particular input.
- the input stream may originate from local storage, or from intranets, the Internet, or streaming data (e.g., Microsoft's "NETSHOW”TM client/server streaming architecture).
- FIG. 1 is a block diagram of a computer system that may be used to implement variable to variable entropy encoding.
- FIG. 2 shows a basic communication model for transmitting streaming and non-streaming data.
- FIG. 3 is a flowchart showing creation of a code book having variable length entries for variable length symbol groupings.
- FIGS. 4-10 illustrate creation of a code book pursuant to FIG. 3 for an alphabet ⁇ A, B, C ⁇ .
- FIG. 1 1 shows encoding of audio data.
- FIG. 12 illustrates an entropy encoder.
- the invention has been implemented in an audio/visual codec (compressor/de-compressor). This is only one example of how the invention may be implemented.
- the invention is designed to be utilized wherever entropy-type coding may be utilized, and is applicable to compression of any type of data. Briefly described, optimal entropy encoding requires excessive resources, and the illustrated embodiments provide a nearly optimal encoding solution requiring far fewer resources.
- FIG. 1 and the following discussion are intended to provide a brief, general description of a suitable computing environment in which the invention may be implemented. While the invention will be described in the general context of computer- executable instructions of a computer program that runs on a personal computer, those skilled in the art will recognize that the invention also may be implemented in combination with other program modules. Generally, program modules include routines, programs, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.
- the illustrated embodiment of the invention also is practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. But, some embodiments of the invention can be practiced on stand alone computers. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
- an exemplary system for implementing the invention includes a computer 20, including a processing unit 21 , a system memory 22, and a system bus 23 that couples various system components including the system memory to the processing unit 21 .
- the processing unit may be any of various commercially available processors, including Intel x86, Pentium and compatible microprocessors from Intel and others, the Alpha processor by Digital, and the PowerPC from IBM and Motorola. Dual microprocessors and other multi-processor architectures also can be used as the processing unit 21.
- the system bus may be any of several types of bus structure including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of conventional bus architectures such as PCI, AGP, VESA, MicroChannel, ISA and EISA, to name a few.
- the system memory includes read only memory (ROM) 24 and random access memory (RAM) 25.
- ROM read only memory
- RAM random access memory
- BIOS basic input/output system
- BIOS basic routines that help to transfer information between elements within the computer 20, such as during start-up, is stored in ROM 24.
- the computer 20 further includes a hard disk drive 27, a magnetic disk drive 28, e.g., to read from or write to a removable disk 29, and an optical disk drive 30, e.g., for reading a CD-ROM disk 31 or to read from or write to other optical media.
- the hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 are connected to the system bus 23 by a hard disk drive interface 32, a magnetic disk drive interface 33, and an optical drive interface 34, respectively.
- the drives and their associated computer- readable media provide nonvolatile storage of data, data structures, computer-executable instructions, etc. for the computer 20.
- a number of program modules may be stored in the drives and RAM 25, including an operating system 35, one or more application programs (e.g., Internet browser software) 36, other program modules 37, and program data 38.
- application programs e.g., Internet browser software
- a user may enter commands and information into the computer 20 through a keyboard 40 and pointing device, such as a mouse 42.
- Other input devices may include a microphone, joystick, game pad, satellite dish, scanner, or the like.
- These and other input devices are often connected to the processing unit 21 through a serial port interface 46 that is coupled to the system bus, but may be connected by other interfaces, such as a parallel port, game port or a universal serial bus (USB).
- a monitor 47 or other type of display device is also connected to the system bus 23 via an interface, such as a video adapter 48.
- personal computers typically include other peripheral output devices (not shown), such as speakers and printers.
- the computer 20 is expected to operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 49.
- the remote computer 49 may be a web server, a router, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 20, although only a memory storage device 50 has been illustrated in FIG. 1 .
- the computer 20 can contact the remote computer 49 over an Internet connection established through a Gateway 55 (e.g., a router, dedicated-line, or other network link), a modem 54 link, or by an intra-office local area network (LAN) 51 or wide area network (WAN) 52.
- LAN local area network
- WAN wide area network
- the present invention is described below with reference to acts and symbolic representations of operations that are performed by the computer 20, unless indicated otherwise. Such acts and operations are sometimes referred to as being computer-executed. It will be appreciated that the acts and symbolically represented operations include the manipulation by the processing unit 21 of electrical signals representing data bits which causes a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in the memory system (including the system memory 22, hard drive 27, floppy disks 29, and CD-ROM 31 ) to thereby reconfigure or otherwise alter the computer system's operation, as well as other processing of signals.
- the memory locations where data bits are maintained are physical locations that have particular electrical, magnetic, or optical properties corresponding to the data bits.
- FIG. 2 shows a basic communication model.
- a data source or sender 200 there is a data source or sender 200, a communication channel 204, and a data receiver 208.
- the source may be someone speaking on a telephone, over telephone wires, to another person.
- the source may be a television or radio broadcast transmitted by wireless methods to television or radio receivers.
- the source may be a digital encoding of some data, whether audio, visual, or other, transmitted over a wired or wireless communication link (e.g., a LAN or the Internet) to a corresponding decoder for the information.
- a wired or wireless communication link e.g., a LAN or the Internet
- an encoder 202 is used to prepare the data source for transmission over the communication channel 204.
- the encoder is responsible for converting the source data into a format appropriate for the channel 204.
- a format appropriate for the channel 204 For example, in the context of a common telephone call, one's voice is typically converted by the phone's handset from voice sounds to analog impulses that are sent as analog data to local telephone receiving equipment. This analog signal is then converted into digital form, multiplexed with numerous other conversations similarly encoded, and transmitted over a common line towards the receiver.
- the channel 204 corresponds in large part to a common pathway shared by multiple senders and receivers.
- the channel 204 is commonly an intranet or the Internet.
- a decoder 206 is required to reverse the encoding process so as to present sensible data to the receiver.
- This simple model does not take into account, however, the real-world demands of application programs.
- a client e.g., an application program
- a streaming delivery system is required, i.e., an adaptive data transmission system that allows application-level bandwidth reservation for a data stream.
- Streaming environments contrast traditional networking programs, such as certain versions of Internet browsers that download web page content on a non-prioritized basis, and allow data content delivery over the network link 240 to be orchestrated (and optimized) for particular retrieval needs (such as a slow dial-up link).
- An exemplary streaming format is the Microsoft Active Streaming Format.
- a SF defines the structure of complex, synchronized object data streams. Any object can be placed into a SF data stream, including audio and video data objects, scripts, ActiveX controls, and HTML documents.
- SF data can be stored in a file or created in real-time using audio and video capture hardware.
- An Application Programming Interface corresponding to an implementation of the SF can provide an application with support for delivering and receiving streaming content.
- One such API is the Microsoft Audio Compression Manager (ACM), which provides functions for processing (e.g., compressing and delivering) audio data.
- ACM Microsoft Audio Compression Manager
- Win32 Internet Extensions (Winlnet), WinSock, and TCP/IP APIs.
- Winlnet Microsoft Win32 Internet Extensions
- WinSock WinSock
- TCP/IP APIs TCP/IP
- networks such as the internet convert the source data into packet form suitable for the network.
- Packets generally include routing information as well as the actual data.
- SF data streams are preferably made up of data packets that can be transmitted over any digital network by inserting them one at a time into the data field of network packets.
- Each SF packet may contain a prioritized mix of data from different objects within the stream, so that the bandwidth can be concentrated on higher priority objects (or organized to optimize throughput).
- This data can be captured in real time, stored to nonvolatile storage, converted from existing audio or video formats, created by combining audio with pictures and scripts, or delivered over the network to a client program or viewer.
- the client receiver 208 of the streaming data can be a traditional "helper" application (for compatibility with the old Web publishing approach), or a more modern web page control (e.g., an ActiveX object) embedded in a web page.
- SF data streams are distinguished over traditional network content as being viewed progressively in real time as a client receives it.
- playback of streamed content becomes susceptible to transmission delays. If data does not arrive reliably, or if transmission speed falls below an acceptable minimum, playback of the content cannot continue at an acceptable rate.
- Smooth-streaming playback at a client requires that the transmission require a bandwidth less than the client's available bandwidth (e.g. the speed of the link 204 less networking overhead).
- a dial-up connection to the Internet provides a bandwidth of 28-34 Kbps. Consequently, audiovisual source data (which is bandwidth intensive) must be significantly compressed to allow its transmission over low bit-rate connections. The degree of compression necessarily impacts the quality of the reproduced signal.
- a server provides multiple sources optimized for different networking speeds, or utilizes an adaptive feedback system to perform real-time analysis of the client's actual throughput.
- SF data packets are encoded 202 and placed inside network packets and sent over the network 204, the routing technology of the network takes care of delivering the network packets to the receiver 208.
- a variety of network and application protocols such as UDP, TCP, RTP, IP Multicast, IPX, and HTTP, are supported by the broadcast sender 200.
- Entropy coding capitalizes on data coherency, and is effective when symbols have non-uniform probability distribution.
- FIG. 3 is a flowchart showing a preferred method for generating an entropy encoder's code book.
- FIG. 3 illustrates how to create a code book having variable length code assignments for variable length symbol groupings.
- prior art techniques either require fixed-length codes or fixed blocks of input.
- Preferred implementations overcome the resource requirements of large dimension vector encoding, and the inapplicability of coding into words of equal lengths, by providing an entropy based variable-to-variable code, where variable length code words are used to encode variable length X sequences.
- Equation L 1 N *i .
- the leaf-node having highest probability is selected for extension (see also FIG. 3 discussion regarding processing sequence).
- group A 400 is tentatively expanded by each character in the alphabet (or one may limit the expansion to some subset thereof as described for creating the initial grouping).
- Probabilities are then recomputed with respect to the input stream "A A A B B A A C A B A B B A B” to determine values for the tentative extensions A 406, B 408, and C 410.
- the result is nine parsing groups, where "A A” appears 2/9, "A B” appears 4/9, and "A C" appears 0/9.
- FIG. 6 shows the collapse into X1 for FIG. 5. Processing repeats with identification of the node having highest probability, e.g., node B 408 at probability 4/9.
- this node 408 is tentatively extended with symbols A 414, B 416, C 418, and as discussed above, the tentative grouping with highest probability is retained. After recalculating probabilities, the result is eight parsing groups in which the symbol sequence "A B A” 414 appears once, "A B B” 416 appears once, and
- the next step is to expand the node currently having highest probability with respect to the input stream.
- the highest node in the tree (XO 402) is extended. (Although it is only necessary to be consistent, it is preferable to expand higher level nodes since this may increase coding efficiency by increasing the number of long code words.)
- FIG. 1 1 shows a transmission model for transmitting audio data over a channel 460.
- channel 460 is of limited bandwidth, and therefore some compression of source data 450 is required before the data can be reliably sent.
- this discussion focuses on transmission of audio data, the invention applies to transfer of other data, such as audio visual information having embedded audio data (e.g., multiplexed within an MPEG data stream), or other data sources having compressible data patterns (e.g., coherent data).
- source data 450 is input to a time / frequency transform encoder 352 such as a filter bank or discrete-cosine type transform.
- Transform encoder 452 is designed so as to convert a continuous or sampled time-domain input, such as an audio data source, into multiple frequency bands of predetermined (although perhaps differing) bandwidth. These bands can then be analyzed with respect to a human auditory perception model 454 (for example, a psychoacoustic model) in order to determine components of the signal that may be safely reduced without audible impact. For example, it is well known that certain frequencies are inaudible when certain other sounds or frequencies are present in the input signal (simultaneous masking). Consequently, such inaudible signals can be safely removed from the input signal.
- Use of human auditory models is well known, e.g., the MPEG 1 , 2 and 4 standards. (Note that such models may be combined into a quantization 456 operation.)
- frequency coefficients within each range are quantized 456 to convert each coefficient (amplitude levels) to a value taken from a finite set of possible values, where each value has a size based on the bits allocated to representing the frequency range.
- the quantizer may be a conventional uniform or non-uniform quantizer, such as a midriser or midtreader quantizer with (or without) memory.
- the general quantization goal is identifying an optimum bit allocation for representing the input signal data, i.e., to distribute usage of available encoding bits to ensure encoding the (acoustically) significant portions of the source data.
- Various quantization methods such as quantization step size prediction to meet a desired bit rate (assuming constant bit rate) can be used.
- FIG. 1 2 shows one method for implementing the entropy encoder 458 of FIG. 1 1 through application of the code book of FIG. 3 to the quantized data.
- the code book for variable-to-variable encoding can be used to encode other types of data.
- the quantized data is received 480 as input to the entropy encoder 458 of FIG. 1 1 . It is understood that the input is in some form of discrete signals or data packets, and that for simplicity of discussion, all input is simply assumed to be a long series of discrete symbols.
- the received input 480 is scanned 482 in order to locate 484 a corresponding code book key in the code book of FIG. 3. Such scanning corresponds to a data look-up, and depending on how the data structure used to implement the code book, the exact method of look-up will vary.
- One structure for a code book is traversal and storage of a N-ary (e.g., binary, tertiary, etc.) tree, where symbol groupings guide a traversal of the tree structure.
- the path to a leaf node of the tree represents the end of a recognized symbol sequence, where a entropy-type code is associated with the sequence.
- Nodes can be coded in software as a structure, class definition, or other structure allowing storage of a symbol or symbols associated with the node, and association of a corresponding entropy-type code 486.
- the code book may be structured as a table having each string of input symbol sorted by probability of occurrence, with highly probable input at the top of the table.
- the table can be sorted according to the first symbol, i.e., all symbol series beginning with "A” are grouped together, followed by series starting with "B", etc. With this arrangement, all entries within the grouping are sorted according to their probabilities of occurrence. The position of the beginning of each section is marked/tracked so that a hash-type function (e.g., a look-up based on the first symbol) can be used to locate the correct portion of the code book table.
- a hash-type function e.g., a look-up based on the first symbol
- the corresponding table section is exhaustively searched until a matching entry is located.
- the code 484 associated with the matching entry is then output 486 as the encoded substitute.
- this output is transmitted over the communication channel 460.
- the receiving end 470 implements a reverse-encoding process, i.e., a series of steps to undo the encoding of the source data 450. That is, the encoded data 486 is received as input to an entropy decoder 462 which performs a reverse code book look-up to convert the encoded output 486 back into the original input symbol series 480 (FIG. 12).
- the recovered input data 480 is then processed by a de-quantizer 464 and time/frequency transform decoder 466 to reverse the original coding operations, resulting in a reconstructed data 468 that is similar to the original source data 450. It should be noted that the reconstructed data 468 only approximates the original source data 450 when, as it presumed herein, a lossy system is employed.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
- Vehicle Body Suspensions (AREA)
Priority Applications (4)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| DE69918172T DE69918172T2 (de) | 1998-12-14 | 1999-12-07 | Entropiekodierung von variabler zu variabler länge |
| EP99966062A EP1142129B1 (en) | 1998-12-14 | 1999-12-07 | Variable to variable length entropy encoding |
| AT99966062T ATE269605T1 (de) | 1998-12-14 | 1999-12-07 | Entropiekodierung von variabler zu variabler länge |
| JP2000588900A JP4559632B2 (ja) | 1998-12-14 | 1999-12-07 | 可変長対可変長エントロピー符号化 |
Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| US09/211,294 | 1998-12-14 | ||
| US09/211,294 US6377930B1 (en) | 1998-12-14 | 1998-12-14 | Variable to variable length entropy encoding |
Publications (1)
| Publication Number | Publication Date |
|---|---|
| WO2000036752A1 true WO2000036752A1 (en) | 2000-06-22 |
Family
ID=22786310
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| PCT/US1999/029108 Ceased WO2000036752A1 (en) | 1998-12-14 | 1999-12-07 | Variable to variable length entropy encoding |
Country Status (6)
| Country | Link |
|---|---|
| US (1) | US6377930B1 (enExample) |
| EP (1) | EP1142129B1 (enExample) |
| JP (1) | JP4559632B2 (enExample) |
| AT (1) | ATE269605T1 (enExample) |
| DE (1) | DE69918172T2 (enExample) |
| WO (1) | WO2000036752A1 (enExample) |
Cited By (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| EP1905000A4 (en) * | 2005-07-15 | 2009-08-26 | Microsoft Corp | SELECTIVE USE OF MULTIPLE ENTROPICAL MODELS FOR ADAPTIVE CODING AND DECODING |
| US7987492B2 (en) | 2000-03-09 | 2011-07-26 | Gad Liwerant | Sharing a streaming video |
| EP2757719A1 (en) * | 2012-12-18 | 2014-07-23 | Telefonaktiebolaget L M Ericsson AB (Publ) | System and method for communicating information in a wireless network |
| US9172965B2 (en) | 2008-05-02 | 2015-10-27 | Microsoft Technology Licensing, Llc | Multi-level representation of reordered transform coefficients |
| US10225584B2 (en) | 1999-08-03 | 2019-03-05 | Videoshare Llc | Systems and methods for sharing video with advertisements over a network |
Families Citing this family (44)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US6704864B1 (en) * | 1999-08-19 | 2004-03-09 | L.V. Partners, L.P. | Automatic configuration of equipment software |
| US7386600B1 (en) | 1998-09-11 | 2008-06-10 | Lv Partners, L.P. | Launching a web site using a personal device |
| US7392945B1 (en) | 1998-09-11 | 2008-07-01 | Lv Partners, L.P. | Portable scanner for enabling automatic commerce transactions |
| US7191247B1 (en) | 1998-09-11 | 2007-03-13 | Lv Partners, Lp | Method for connecting a wireless device to a remote location on a network |
| US7379901B1 (en) | 1998-09-11 | 2008-05-27 | Lv Partners, L.P. | Accessing a vendor web site using personal account information retrieved from a credit card company web site |
| US7370114B1 (en) | 1998-09-11 | 2008-05-06 | Lv Partners, L.P. | Software downloading using a television broadcast channel |
| US7284066B1 (en) | 1998-09-11 | 2007-10-16 | Lv Partners, Lp | Method and apparatus for matching a user's use profile in commerce with a broadcast |
| US6823388B1 (en) | 1998-09-11 | 2004-11-23 | L.V. Parners, L.P. | Method and apparatus for accessing a remote location with an optical reader having a programmable memory system |
| US6868433B1 (en) | 1998-09-11 | 2005-03-15 | L.V. Partners, L.P. | Input device having positional and scanning capabilities |
| US7536478B2 (en) | 1998-09-11 | 2009-05-19 | Rpx-Lv Acquisition Llc | Method and apparatus for opening and launching a web browser in response to an audible signal |
| US7440993B1 (en) | 1998-09-11 | 2008-10-21 | Lv Partners, L.P. | Method and apparatus for launching a web browser in response to scanning of product information |
| US6636896B1 (en) | 1998-09-11 | 2003-10-21 | Lv Partners, L.P. | Method and apparatus for utilizing an audibly coded signal to conduct commerce over the internet |
| US7159037B1 (en) | 1998-09-11 | 2007-01-02 | Lv Partners, Lp | Method and apparatus for utilizing an existing product code to issue a match to a predetermined location on a global network |
| US6745234B1 (en) | 1998-09-11 | 2004-06-01 | Digital:Convergence Corporation | Method and apparatus for accessing a remote location by scanning an optical code |
| DE19907729C2 (de) * | 1999-02-23 | 2001-02-22 | Fraunhofer Ges Forschung | Verfahren und Vorrichtung zum Erzeugen eines Datenstroms aus Codeworten variabler Länge und Verfahren und Vorrichtung zum Lesen eines Datenstroms aus Codeworten variabler Länge |
| DE19907964C1 (de) * | 1999-02-24 | 2000-08-10 | Fraunhofer Ges Forschung | Vorrichtung und Verfahren zum Erzeugen eines verschlüsselten Datenstroms und Vorrichtung und Verfahren zum Erzeugen eines entschlüsselten Audio- und/oder Videosignals |
| US6687663B1 (en) * | 1999-06-25 | 2004-02-03 | Lake Technology Limited | Audio processing method and apparatus |
| US6961011B2 (en) * | 2001-08-27 | 2005-11-01 | Freescale Semiconductor, Inc. | Data compression system |
| US6934677B2 (en) * | 2001-12-14 | 2005-08-23 | Microsoft Corporation | Quantization matrices based on critical band pattern information for digital audio wherein quantization bands differ from critical bands |
| US7016547B1 (en) * | 2002-06-28 | 2006-03-21 | Microsoft Corporation | Adaptive entropy encoding/decoding for screen capture content |
| US7433824B2 (en) * | 2002-09-04 | 2008-10-07 | Microsoft Corporation | Entropy coding by adapting coding between level and run-length/level modes |
| ATE449405T1 (de) | 2002-09-04 | 2009-12-15 | Microsoft Corp | Entropische kodierung mittels anpassung des kodierungsmodus zwischen niveau- und lauflängenniveau-modus |
| US7123774B2 (en) * | 2002-11-27 | 2006-10-17 | General Electric Company | System and method for coding data |
| JP4165298B2 (ja) * | 2003-05-29 | 2008-10-15 | 株式会社日立製作所 | 端末装置、及び通信網の切替え方法 |
| US7313817B2 (en) * | 2003-06-17 | 2007-12-25 | Lockheed Martin Corporation | Data transmission system utilizing efficient complexity estimation of the kolmogorov complexity for data transmission |
| US7688894B2 (en) * | 2003-09-07 | 2010-03-30 | Microsoft Corporation | Scan patterns for interlaced video content |
| US7782954B2 (en) * | 2003-09-07 | 2010-08-24 | Microsoft Corporation | Scan patterns for progressive video content |
| US7724827B2 (en) * | 2003-09-07 | 2010-05-25 | Microsoft Corporation | Multi-layer run level encoding and decoding |
| US7693709B2 (en) * | 2005-07-15 | 2010-04-06 | Microsoft Corporation | Reordering coefficients for waveform coding or decoding |
| US7684981B2 (en) * | 2005-07-15 | 2010-03-23 | Microsoft Corporation | Prediction of spectral coefficients in waveform coding and decoding |
| US8599925B2 (en) * | 2005-08-12 | 2013-12-03 | Microsoft Corporation | Efficient coding and decoding of transform blocks |
| US7565018B2 (en) * | 2005-08-12 | 2009-07-21 | Microsoft Corporation | Adaptive coding and decoding of wide-range coefficients |
| US7933337B2 (en) * | 2005-08-12 | 2011-04-26 | Microsoft Corporation | Prediction of transform coefficients for image compression |
| US8184710B2 (en) * | 2007-02-21 | 2012-05-22 | Microsoft Corporation | Adaptive truncation of transform coefficient data in a transform-based digital media codec |
| US7774205B2 (en) * | 2007-06-15 | 2010-08-10 | Microsoft Corporation | Coding of sparse digital media spectral data |
| KR101449434B1 (ko) * | 2008-03-04 | 2014-10-13 | 삼성전자주식회사 | 복수의 가변장 부호 테이블을 이용한 멀티 채널 오디오를부호화/복호화하는 방법 및 장치 |
| US8406307B2 (en) | 2008-08-22 | 2013-03-26 | Microsoft Corporation | Entropy coding/decoding of hierarchically organized data |
| GB2466666B (en) * | 2009-01-06 | 2013-01-23 | Skype | Speech coding |
| KR20110011357A (ko) * | 2009-07-28 | 2011-02-08 | 삼성전자주식회사 | 비트의 순서를 변경한 데이터의 부호화, 복호화 방법 및 장치 |
| US8572042B2 (en) * | 2011-01-25 | 2013-10-29 | Andrew LEPPARD | Manipulating the actual or effective window size in a data-dependant variable-length sub-block parser |
| US10049140B2 (en) * | 2015-08-28 | 2018-08-14 | International Business Machines Corporation | Encoding system, method, and recording medium for time grams |
| US10069519B1 (en) * | 2018-01-23 | 2018-09-04 | Mitsubishi Electric Research Laboratories, Inc. | Partition based distribution matcher for probabilistic constellation shaping |
| GB201804948D0 (en) * | 2018-03-27 | 2018-05-09 | Nchain Holdings Ltd | Computer implemented system and method |
| CN114203165A (zh) * | 2021-11-30 | 2022-03-18 | 南京理工大学 | 一种老年人不完整语音快速识别方法及系统 |
Citations (7)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| JPS62247626A (ja) * | 1986-04-19 | 1987-10-28 | Fuji Photo Film Co Ltd | 符号化方法 |
| US4744085A (en) * | 1985-04-13 | 1988-05-10 | Canon Kabushiki Kaisha | Data processing device |
| EP0283735A2 (en) * | 1987-02-24 | 1988-09-28 | Hayes Microcomputer Products, Inc. | Adaptive data compression method and apparatus |
| EP0535571A2 (en) * | 1991-09-30 | 1993-04-07 | Eastman Kodak Company | Modified Huffman encode/decode system with simplified decoding for imaging systems |
| JPH09232968A (ja) * | 1996-02-23 | 1997-09-05 | Kokusai Denshin Denwa Co Ltd <Kdd> | 可変長符号生成装置 |
| WO1998040969A2 (en) * | 1997-03-14 | 1998-09-17 | J.Stream, Inc. | Text file compression system |
| US5959560A (en) * | 1997-02-07 | 1999-09-28 | Said; Amir | Data compression via alphabet partitioning and group partitioning |
Family Cites Families (36)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US4122440A (en) * | 1977-03-04 | 1978-10-24 | International Business Machines Corporation | Method and means for arithmetic string coding |
| US4464650A (en) | 1981-08-10 | 1984-08-07 | Sperry Corporation | Apparatus and method for compressing data signals and restoring the compressed data signals |
| US4558302A (en) | 1983-06-20 | 1985-12-10 | Sperry Corporation | High speed data compression and decompression apparatus and method |
| JPS61107818A (ja) | 1984-10-30 | 1986-05-26 | Nec Corp | エントロピ−符号化方式とその装置 |
| US5532694A (en) | 1989-01-13 | 1996-07-02 | Stac Electronics, Inc. | Data compression apparatus and method using matching string searching and Huffman encoding |
| US5003307A (en) | 1989-01-13 | 1991-03-26 | Stac, Inc. | Data compression apparatus with shift register search means |
| US5479562A (en) | 1989-01-27 | 1995-12-26 | Dolby Laboratories Licensing Corporation | Method and apparatus for encoding and decoding audio information |
| DE3912605B4 (de) | 1989-04-17 | 2008-09-04 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Digitales Codierverfahren |
| US5254990A (en) | 1990-02-26 | 1993-10-19 | Fujitsu Limited | Method and apparatus for compression and decompression of data |
| US5049881A (en) | 1990-06-18 | 1991-09-17 | Intersecting Concepts, Inc. | Apparatus and method for very high data rate-compression incorporating lossless data compression and expansion utilizing a hashing technique |
| US5530866A (en) * | 1991-07-30 | 1996-06-25 | Tera Computer Company | Register allocation methods having upward pass for determining and propagating variable usage information and downward pass for binding; both passes utilizing interference graphs via coloring |
| US5229768A (en) * | 1992-01-29 | 1993-07-20 | Traveling Software, Inc. | Adaptive data compression system |
| US5227788A (en) * | 1992-03-02 | 1993-07-13 | At&T Bell Laboratories | Method and apparatus for two-component signal compression |
| US5406279A (en) * | 1992-09-02 | 1995-04-11 | Cirrus Logic, Inc. | General purpose, hash-based technique for single-pass lossless data compression |
| US5442350A (en) | 1992-10-29 | 1995-08-15 | International Business Machines Corporation | Method and means providing static dictionary structures for compressing character data and expanding compressed data |
| JP2505980B2 (ja) | 1993-04-16 | 1996-06-12 | インターナショナル・ビジネス・マシーンズ・コーポレイション | 静的辞書作成方法及びコンピュ―タ実行システム |
| JP3210996B2 (ja) | 1993-07-30 | 2001-09-25 | 三菱電機株式会社 | 高能率符号化装置及び高能率復号化装置 |
| US5550541A (en) | 1994-04-01 | 1996-08-27 | Dolby Laboratories Licensing Corporation | Compact source coding tables for encoder/decoder system |
| JP3278297B2 (ja) | 1994-07-20 | 2002-04-30 | 富士通株式会社 | データ圧縮方法及びデータ復元方法並びにデータ圧縮装置及びデータ復元装置 |
| US5623262A (en) * | 1994-08-17 | 1997-04-22 | Apple Computer, Inc. | Multi-word variable length encoding and decoding |
| JPH08167852A (ja) * | 1994-12-13 | 1996-06-25 | Fujitsu Ltd | データ圧縮方法及び装置 |
| JPH08205169A (ja) * | 1995-01-20 | 1996-08-09 | Matsushita Electric Ind Co Ltd | 動画像符号化装置及び復号装置 |
| EP0731614B1 (en) | 1995-03-10 | 2002-02-06 | Kabushiki Kaisha Toshiba | Video coding/decoding apparatus |
| US5884269A (en) | 1995-04-17 | 1999-03-16 | Merging Technologies | Lossless compression/decompression of digital audio data |
| JP3181809B2 (ja) | 1995-05-31 | 2001-07-03 | シャープ株式会社 | データ圧縮のための圧縮コードの復元回路 |
| US5825830A (en) | 1995-08-17 | 1998-10-20 | Kopf; David A. | Method and apparatus for the compression of audio, video or other data |
| US5819215A (en) * | 1995-10-13 | 1998-10-06 | Dobson; Kurt | Method and apparatus for wavelet based data compression having adaptive bit rate control for compression of digital audio or other sensory data |
| US5933104A (en) | 1995-11-22 | 1999-08-03 | Microsoft Corporation | Method and system for compression and decompression using variable-sized offset and length fields |
| US5831559A (en) | 1996-01-24 | 1998-11-03 | Intel Corporation | Encoding/decoding video signals using multiple run-val mapping tables |
| JP3566441B2 (ja) | 1996-01-30 | 2004-09-15 | シャープ株式会社 | テキスト圧縮用辞書作成装置 |
| JP3277792B2 (ja) | 1996-01-31 | 2002-04-22 | 株式会社日立製作所 | データ圧縮方法および装置 |
| US5790706A (en) | 1996-07-03 | 1998-08-04 | Motorola, Inc. | Method and apparatus for scanning of transform coefficients |
| US6100824A (en) | 1998-04-06 | 2000-08-08 | National Dispatch Center, Inc. | System and method for data compression |
| US6029126A (en) | 1998-06-30 | 2000-02-22 | Microsoft Corporation | Scalable audio coder and decoder |
| US6300888B1 (en) * | 1998-12-14 | 2001-10-09 | Microsoft Corporation | Entrophy code mode switching for frequency-domain audio coding |
| US6223162B1 (en) * | 1998-12-14 | 2001-04-24 | Microsoft Corporation | Multi-level run length coding for frequency-domain audio coding |
-
1998
- 1998-12-14 US US09/211,294 patent/US6377930B1/en not_active Expired - Lifetime
-
1999
- 1999-12-07 WO PCT/US1999/029108 patent/WO2000036752A1/en not_active Ceased
- 1999-12-07 JP JP2000588900A patent/JP4559632B2/ja not_active Expired - Lifetime
- 1999-12-07 EP EP99966062A patent/EP1142129B1/en not_active Expired - Lifetime
- 1999-12-07 DE DE69918172T patent/DE69918172T2/de not_active Expired - Lifetime
- 1999-12-07 AT AT99966062T patent/ATE269605T1/de not_active IP Right Cessation
Patent Citations (8)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US4744085A (en) * | 1985-04-13 | 1988-05-10 | Canon Kabushiki Kaisha | Data processing device |
| JPS62247626A (ja) * | 1986-04-19 | 1987-10-28 | Fuji Photo Film Co Ltd | 符号化方法 |
| EP0283735A2 (en) * | 1987-02-24 | 1988-09-28 | Hayes Microcomputer Products, Inc. | Adaptive data compression method and apparatus |
| EP0535571A2 (en) * | 1991-09-30 | 1993-04-07 | Eastman Kodak Company | Modified Huffman encode/decode system with simplified decoding for imaging systems |
| JPH09232968A (ja) * | 1996-02-23 | 1997-09-05 | Kokusai Denshin Denwa Co Ltd <Kdd> | 可変長符号生成装置 |
| US5883589A (en) * | 1996-02-23 | 1999-03-16 | Kokusai Denshin Denwa Co., Ltd. | Variable length code construction apparatus |
| US5959560A (en) * | 1997-02-07 | 1999-09-28 | Said; Amir | Data compression via alphabet partitioning and group partitioning |
| WO1998040969A2 (en) * | 1997-03-14 | 1998-09-17 | J.Stream, Inc. | Text file compression system |
Non-Patent Citations (2)
| Title |
|---|
| PATENT ABSTRACTS OF JAPAN vol. 012, no. 118 (E - 600) 13 April 1988 (1988-04-13) * |
| PATENT ABSTRACTS OF JAPAN vol. 1998, no. 01 30 January 1998 (1998-01-30) * |
Cited By (9)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| US10225584B2 (en) | 1999-08-03 | 2019-03-05 | Videoshare Llc | Systems and methods for sharing video with advertisements over a network |
| US10362341B2 (en) | 1999-08-03 | 2019-07-23 | Videoshare, Llc | Systems and methods for sharing video with advertisements over a network |
| US7987492B2 (en) | 2000-03-09 | 2011-07-26 | Gad Liwerant | Sharing a streaming video |
| US10277654B2 (en) | 2000-03-09 | 2019-04-30 | Videoshare, Llc | Sharing a streaming video |
| US10523729B2 (en) | 2000-03-09 | 2019-12-31 | Videoshare, Llc | Sharing a streaming video |
| EP1905000A4 (en) * | 2005-07-15 | 2009-08-26 | Microsoft Corp | SELECTIVE USE OF MULTIPLE ENTROPICAL MODELS FOR ADAPTIVE CODING AND DECODING |
| NO341186B1 (no) * | 2005-07-15 | 2017-09-04 | Microsoft Technology Licensing Llc | Selektiv anvendelse ved bruk av flere entropimodeller i adaptiv koding og dekoding |
| US9172965B2 (en) | 2008-05-02 | 2015-10-27 | Microsoft Technology Licensing, Llc | Multi-level representation of reordered transform coefficients |
| EP2757719A1 (en) * | 2012-12-18 | 2014-07-23 | Telefonaktiebolaget L M Ericsson AB (Publ) | System and method for communicating information in a wireless network |
Also Published As
| Publication number | Publication date |
|---|---|
| DE69918172D1 (de) | 2004-07-22 |
| ATE269605T1 (de) | 2004-07-15 |
| EP1142129B1 (en) | 2004-06-16 |
| EP1142129A1 (en) | 2001-10-10 |
| JP4559632B2 (ja) | 2010-10-13 |
| DE69918172T2 (de) | 2009-10-01 |
| US6377930B1 (en) | 2002-04-23 |
| JP2002533006A (ja) | 2002-10-02 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| EP1142129B1 (en) | Variable to variable length entropy encoding | |
| EP1142130B1 (en) | Entropy code mode switching for frequency-domain audio coding | |
| US6223162B1 (en) | Multi-level run length coding for frequency-domain audio coding | |
| EP1147612B1 (en) | Code book construction for variable to variable length entropy encoding | |
| US11044495B1 (en) | Systems and methods for variable length codeword based data encoding and decoding using dynamic memory allocation | |
| US6985965B2 (en) | Static information knowledge used with binary compression methods | |
| CA2438309C (en) | Method and apparatus for adaptive data compression | |
| US6883035B2 (en) | System and method for communicating with temporary compression tables | |
| CN1201289C (zh) | 数字信号的编码和解码方法 | |
| US6373411B1 (en) | Method and apparatus for performing variable-size vector entropy coding | |
| CA2428788C (en) | Static information knowledge used with binary compression methods | |
| US6668092B1 (en) | Memory efficient variable-length encoding/decoding system | |
| US20030018647A1 (en) | System and method for data compression using a hybrid coding scheme | |
| KR101381602B1 (ko) | 계층적 부호화 및 복호화 방법 및 장치 | |
| Abate Tefera et al. | Compressed Amharic Text: A Prediction by Partial Match Context-Modeling Algorithm | |
| HK40073688B (zh) | 音频转码方法、装置、音频转码器、设备以及存储介质 | |
| JP2005283692A (ja) | オーディオ信号圧縮方法 |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| AK | Designated states |
Kind code of ref document: A1 Designated state(s): JP |
|
| AL | Designated countries for regional patents |
Kind code of ref document: A1 Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE |
|
| 121 | Ep: the epo has been informed by wipo that ep was designated in this application | ||
| DFPE | Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101) | ||
| ENP | Entry into the national phase |
Ref country code: JP Ref document number: 2000 588900 Kind code of ref document: A Format of ref document f/p: F |
|
| WWE | Wipo information: entry into national phase |
Ref document number: 1999966062 Country of ref document: EP |
|
| WWP | Wipo information: published in national office |
Ref document number: 1999966062 Country of ref document: EP |
|
| WWG | Wipo information: grant in national office |
Ref document number: 1999966062 Country of ref document: EP |