US20070247515A1 - Handheld video transmission and display - Google Patents
Handheld video transmission and display Download PDFInfo
- Publication number
- US20070247515A1 US20070247515A1 US11/823,493 US82349307A US2007247515A1 US 20070247515 A1 US20070247515 A1 US 20070247515A1 US 82349307 A US82349307 A US 82349307A US 2007247515 A1 US2007247515 A1 US 2007247515A1
- Authority
- US
- United States
- Prior art keywords
- video
- handheld
- receiver
- user
- video receiver
- 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.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/14—Systems for two-way working
- H04N7/141—Systems for two-way working between two video terminals, e.g. videophone
- H04N7/148—Interfacing a video terminal to a particular transmission medium, e.g. ISDN
-
- 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/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/132—Sampling, masking or truncation of coding units, e.g. adaptive resampling, frame skipping, frame interpolation or high-frequency transform coefficient masking
-
- 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/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/136—Incoming video signal characteristics or properties
-
- 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/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/184—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being bits, e.g. of the compressed video stream
-
- 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/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/59—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial sub-sampling or interpolation, e.g. alteration of picture size or resolution
-
- 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N23/00—Cameras or camera modules comprising electronic image sensors; Control thereof
- H04N23/60—Control of cameras or camera modules
- H04N23/62—Control of parameters via user interfaces
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/14—Systems for two-way working
- H04N7/141—Systems for two-way working between two video terminals, e.g. videophone
- H04N7/142—Constructional details of the terminal equipment, e.g. arrangements of the camera and the display
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/14—Systems for two-way working
- H04N7/141—Systems for two-way working between two video terminals, e.g. videophone
- H04N7/147—Communication arrangements, e.g. identifying the communication as a video-communication, intermediate storage of the signals
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/14—Systems for two-way working
- H04N7/15—Conference systems
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/14—Systems for two-way working
- H04N7/141—Systems for two-way working between two video terminals, e.g. videophone
- H04N7/142—Constructional details of the terminal equipment, e.g. arrangements of the camera and the display
- H04N2007/145—Handheld terminals
Definitions
- This invention relates to handheld devices for video transmission, including video capture, wired and wireless file transfer and live streaming, and display.
- Embodiments of the invention relate to data compression, specifically to the compression and decompression of video and still images, and relate to graphical user interfaces for controlling video transmission and display.
- Standard video signals are analog in nature. In the United States, television signals contain 525 scan lines of which 480 lines are visible on most televisions.
- the video signal represents a continuous stream of still images, also known as frames, that are fully scanned, transmitted and displayed at a rate of 30 frames per second. This frame rate is considered full motion.
- a television screen has a 4:3 aspect ratio.
- each of the 480 lines is sampled 640 times, and each sample is represented by a number.
- Each sample point is called a picture element, or pixel.
- a two dimensional array is created that is 640 pixels wide and 480 pixels high. This 640 ⁇ 480 pixel array is a still graphical image that is considered to be full frame.
- the human eye can perceive 16.7 thousand colors.
- a pixel value comprised of 24 bits can represent each perceivable color.
- a graphical image made up of 24-bit pixels is considered to be full color.
- a single, second-long, full frame, full color video requires over 220 millions bits of data.
- the transmission of 640 ⁇ 480 pixels ⁇ 24 bits per pixel times 30 frames requires the transmission of 221 , 184,000 million bits per second.
- a T1 Internet connection can transfer up to 1.54 million bits per second.
- a high-speed (56 Kb) modem can transfer data at a maximum rate of 56 thousand bits per second.
- the transfer of full motion, full frame, full color digital video over a T1 Internet connection, or 56 Kb modem, will require an effective data compression of over 144:1, or 3949:1, respectively.
- a video signal typically will contain some signal noise.
- the image is generated based on sampled data, such as an ultrasound machine, there is often noise and artificial spikes in the signal.
- a video signal recorded on magnetic tape may have fluctuations due the irregularities in the recording media. Florescent or improper lighting may cause a solid background to flicker or appear grainy. Such noise exists in the real world but may reduce the quality of the perceived image and lower the compression ratio that could be achieved by conventional methods.
- Huffman disclosed a more efficient approach of variable length encoding known as Huffman coding in a paper entitled “A Method for Construction of Minimum Redundancy Codes,” published in 1952. This approach also has failed to achieve the necessary compression ratios.
- Dictionary-based compression uses a completely different method to compress data. Variable length strings of symbols are encoded as single tokens. The tokens form an index to a dictionary.
- Abraham Lempel and Jacob Ziv published a paper entitled, “A Universal Algorithm for Sequential Data Compression” in IEEE Transactions on Information Theory, which disclosed a compression technique commonly known as LZ77.
- the same authors published a 1978 sequel entitled, “Compression of Individual Sequences via Variable-Rate Coding,” which disclosed a compression technique commonly known as LZ78 (see U.S. Pat. No. 4,464,650).
- JPEG Joint Photographic Experts Group
- JPEG can be scaled to perform higher compression ratio by allowing more loss in the quantization stage of the compression.
- this loss results in certain blocks of the image being compressed such that areas of the image have a blocky appearance and the edges of the 8 by 8 blocks become apparent because they no longer match the colors of their adjacent blocks.
- Another disadvantage of JPEG is smearing. The true edges in an image get blurred due to the lossy compression method.
- MPEG Moving Pictures Expert Group
- JPEG Joint Pictures Expert Group
- QuickTime compressor/decompressor codec
- Some popular codec are CinePak, Sorensen, and H.263.
- CinePak and Sorensen both require extensive computer processing to prepare a digital video sequence for playback in real time; neither can be used for live compression.
- H.263 compresses in real time but does so by sacrificing image quality resulting in severe blocking and smearing.
- Sub-sampling is the selection of a subset of data from a larger set of data. For example, when every other pixel of every other row of a video image is selected, the resulting image has half the width and half the height. This is image sub-sampling.
- Other types of sub-sampling include frame sub-sampling, area sub-sampling, and bit-wise sub-sampling.
- the original iPod has a display, a set of controls, and ports for connecting to a computer, such as a Macintosh or PC, via Firewire, and for connecting to headphones.
- a computer such as a Macintosh or PC
- Firewire for connecting to headphones.
- the original iPod did not have a color display, a built-in camera, built-in speakers, built-in microphone or wireless communications.
- the first cellular telephones had simple LCD displays suitable for displaying only a limited amount of text. More recently, cell phones have been developed which have larger, higher resolution displays that are both grayscale and color. Some cell phones have been equipped with built-in cameras with the ability to save JPEG still photos to internal memory. In April 2002, Samsung introduced a cell phone with a built-in still photo camera and a color display. The Samsung SCH-X590 can store up to 100 photos in its memory and can transfer still photos wirelessly.
- Cell phones can be used as wireless modems. Initially they had limited data bandwidth. Next, digital cell phones were developed. By early 2002, bandwidth was typically 60-70 Kbps. Higher bandwidth wireless networks are being developed.
- Hand held devices are limited in size and weight. Many users are only willing to use a handheld device that weights a few ounces and can fit inside a typical shirt pocket, or even worn on their waist or arm. These size and weight limitation prevent handheld devices from having the electronic circuitry, processors, and batteries found in laptops and other larger computers. These limitations have made it impossible to provide full frame, full motion video display or live transmission on handheld devices.
- PDAs, PocketPCs, and Picture Phones are Limited by Battery Life, Processor Speed, and Network Bandwidth
- a handheld device that could capture and transmit live video would provide live coverage of events that would otherwise not be able to be seen.
- handheld video devices that both transmit and receive live video handheld wireless videoconferencing could become a reality.
- a video compression method that requires significantly reduced processing power and would be less draining on the battery of a handheld device is needed.
- handheld video display screens which are smaller than typical computer screens, a user of a handheld video receiver needs to be able control the portion of a video be transmitted to allow a smaller, higher quality video to be received and viewed on the handheld screen with dimensions smaller than the original video.
- a handheld device comprises a black and white or color video display screen, speakers or headphones for hearing audio associated with the video display, controls for user input, a memory for storing compressed video data, and a processor for running computer programs which decompress the compressed video data and play the video on the display screen, and the video's audio on speakers and/or headphones. Further, some embodiments of the present invention include a microphone and video camera for inputting audio and video.
- a plurality of handheld video devices are connected to a network for exchanging video file, streaming video from a pre-recorded video file or live transmission from one device to one or more devices in remote locations.
- the network connections can be wired or wireless.
- One embodiment of the present invention comprises a video camera that can be removably mounted on an iPod-type device to add the video capture capability. Further the separate camera unit could include a microphone or speakers. Further, wireless communications could be added to the separate camera unit or as yet another removable unit.
- the present invention includes a method of compression of a video stream comprising steps of sub-sampling a video frame, and run-length encoding the sub-sampled pixel values, whereby the method can be executed in real time, and whereby the compressed representation of pixels saves substantial space on a storage medium and requires substantially less time and bandwidth to be transported over a communications link.
- the present invention includes a corresponding method for decompressing the encoded data.
- the present invention includes a zoom control that is graphically displayed on the display screen and receives input from either the touch screen or the controls of the handheld device.
- a user may use the zoom control to send remote control commands to a transmitting device to dynamically specify an area to be transmitted.
- the user may use the zoom control to magnify video that is being played from a file.
- FIG. 1 shows the high level steps of compression and decompression of an image.
- FIGS. 2A to 2 H show alternatives for selecting a pixel value for encoding.
- FIG. 3A shows the variable encoding format.
- FIG. 3B shows an example of a code where N is 5 bits wide and U is 3 bits wide.
- FIG. 4A shows the flowchart for the compression method.
- FIG. 4B shows an image and a corresponding stream of pixels.
- FIGS. 5A to 5 C shows the formats for the run-length encoding of the RHN method.
- FIG. 6 shows a series of codes and the resulting encoded stream.
- FIG. 7 shows a series of codes and the resulting encoded stream of the RHN method.
- FIG. 8A shows examples of variable formats.
- FIG. 8B shows a format that preserves 9 bits of color.
- FIG. 9 shows the flow chart for the decompression method.
- FIG. 10 shows image stretching by interpolation.
- FIGS. 11A and 11B show an encryption table and a decryption table.
- FIGS. 12A and 12B show machines for compressing and decompressing, respectively.
- FIG. 12C shows a compressor and decompressor connected to a storage medium.
- FIG. 12D shows a compressor and decompressor connected to a communications channel.
- FIG. 13A shows elements of a compressor.
- FIG. 13B shows an embodiment of an encoding circuit.
- FIG. 13C shows a generic pixel sub-sampler.
- FIGS. 13D through 13J show embodiments of pixel sub-samplers.
- FIGS. 14A through 14C shows embodiments of a machine element for variably altering the number of bits.
- FIG. 15 shows elements of a decompressor.
- FIG. 16A shows elements for setting width, height, frame rate, brightness, and contrast which are variably altered by a receiver.
- FIG. 16B shows elements for setting the number of pixel bits that are variably altered by a receiver.
- FIG. 17 shows a lossless compression step for further compression of an encoded data buffer.
- FIG. 18 shows images being enlarged by stretching.
- FIGS. 19A through 19C show various network configuration comprising handheld video devices.
- FIGS. 20A through 20D show various embodiments of handheld video devices.
- FIGS. 21A through 21C show handheld video devices comprising graphical zoom controls.
- FIG. 1 Compression and Decompression Steps
- FIG. 1 illustrates a sequence of compression steps 100 and a sequence of decompression steps 150 of the present invention.
- the compression steps 100 comprise a sub-sampling step 110 and an encoding step 130 .
- a stream of encoded data 140 is output to either a storage medium or a transmission channel.
- the decompression steps 150 comprise a decoding step 160 wherein the stream of encoded data 140 is processed and an image reconstitution step 180 .
- FIGS. 2A to 2 H Selecting Pixel Values for Encoding
- FIGS. 2A to 2 G illustrate alternatives for selecting a pixel value for encoding.
- the sub-sampling step 110 ( FIG. 1 ) includes sub-sampling of a pixel value to obtain a variable selected number of bits.
- Video digitizing hardware typical has the options of storing the pixel values as a 32 bit pixel value 200 or a 24 bit pixel value 210 , shown in FIG. 2A and FIG. 2B , respectively.
- the 32 bit pixel value 200 is composed of a blue channel 202 , a green channel 204 , a red channel 206 , and an alpha channel 208 .
- Each channel contain 8 bits and can represent 256 saturation levels for the particular color channel. For each channel the saturation intensity value of zero represents the fully off state, and the saturation intensity value of “255” represents the fully on state.
- a common alternative not shown is a sixteen-bit format where the three color channels contain 5 bits each and the alpha channel is a single bit.
- the present invention anticipates the use of the color channels of 16 bit pixel value is a manner substantially the same as the 32-bit pixel value 200 except the number of bits per channel is 5 instead of 8.
- the 24-bit pixel value 210 is composed of a blue component 212 , a green component 214 , and a red component 216 . There is no component for the alpha channel in the 24 bit pixel value 210 . Regardless of the structure, the blue channel 202 is equivalent to the blue component 212 , the green channel 204 is equivalent to the green component 214 , and the red channel 206 is equivalent to the red component 216 .
- the 32 bit pixel value 200 alternative is preferred due to the consistent alignment of 32 bit values in most computer memories; however for simplicity of illustration the alpha channel 208 will be omitted in FIGS. 2C to 2 G.
- a RGB averaging diagram 220 illustrates a blue value 222 of 35 decimal, a green value 224 of 15, and a red value 226 of 10.
- a color image can be preserved by sampling bits from each color component (see FIG. 8B ).
- FIG. 2D illustrates another alternative for selecting an 8 bit value in a blue selection diagram 230 .
- a blue instance 232 has the value of 35
- a green instance 234 has the value of 15
- a red instance 236 has the value of 10.
- the blue instance 232 is always selected as a selected blue value 240 .
- FIG. 2E illustrates another alternative for selecting an 8 bit value in a green selection diagram 250 .
- the green instance 234 is always selected as a selected green value 260 .
- FIG. 2F illustrates another alternative for selecting an 8 bit value in a red selection diagram 270 .
- the red instance 236 is always selected as a selected red value 280 .
- a grayscale pixel 290 comprises a grayscale blue 292 with a value of decimal 40, a grayscale green 294 with a value of 40, and a grayscale red with a value of 40. Because the values are all the same, it makes no difference which grayscale color component is selected, a selected grayscale value 298 will have the value of 40 in this example.
- the preferred embodiment of this invention uses the low order byte of the pixel value, which is typically the blue component as shown in FIG. 2D .
- FIG. 2H illustrates a filtered pixel value 299 of 8 bits that may be selected by one of the alternatives described above.
- the filtered pixel value 299 is equivalent to items referenced by numerals 228 , 240 , 260 , 280 , or 298 .
- This reduction of the 32 bit pixel value 200 or the 24 bit pixel value 210 contributes a reduction in data size of 4:1 or 3:1, respectively. This reduction recognizes that for some images, such as medical images or grayscale images, no relevant information is lost.
- the filtered pixel value 299 can variably select any number of bits. For example, selection of the most significant four bits instead of all eight bits filters noise that may show up in the low order bits may be very suitable for an image such as one produced by an ultrasound medical device. An example of this is shown by ZL4 804 in FIG. 8A .
- FIGS. 3 A and 3 Endcoding Formats
- Speed of compression and decompression may be enhanced if the algorithms fit into computer memory native storage elements such as 8 bit bytes, 16 bit words, or 32 bit double words, or some other size for which the computer architecture is optimized.
- a grayscale image may be stored at a higher bit level than the actual values require. This may occur when an image is generated by an imaging technology such as radar, ultrasound, x-ray, magnetic resonance, or similar electronic technology. For example an ultrasound machine may only produce 16 levels of grayscale, requiring 4 bits of data per pixel, but the image digitizing may be performed at 8 to 12 bits per pixel. In this example, the low order bits (4 to 8) respectively provide no significant image data.
- an imaging technology such as radar, ultrasound, x-ray, magnetic resonance, or similar electronic technology.
- an ultrasound machine may only produce 16 levels of grayscale, requiring 4 bits of data per pixel, but the image digitizing may be performed at 8 to 12 bits per pixel.
- the low order bits (4 to 8) respectively provide no significant image data.
- a fast and efficient compression and encoding method is implemented by using unused bits to store a repeat count for repeated values.
- N is the number of significant bits (determined by data analysis or by user selection). If N is less than W, where W is a native machine data type such as 8 bit byte, 16 bit word, or 32 bit double word or some other size for which the computer architecture is optimized, then W-N equals the number of unneeded bits, U.
- a repeat count, C can contain a value from 1 to CMAX where CMA is 2 to the power of U. For example, if U equals 4, C can be a number from 1 to 16. In practice the maximum value will be encoded as a zero because the high order bit is truncated. In the example, decimal 16 has a binary value “10000” will be stored as “0000”.
- value pairs for N and U could include without limitation (2,6), (3,5), (4,4), (5,3), and (6,2).
- value pairs for N and U could include without limitation (2,14), (3,13), (4,12), (5,11), (6,10), (7, 9), (8, 8), (9, 7), (10, 6), (11, 5), (12,4), (13, 3), and (14, 2).
- value pairs for N and U could include without limitation all combinations of values pairs for N and U where N+U equals 32 and N>1 and U>1.
- value pairs for N and U could include without limitation all combinations of values pairs for N and U where N+U equals W and N>1 and U>1.
- FIG. 3A shows the encoded format where N 300 represent the N most significant bits of the pixel value 299 , U 301 represents the bits that are not used for the data and are used for the repeat count, and W 302 where W is the width of the encoded data and equal to sum of N and U
- FIG. 3B illustrates bit sub-sampling where N's 300 bit width is 5, U's 301 bit width is 3, and W 302 is 8.
- the high order 5 bits 310 - 318 of an 8 bit pixel 325 are extracted to form a five bit sample 330 .
- the lower 3 bits of 330 are ignored bits 350 .
- the ignored bits 350 are replaced with the repeat count value 380 .
- V may be used to select an encoded value, E, from the encoding table.
- E is also a N-bit value.
- the number of elements in the encode table 1100 ( FIG. 11 ) is 2 to the Nth power.
- V is used as E.
- E is saved as the prior value, P.
- the encoded value, E is obtained and compared to the prior value, P. If the prior value, P, is the same as E, then a repeat counter, C, is incremented; otherwise the accumulated repeat count, C, for the prior value, P, is merged with P and placed in an array A that implements the encoded data 140 ( FIG. 1 ) buffer. For example, if W is 8 and N is 4 and C is 10, U is 4, CMAX is 16, and ((P ⁇ U)
- FIG. 4A Endcode Flowchart
- FIG. 4A illustrates the encode flowchart 400 which represents the details of the encryption embodiment of the encoding step 130 ( FIG. 1 ) for the present invention.
- the encoding begins at an encode entry 402 .
- a prior value P is set to a known value, preferably decimal “255” or hexadecimal 0xFF, a repeat counter C is set to zero, an encoded length L is set to 0, and a completion flag “Done” is set to a logical value of false.
- a get pixel step 404 obtains a pixel from the image being encoded.
- a value V is set to the N bit filtered pixel value 299 as derived from the pixel using one of the methods shown in FIGS. 2C to 2 G, preferably the fastest as explained above, and extracting the N most significant bits.
- an encoded value E is set to the value of one of the codes 1105 ( FIG. 11A ) of the encode table 1100 as indexed by V. (In the non-encrypted embodiment of this invention, step 406 is bypassed because V is used as E)
- a compare previous 408 decision is made by comparing the values of E and P. If the values are the same, an increment counter step 410 is executed and flow continues to the get pixel step 404 that obtains the next pixel from the image.
- a check count overflow 412 decision is made. If the counter C is less than or equal to CMAX, then a new code step 414 is executed, otherwise a counter overflow step 420 is executed.
- step 414 the counter C is masked and bit-wise OR-ed with P shifted left by U bit positions and is placed in the A at the next available location as indexed by the encoded length L. Then, continuing inside flowchart step 414 , L is incremented, the repeat count C is set to 1 and the prior value P is set to E.
- step 414 a “check end of data” decision is made by checking to see if there are any more pixels in the image, and, if not, if the last value has been processed. Because this method utilizes a read ahead technique step 414 must be executed one more time after the end of data is reached to process the last run-length. If there is more data in the image, flow continues to a check of the completion flag “Done” at step 422 . If the check indicates that the process is not completed, flow continues to step 404 .
- step 418 the completion flag “Done” is set to logical true, and flow continues to decision 412 where the last run-length will be output and flow will eventually exit through step 414 , decision 416 , decision 422 , and then terminate at encode exit 428 .
- the repeat count C It is possible for the repeat count C to become larger than CMAX requiring more bits than allocated by this method. This situation is handled by making the check count overflow 412 decision and executing the counter overflow step 420 .
- the counter C is masked and bit-wise OR-ed with P shifted left by U bit positions and is placed in the A at the next available location as indexed by the encoded length L. Then, continuing inside flowchart step 414 , L is incremented, and the repeat count C is decrement by CMAX.
- flow continues to the check count overflow 412 decision.
- the encode value E repeats more than CMAX times, multiple sets of repeat counts and encoded values are output to the encoded data 140 buffer.
- the encoded length L is transmitted with the encoded data associated with each frame.
- the encoded length varies from frame to frame depending on the content of the image being encoded.
- FIG. 4 Image and Pixel Stream
- FIG. 4B illustrates an image and its corresponding stream of pixels.
- a rectangular image 430 is composed of rows and columns of pixels.
- the image 430 has a width 440 and a height 450 , both measured in pixels.
- pixels in a row are accessed from left to right. Rows are accessed from top to bottom.
- Some pixels in the image are labeled from A to Z.
- Pixel A is the first pixel and pixel Z is the last pixel. Scanning left to right and top to bottom will produce a pixel stream 460 .
- pixels A and B are adjacent.
- pixels N and 0 are adjacent even though they appear on different rows in the image. If adjacent pixels have the same code the process in FIG. 4A will consider them in the same run.
- the video digitizing hardware can be configured to sample the analog data into the image 430 with almost any width 440 and any height 450 .
- the present invention achieves most of its effective compression by sub-sampling the data image with the width 440 value less than the conventional 640 and the height 450 value less than the convention 480 .
- image dimensions are sub-sampled at 320 by 240.
- an image dimension sub-sampling resolution of 80 by 60 may be suitable for some video application.
- FIGS. 5A to 5 C Random-length Encoding Formats of the RHN Method
- FIGS. 5A to 5 C show use of a different structure than the present invention.
- FIGS. 5A to 5 C show the formats for the run-length encoding of RHN.
- a code byte 500 with its high order bit designated as a flag bit 510 .
- FIG. 5B shows a repeat code 520 comprising a Boolean value one in its flag bit 510 and a 7 bit count 530 in the remaining 7 low order bits.
- the seven bit count 530 can represent 128 values with a zero representing “128” and 1 through 127 being their own value.
- FIG. 5C shows a data code 550 comprising:
- FIG. 5C shows that in every byte of the RHN data code 550 two bits are unused and one bit is used for the flag bit, so that only five of the eight bits are used for data. The remaining three bits are wasted bits 560 .
- the present invention uses a different structure by placing the repeat count in bits that the RHN format would not have used for data (U).
- the corresponding ZLN format, ZL5 (where N is 5, U is 3, and W is 8), always uses five bits for data and the remaining 3 bits for the repeat count.
- repeat counts are small and often can fit in 3 bits, so this embodiment of the present invention will result in superior compression performance over the RHN method.
- the present invention provides for a larger count when the bit filtering is larger.
- the alternate ZLN format where each byte contains 4 data bits, ZL4 (where N is 4 and U is 4), allows for a four bits of repeat count.
- ZIA is superior to RHN on a typical ultrasound image containing 16 shades of gray.
- FIG. 6 Encoded Data Stream
- FIG. 6 shows a series of exemplary decimal values 610 comprising a first value 620 equal to decimal 0, a second value 622 equal to 0, a third value 624 equal to 0, a fourth value 626 equal to 0, a fifth value 628 equal to 0, a sixth value 630 equal to 2, and a seventh value 632 equal to 10.
- the value of zero is merely exemplary and could be any binary value.
- the first data 651 has a binary value of “00000” which equals the exemplary repeated decimal value.
- the first count 652 has a binary value “101” which equals decimal five representing the run-length of the repeating value in the first five of the decimal values 610 .
- the second data 654 has a binary value of “00010” which equals the non-repeated decimal value two.
- the second count 655 has a value of 1.
- the third data 657 has a binary value of “01010” which equals the non-repeated decimal value ten.
- the third count 658 has a value of 1.
- FIG. 7 RHN Codes and Encoded Stream
- FIG. 7 shows the same series of decimal values 610 ( FIG. 6 ) comprising the first value 620 equal to decimal 0, the second value 622 equal to 0, the third value 624 equal to 0, the fourth value 626 equal to 0, the fifth value 728 equal to 0, the sixth value 730 equal to 2, and the seventh value 732 equal to 10.
- the embodiment of the present invention shown in FIG. 6 only requires three bytes to encode the same data.
- the present invention is 25% better than the RHN format.
- FIGS. 8 A and 8 ZLN Formats
- the ZLN method of the present invention provides for variable formats.
- the values of N 300 , U 301 , and W 302 can be dynamically changed between frames.
- a format is named with the prefix “ZL” and a digit representing the value of N.
- ZL5 refers to a format where bit width of N is equal to 5.
- U bit width of U
- W bit width of U
- ZL5- 3 is a common format and may be imprecisely referred to as “ZL5.”
- FIG. 8A shows a number of formats with adjacent labels: ZL3 803 , ZM4 804 , ZL5 805 , ZL8 808 , ZL9 809 , and ZL12 812 .
- Data bits are represented by “D,” and count bits are represented by “C”.
- FIG. 8B shows how the most significant 3 bits of each color component ( 216 , 214 , and 212 of FIG. 2B ) are extracted and formatted in ZL9-7C format (the “C” append indicates that the color is preserved). With three red bits represented by “R”, three green bits represented “G” and three blue bits represented by “B”.
- the decoder has a decode table that corresponds with the encode table.
- the decode table contains the appropriate alpha, red, green, and blue values.
- the alpha value is not used.
- the compressed array is processed W bits at a time as X.
- the encoded value, E may be used to index into the decryption.
- the decoded pixels are placed in a reconstructed image and repeated C times. Each element of the compressed array, A, is processed until its entire length, L, has been processed.
- FIG. 9 Decode Flowchart
- FIG. 9 illustrates the decode flowchart 920 which presents the details of the decryption embodiment of the decode step 160 ( FIG. 1 ) and the image reconstitution step 180 ( FIG. 1 ).
- the decoding begins at a decode entry 900 .
- a “decode initialization” step 901 a repeat counter C is set to one, an encoded length L is set to the value obtained with the encoded data 140 ( FIG. 1 ), and an index I is set to 0.
- a “get code” step 902 obtains a signed byte X from the encoded data 140 ( FIG. 1 ) array A. The index I is incremented.
- the count mask and value mask can be pre-computed with the following two lines of code in the C programming language:
- countMask ⁇ valueMask
- step 908 flow goes to a “decode lookup” step 908 where the value of E is used to index into the decode table 1110 ( FIG. 11 ) to obtain a pixel value V.
- E is used as V and step 908 is bypassed.
- Flow continues to a “check zero count” 909 decision.
- the 909 decision always fails the first time ensuring that a place pixel step 910 is executed.
- the place pixel step 910 places the pixel value V in the next location of the decompressed image and decrements the repeat counter C and returns to the 909 decision.
- the pixel value V is placed repeatedly until C decrements to zero.
- the 909 decision branches flow to a “reset counter” step 914 .
- the repeat counter is reset to 1.
- the entire decode process is repeated for each encoded frame image.
- FIG. 10 Interpolation
- FIG. 10 illustrates interpolation when two adjacent pixels 1010 and 1012 and two subsequent row adjacent pixels 1014 and 1016 are stretched to insert a new row and column of pixels.
- Pixels 1052 , 1054 , 1056 , 1058 and 1060 are inserted due to the enlargement of the image. Their values are calculated by averaging the values of the two pixels above and below or to the left or the right of the new pixel.
- a preferred sequence is calculation of:
- Pixel 1060 can be calculated on the interpolation for the subsequent row.
- FIG. 11 Encryption
- Encryption provides a level of security for the encoded data 140 while in storage or transit.
- FIG. 11 shows an example of an encryption table 1100 , where N is 3 and W is 8, and a decryption table 1110 , where N is 3 and U is 5.
- the encode table 1100 is 2 the power of N in length. If the target color image format is W*4 bit color, then the decode table 1110 has W bits for alpha, red, green, and blue each, respectively. If the target color image format is W*3 bit color, then the alpha value is not used. If the image is W bit grayscale then only the grayscale value is used to create the decompressed and decoded image.
- the corresponding table elements are mapped to each other. For example, 0 could encode to 22 as long as the 22 nd element of the decode table returns ( ⁇ xff ⁇ 24
- FIGS. 12 A through 12 D Compression and Decompression Devices
- FIGS. 12A and 12B show devices for compressing and decompressing, respectively, a stream video frames.
- FIG. 12A shows a video signal 1215 being compressed and encoded by a compressor 1210 to form an encoded data stream 1235 , which is sent to an I/O device 1240 .
- the video signal 1215 comprises a series of video frames 1200 , shown as first video frame 1205 a , second video frame 1205 b , . . . through nth video frame 1205 n .
- the encoded data stream 1235 comprises a series of encoded data 1220 , shown as first encoded data 1225 a , second encoded data 1225 b , . . . , through nth encoded data 1225 n.
- FIG. 12B shows an input encoded data stream 1245 being received from an I/O device 1240 , and then, decoded and decompressed by a decompressor 1250 to form a video sequence 1270 .
- the input encoded data stream 1245 comprises received encoded data 1238 , shown as first received encoded data 1230 a , second received encoded data 1230 b , . . . , through nth received encoded data 1230 n .
- the video sequence 1270 comprises a series of decoded video frames 1268 , shown as first decoded video frame 1260 a , second decoded video frame 1260 b , . . . , through nth decoded video frame 1260 n.
- FIG. 12C shows an embodiment where the I/O device 1240 of FIGS. 12A and 12B is a storage medium 1280 .
- the encoded data stream 1235 from the compressor 1210 is stored in the storage medium 1280 .
- the storage medium 1280 provides the input encoded data stream 1245 as input to the decompressor 1250 .
- FIG. 12D shows an embodiment where the I/O device 1240 of FIGS. 12A and 12B is a communications channel 1290 .
- the encoded data stream 1235 from the compressor 1210 is transmitted over the communications channel 1290 .
- the communications channel 1290 provides the input encoded data stream 1245 as input to the decompressor 1250 .
- FIGS. 13 A through 13 J Compressor Details, Encoding Circuit, and Bitwise Pixel Sub-Samplers
- FIG. 13A shows details of an embodiment of the compressor 1210 , which comprises a video digitizer 1310 , a video memory 1330 , an encoding circuit 1350 , and encoded data 1370 .
- Each video frame 1205 in the series of video frames 1200 is digitized by the video digitizer 1310 and stored along path 1320 in the video memory 1330 .
- the encoding circuit 1350 access the digitized video frame via path 1340 and outputs the encoded data 1370 along path 1360 .
- the encoded data 1225 corresponding to each video frame 1205 is then output from the compressor 1210 .
- FIG. 13B shows further details of an embodiment of the encoding circuit 1350 .
- a pixel sub-sampler 1380 scans each pixel from the digitized video frame in the video memory 1330 .
- a pixel index 1332 is used to drive a scan 1331 signal to select each pixel from the video memory, in a predetermined sequence.
- a novel aspect of the present invention is that the compression method can be accomplished with a single scan of the video memory for each frame.
- the pixel sub-sampler 1380 selects a predetermined number of bits from each pixel and outputs the data value along path 1385 .
- the pixel sub-sampler 1380 encodes the sub-sampled data by using a lookup table similar to FIG. 11A .
- the data/count 1390 unit increments the count each time the output of the pixel sub-sampler 1380 is the same; otherwise, when the output of the pixel sub-sampler 1380 is different (or when the counter reaches the maximum count value, the data and count are combined as a code and output along path 1395 to the encoded data 1225 for the frame currently in the video memory 1330 .
- the location of the code in the encoded data 1225 is selected by the code index 1392 signal.
- FIG. 13C shows further details of a generic pixel sub-sampler 1380 .
- a pixel When a pixel is scanned from video memory along path 1340 , it has an original pixel bit width, P.
- a pixel extractor 1382 extracts a subset of bits from each pixel with a value bit width, V, along value path 1383 .
- the value bit width V is less than the pixel bit width P.
- a coder 1384 takes the V bits from the pixel path 1383 and outputs a code with an encoded bit width, E, as the data value along path 1385 .
- One embodiment of the coder is a null coder, or pass-through coder.
- Another embodiment of the coder uses an encryption table to encrypt the data value as an encrypted data value.
- FIGS. 13D through 13J show embodiments of pixel sub-samplers.
- FIG. 13E illustrates a 24-bit RGB to 5 bit sub-sampler 1380 b , where the pixel bit width, P, is 24 divided into 8 bits of red, green, and blue (RGB, see FIG. 2B ); the value bit width, V, output from the pixel extractor 1382 is 8; and the encoded bit width, E, output from the coder 1384 is 5.
- the extracted 8 bits could be an average (e.g. FIG. 2C ) or one of the colors (e.g. FIGS. 2D, 2E , or 2 F).
- FIG. 13F illustrates a 32-bit RGB to 5 bit sub-sampler 1380 c , where the pixel bit width, P, is 32 divided into 8 bits of red, green, blue, and alpha (see FIG. 2A ); the value bit width, V, output from the pixel extractor 1382 is 8; and the encoded bit width, E, output from the coder 1384 is 5.
- the extracted 8 bits could be an average (e.g. FIG. 2C ) or one of the colors (e.g. FIGS. 2D, 2E , or 2 F).
- FIG. 13G illustrates a color 9-bit sub-sampler 1380 d , where the pixel bit width, P, is 24 divided into 8 bits each of red, green, and blue; the value bit width, V, output from the pixel extractors 1382 is 9; and the encoded bit width, E, output from the coder 1384 is 9.
- the high order 3 bits of each color component are selected (e.g. ZL9C shown FIG. 8B ).
- FIG. 13H illustrates a YUV sub-sampler 1380 e , where the pixel bit width, P, is 24 divided into 8 bits for each of YUV; the value bit width, V, output from the pixel extractors 1382 is 8; and the encoded bit width, E, output from the coder 1384 is 5.
- the pixel bit width, P is 24 divided into 8 bits for each of YUV
- the value bit width, V, output from the pixel extractors 1382 is 8
- the encoded bit width, E output from the coder 1384
- FIG. 13I illustrates a 36-bit RGB to 24 bit sub-sampler 1380 f , where the pixel bit width, P, is 36 divided into 12 bits each of red, green, and blue; the value bit width, V, output from the pixel extractors 1382 is 24; and the encoded bit width, E, output from the coder 1384 is also 24 .
- the high order 8 bits of each 12-bit color component are selected.
- FIG. 13J illustrates a 15-bit sub-sampler 1380 g , where the pixel bit width, P, is 24 divided into 8 bits from each color component; the value bit width, V, output from the pixel extractor 1382 is 15; and the encoded bit width, E, output from the coder 1384 is 15.
- the high order 5 bits of each 8-bit color component are selected.
- FIGS. 14 A through 14 C Variable Selection of Bit-wise Sub-sampling
- FIGS. 14A through 14C shows embodiments of a device for variably altering the number of bits.
- FIG. 14A illustrates 24-bit to variable bit sub-sampler 1400 .
- a pixel When a pixel is scanned from video memory along path 1340 , it has an original pixel bit width, P, equal to 24 bits. These 24 bits are passed as input to a number of sub-samplers.
- the variable number of bits is selected by a number of bits selector 1410 as indicated by a number of bits indicator 1420 and outputs a code with an variable encoded bit width, E, as the data value along path 1385 .
- a user at remote receiver 1610 sets the number of bits indicator 1420 (see discussion regarding FIGS. 16A and 16B ).
- the variable bit sub-sampler comprises a generic 3-bit sub-sampler 1401 , a generic 4-bit sub-sampler 1402 , generic 8-bit sub-sampler 1403 , and generic 10-bit sub-sampler 1404 which are embodiments of the generic sub-sampler shown in FIG. 13C with specific values for E.
- the variable bit sub-sampler further comprises nested sub-samplers: the 24 to 5 bit sub-sampler 1380 a of FIG. 13D , the 1380 d of FIG. 13G , and the 15-bit sub-sampler 1380 g of FIG. 13J . This is illustrative of the types of bit sub-samplers that can be variably selected.
- FIG. 14B illustrates a 36-bit to variable bit sub-sampler 1430 , where P is 36 and the number of bit that can be selected are 12, 15, or 24, respectively.
- FIG. 14C shows that the 24 bit to variable bit sub-sampler 1400 of FIG. 14A and the 36-bit to variable bit sub-sampler 1430 of FIG. 14B can be further combined to form at 24/36 bit variable bit sub-sampler 1440 where a second selector 1450 is used to selected either the 24 bit inputs or the 36 bit inputs using selection logic 1460 that also receives the number of bits indicator 1420 .
- a selection signal 1470 enables either the output of 24-bit to variable bit sub-sampler 1400 or the output of 36-bit to variable bit sub-sampler 1430 .
- Sub-samplers 1400 and 1430 both receive the number of bits indicator 1420 as shown in FIG. 14A and FIG. 14B . In this way any number of bits may reasonably be selected from either a 36 or 24-bit pixel bit width.
- FIG. 15 Decompressor Elements
- FIG. 15 shows details of an embodiment of the decompressor 1250 , which comprises a decoding circuit 1510 which inputs received encoded data 1230 and outputs decoded pixel values 1520 to an image memory 1540 .
- a decoder pixel index 1530 selects the location in the image memory 1540 to store the decoded pixels values 1520 .
- the image memory 1540 delivers each decoded video frame 1260 to the video display.
- FIGS. 16 A and 16 B Paraameters Altered by a Remote Receiver
- FIG. 16A shows a system for setting width, height, frame rate, brightness, and contrast in a transmitter 1600 which are variably altered by a receiver 1610 .
- the receiver sends commands to the transmitter 1600 via setting control path 1615 .
- the commands alter the transmitter settings 1660 .
- the settings 1660 include brightness 1661 , contrast 1662 , height 1663 , width 1664 , and frame rate 1665 .
- the brightness 1661 , contrast 1662 , height 1663 , and width 1664 setting alter the attributes of each frame as it is digitized in a frame sub-sampler 1620 .
- the brightness 1661 and contrast 1662 settings alter the video digitizer 1310 ( FIG. 13A ) as it senses the video frame.
- the height 1663 and 1664 allow for optionally selecting a subset area of each frame; this is area sub-sampling.
- height 1663 and 1664 allow for optionally selecting a subset of pixels from an array of pixels that make up a single frame, by skipping pixels in a row or by skipping rows; this is image sub-sampling.
- the frame rate 1665 setting alters the frame selector 1670 which drives the frame select indicator 1675 to optionally sub-sample frames from a sequence of video frames; this is frame sub-sampling.
- the frame sub-sampler 1620 outputs a selected frame 1630 along path 1621 .
- the transmitter pixel sub-sampler 1640 scans the selected frame 1630 getting each pixel from frame 1632 and outputs data values along path 1642 to a run length encoder 1650 .
- the encoded data stream 1235 is then transmitted to the remote receiver 1610 .
- FIG. 16B shows additional elements of a system for setting the number of pixel bits in an alternate transmitter 1690 which is variably altered by a receiver 1610 .
- the receiver sends commands to the transmitter 1600 via setting control path 1615 .
- the commands alter the transmitter settings 1660 .
- the settings include a number of pixel bits setting 1680 which affect the number of bits selected by the transmitter pixel sub-sampler 1640 .
- the pixel sub-sampler 1640 could be any pixel sub-sampler, for example, see FIGS. 13C through 13J and 14 A through 14 C.
- the transmitter pixel sub-sampler 1640 scans the selected frame 1630 (as in FIG. 16A ) getting each pixel from frame 1632 and outputs data values along path 1642 to a run length encoder 1650 .
- the encoded data stream 1235 is then transmitted to the remote receiver 1610 .
- These embodiments illustrate the novel feature of the present invention of allowing a user at a remote receiver 1610 to control aspects of the transmitter 1600 or 1690 from a remote location, including brightness, contrast, frame dimensions, frame rate, image area, and the type of compression used.
- FIG. 17 Frether Lossless Compression Step
- FIG. 17 shows a lossless compression step for further compressing an encoded data buffer.
- a run-length encoded output 1710 can be further processed with a further lossless compression step 1720 resulting in further lossless compression output 1730 .
- the further lossless compression step 1720 could be implemented as a variable length coding, arithmetic coding, or other compression step known in the art.
- FIG. 18 Image Stretching
- FIG. 18 shows images being enlarged by stretching.
- An unstretched frame 1800 is stretched during stretching step 1820 resulting in an enlarged image 1810 .
- the remaining data can be stretched to fill the full display area on the receiver 1610 . This results in an interpolated image or magnified image, respectively.
- FIGS. 19 A through 19 C Handheld Video Transmission Networks
- FIGS. 19A through 19C show various network configuration comprising handheld video devices.
- FIG. 19A illustrates an exemplary network 1910 comprising a first node 1920 a , a second node 1920 b , and an optional reflector 1930 .
- the network 1910 is shown as a wired network 1910 a .
- the first node 1920 a is displaying a first video 1901 a of a man.
- the second node 1920 b is displaying a second video 1902 a of a woman. This illustrates a videoconference between the man at the second node 1920 b and the woman at the first node 1920 a .
- the respective videos are transmitted over a point-to-point transmission 1940 path between the two nodes over the network 1910 .
- each of the videos is transmitted to the reflector where both videos are displayed as first reflected video 1901 b and second reflected video 1902 b .
- the second video 1902 a originates at the first node 1920 a is transmitted to the reflector over first indirect path 1942 .
- the second video 1901 a originates at the second node 1920 b is transmitted to the reflector over second indirect path 1944 .
- the reflector then retransmits the two videos to the respective display nodes, 1920 a and 1920 b , over the indirect paths. In other configurations, the reflector would also transmit the combined video to other nodes participating in the videoconference.
- FIG. 19B shows an example of three nodes, third node 1920 c , fourth node 1920 d , and fifth node 1920 e in a wireless network.
- the wireless connections are shown as waves.
- the three nodes operate in the same manner as the three nodes in FIG. 19A .
- FIG. 19C shows an example of a combined network 1910 c where five nodes are connect in a network comprised of both a wired network 1910 a and a wireless network 1910 b . Any of the five nodes could transmit video to any of the other nodes in the combined network. Any node, for example third node 1920 c as shown, could act as a reflector 1930 .
- any node could act as a video server and transmit pre-recorded video to one or more other nodes.
- combined networks could consist of any number of nodes. Any of the nodes in the network could be a handheld video device.
- FIGS. 20 A through 20 D Handheld Video Devices
- FIGS. 20A through 20D show various embodiments of handheld video devices.
- FIG. 20A shows a handheld video transmitter comprising a video source 2052 , a video transmitter 2054 , and video storage 2056 .
- FIG. 20B shows two handheld video devices in communication over either a wireless connection 2050 or a wired connection 2051 .
- a first handheld device 2010 comprises a display 2012 , manual controls 2014 , a wireless port 2016 , and a first wired connection 2051 a . While either the wireless port 2016 or the wired connection 2051 a could be present, only one of the two would be necessary to receive video from or transmit video to other nodes in the network 1910 .
- the first handheld device is shown as an iPod-type device with an internal hard disk drive.
- the first handheld device 2010 further comprises a headphone 2020 , connected via a speaker/microphone cable 2024 , and a camera 2030 , connected via a camera cable 2034 .
- the headphone 2020 comprises a right speaker 2021 , a microphone 2022 , and a left speaker 2023 .
- the camera 2030 has a lens 2032 and internal circuitry that converts the light that passes through the lens 2032 into digital video data.
- the iPod-type device is implemented using a standard Apple iPod (enhanced with an audio input for the microphone and, optionally, with a wireless port, and appropriate software), and the camera 2030 is implemented using an iBot Firewire camera manufactured by Orange Micro, a lower performing Connectix USB camera, or similar camera.
- the Apple iPod could be used without hardware modification.
- the microphone could be build into the camera (not shown) instead of the headphones.
- a second handheld device 2040 comprises a second display 2012 b , a second wireless port 2016 b , and a second wired connection 2051 b . While either the wireless port 2016 b or the wired connection 2051 b could be present, only one of the two would be necessary to receive video from or transmit video to other nodes in the network 1910 .
- the second handheld device is shown as a device with a touch screen.
- the second handheld device 2040 further comprises a right built-in speaker 2021 b , a built-in microphone 2022 b , a left built-in speaker 2023 b , and a built-in camera 2030 b with lens 2032 .
- the configuration of the second handheld device 2040 has the advantage of eliminating the cables for the external headphone and camera of the first handheld device 2010 by having all elements built-in.
- a two-device handheld videoconferencing network could have two identical handheld devices, such as the first handheld device 2010 . Further, a single device with a camera (as shown) could transmit video for display on any number of hand held devices that do not have cameras or microphones.
- FIG. 20C illustrates an integrated handheld device 2060 comprising an iPod type device 2010 , an A/V module 2062 and an optional wireless module 2064 .
- the iPod type device 2010 comprises display 2012 , controls 2014 , and a wired connection 2051 .
- the A/V module 2062 comprises a right integrated speaker 2021 c , an integrated microphone 2022 c , a left integrated speaker 2023 c , and a integrated camera 2030 c with lens 2032 .
- the A/V module 2062 could be manufactured and marketed separately (as shown) as an add-on module for standard iPods, or could be incorporated into the iPod packaging as an enhanced iPod-type device.
- the wireless module 2064 comprises an integrated wireless port 2016 c .
- the wireless module 2064 also could be manufactured and marketed separately (as shown) as an add-on module for standard iPods, or could be incorporated into the iPod packaging as an enhanced iPod-type device.
- the configuration of the integrated handheld device 2060 has the advantage of eliminating the cables for the external headphone and camera of the first handheld device 2010 by having all elements integrated into removably attached modules that form a single unit when attached.
- the user can configure the standard iPod based on the user's intended use. If only a wireless connection is needed, only the wireless module 2064 can be attached to the iPod; in this configuration video can be received and displayed but not transmitted. If only video transmission is necessary and a wired connection is convenient, the wireless module 2064 can be omitted. Either configuration provides a single integrated unit that can be carried in the user's pocket and can store and display videos.
- FIG. 20D illustrates an cellular integrated device 2070 comprising phone display 2012 d , phone controls 2014 d (including a number keypad), a cellular port 2016 d , a right phone speaker 2021 d , a phone earphone 2021 e , phone microphone 2022 d , left phone speaker 2023 d , and a phone camera 2030 d with lens 2032 .
- any of the handheld devices shown in FIGS. 20A through 20D could be nodes in video transmission networks, such as those shown in FIGS. 12D and 19A through 19 C.
- Each transmitting device preferably would include a compressor 1210 as shown in FIGS. 12A and 12D .
- Each receiving device preferably would include a decompressor 1250 as shown in FIGS. 12B and 12D .
- the compressor 1210 and decompressor 1250 preferably would implement one or more embodiments of the compression methods discussed above.
- FIGS. 21 A through 21 C Handheld Video Devices with Graphical Zoom Control
- FIGS. 21A through 21C show exemplary handheld video devices comprising graphical zoom controls.
- a graphical user interface graphically corresponds to a video display window 2110 through which a single image or a stream of video frames is displayed.
- the GUI and the video display window 2110 are displayed on a display 2012 (or 2012 b or 2012 d ).
- the GUI includes a zoom control 2100 having an inner region 2102 positioned within an outer region 2106 .
- the zoom control 2100 is a graphical way for the user of a remote receiver 1610 (see FIGS. 16A and 16B ) to send remote control commands to set the parameters of a video transmitter ( 1600 or 1690 ) for control the area of the video to be compressed and transmitted.
- FIG. 21A shows an embodiment of the iPod-type handheld device 2010 of FIG. 20C displaying a zoom control 2100 having an inner region 2102 a positioned within an outer region 2106 a .
- the zoomed video image is show in video display window 2110 a .
- the zoom control 2100 is displayed on top of the video display window 2110 a .
- the size and position of the inner region 2102 a relative to the outer region 1206 a shows the user which portion of the original video is being received and magnified. Only the selected portion of the original video (in this example, the hair and top of the face) needs to be transmitted in full resolution or high quality.
- a low resolution, or thumbnail version of the original video frame is optionally displayed in the outer region 2106 a .
- the thumbnail can be updated at a rate slower than the frame rate of the magnified video, such as once or twice a second.
- the magnification factor 2104 a shows the text 2 ⁇ showing that the portion being displayed in the video display window 2110 a is being displayed at twice the size.
- FIG. 21B shows an embodiment of the cellular integrated device 2070 of FIG. 20D displaying a zoom control 2100 having an second inner region 2102 b positioned within an second outer region 2106 b .
- the zoomed video image is shown in alternate video display window 2110 b .
- the zoom control 2100 is displayed outside and below the alternate video display window 2110 b .
- the size and position of the second inner region 2102 b relative to the second outer region 1206 b shows the user which portion of the original video is being received and magnified. Only the selected portion of the original video (in this example, the lower face and tie) needs to be transmitted in full resolution or high quality.
- a low resolution, or thumbnail version of the original video frame is optionally displayed in the second outer region 2106 b .
- the second magnification factor 2104 b shows the text 2 ⁇ showing that the portion being displayed in the alternate video display window 2110 b is being displayed at twice the size.
- FIG. 21C shows an embodiment of the second handheld device 2040 of FIG. 20B displaying a zoom control 2100 having an third inner region 2102 c positioned within an third outer region 2106 c .
- the zoomed video image is shown in a video display window 2110 a shown filling the second display 2112 b .
- the zoom control 2100 is displayed over the video display window 2110 a .
- the size and position of the third inner region 2102 c relative to the third outer region 1206 c shows the user which portion of the original video is being received and magnified. Only the selected portion of the original video (in this example, the right shoulder of the woman) needs to be transmitted in full resolution or high quality.
- a low resolution, or thumbnail version of the original video frame is optionally displayed in the third outer region 2106 c .
- the third magnification factor 2104 c shows the text 3 ⁇ showing that the portion being displayed in the video display window 2110 a is being displayed at three times the size.
- the controls (similar in function to controls 2014 ) are incorporated into a touch screen of the second display 2012 b .
- the user enters zoom in, zoom out, and pan commands by tapping the third inner region 2102 c or the third outer region 2106 , or by selecting and dragging the outline of the third inner region 2102 c.
- a user controls aspects and changes parameters of the image displayed within the video display window 2110 using the controls 2014 to enter input commands within the zoom control 2100 by selecting appropriate parts of the controls 2104 (or regions of the zoom control 2100 on a touch screen or with a pointing device).
- the controls 2014 can be a touch screen, touch pad, iPod-like scroll pad, remote control or other device, depending on the configuration of the handheld device.
- the size of the inner region 2102 relative to the outer region 2106 represents the magnification of the portion of the image being displayed within the video display window 2110 .
- a magnification factor 104 representing the current magnification of the image being displayed within the video display window 2110 from the original image is displayed within the inner region 2102 .
- the magnification of the image being displayed is increased by tapping within the inner region 2102 , or while in zoom control mode, pressing the “zoom in” button on a iPod-type control 2104 or cell phone control 2014 d . As the magnification is thus increased, the size of the inner region 2102 is decreased appropriately relative to the outer region 2106 and the magnification factor 104 is appropriately incremented.
- the magnification of the image being displayed is decreased by tapping outside of the inner region but inside of the outer region, or while in zoom control mode clicking the “zoom out” button on a iPod-type control 2104 or cell phone control 2014 d .
- the magnification is thus decreased, the size of the inner region 102 is increased appropriately relative to the outer region 2106 and the magnification factor 104 is appropriately decremented.
- the position of the inner region 2102 within the outer region 2106 represents the portion of the entire original image being displayed within the video display window 2110 .
- the portion of the image being displayed within the video display window 2110 is changed by moving the inner region 2102 to the desired position within the outer region 2106 using the touch screen, a pointing device, or the controls 2014 or 2014 d .
- the position of the inner region 2102 changes within the outer region 2106
- the portion of the image displayed within the video display window 2110 changes appropriately.
- the magnification factor 104 is changed by using the touch screen or controls 2014 (or 2014 d ) to zoom in or zoom out. By zooming in a number of times, the inner region 102 becomes continually smaller in size and the magnification factor 104 is incremented a number of times equal to the number of times that the control zoomed in.
- a user zooms out on a specific portion of the image to decrease the magnification factor 104 ; the inner region 102 becomes appropriately larger in size and the magnification factor 104 is decremented.
- the inner region 102 becomes increasingly larger with each zoom out and the magnification factor 104 is decremented a number of times equal to the number of times the user zooms out, until the magnification factor is equal to 1.
- the inner region 2102 also has a pan or positional feature within the outer region 2106 , such that the position of the inner region 2102 within the outer region 2106 represents the portion of the entire original image that is being displayed within the video display window 2110 .
- the position of the inner region 2102 is changed within the outer region 2106 by using the touch screen, a pointing device, or controls 2014 to move the inner region 2102 to the desired position within the outer region 2106 .
- the inner region 2102 graphically represents what portion of the entire image is currently being displayed within the video display window 2110 and what magnification factor 104 is currently being used to make this selected portion of the original image fit within the video display window 2110 .
- the present invention will allow low cost, portable, video transmission of events of interest whenever and wherever they happen. These handheld wireless video transmitters will be able to provide news coverage of wars, natural disasters, terrorist attacks, traffic and criminal activities in a way that has never before been possible.
- the present invention will enabled enhanced personal communication between friends, family, and co-workers in ways never before possible.
- the present invention will enabled the transmission of video-based entertainment and education in ways never before possible.
- User will be able to use pocket-sized, handheld device to watch video that are downloaded from a global media exchange, streamed from a video server, or transmitted live from a performance, classroom, laboratory, or field experience.
- the present invention would enable a physician or medical specialist to receive medical quality video any time in any location.
- a critical emergency room ultrasound study could be monitored while it is being performed by less skilled emergency room personnel ensuring that the best medical image is acquired.
- a rapid diagnosis can be made and the results of a study can be verbally dictated for immediate transcription and use within the hospital.
- the present invention could be used to transmit medical quality video from a remote, rural location, including a battle ground. It could also be used to transmit guidance and advice from an expert physician into a remote, rural location.
- the present invention can improve medical care, reduce the turnaround for analysis of medical studies, reduce the turnaround for surgery, and provide medical professionals with continuous access to medical quality imaging.
- the removal of the least significant bits of pixel values results in high quality decompressed images when the original image is generated by an electronic sensing device, such as an ultrasound machine, which is generating only a certain number of bits of grayscale resolution.
- an electronic sensing device such as an ultrasound machine
- various filters can be implemented to enhance the image quality.
- Such a noise filter can be beneficial when the image is generated by an imaging technology such as radar, ultrasound, x-ray, magnetic resonance, or similar technology. Variations can be made to enhance the perceived quality of the decompressed image. Therefore, altering the number of data bits selected and altering the width of the repeat count is anticipated by this invention and specific values in the examples should not be construed as limiting the scope of this invention.
- While a video stream is being viewed a viewer on the decoding end of the transmission can vary the settings for the compressor. Different tradeoffs between image spatial and temporal quality can be made. As the contents of the video signal change an appropriate format can be selected. Control signals can be sent back to the compressor via a communications link.
- the preferred embodiment of this invention uses a number of techniques to reduce the time required to compress and decompress the data.
- Both the compression steps 100 and the decompression steps 150 access a pixel once and perform all calculations.
- the preferred embodiment selects the low order byte from the 32 bit pixel value 200 or the 24 bit pixel value 210 so that an additional shift operation or addressing operation is avoided.
- the shift operation is a fast and efficient way to convert a byte or word to the filtered pixel value 299 .
- the lossless compression of the sampled data achieved by the preferred embodiment of the present invention results in high quality video streams that have general purpose application in a number of areas including, without limitation, video conferencing, surveillance, manufacturing, rich media advertising, and other forms of video transmission, storage, and processing.
- the methods of the present invention compress and decompress the data with no irreversible data loss. Unlike JPEG and MPEG, the decompressed image never suffers from artificially induced blocking or smearing or other artifacts that are result of the lossy compression algorithm itself. As a result even a small sub-sample of the image remains clear and true to the perceived quality of the original image.
- the format and methods of the present invention provide a number of advantages, including, but not limited to, faster speed and smaller size of encoded data, better performance for both medical and typical video images, and a typically closer representation of the original video signal.
- handheld wireless devices are used to receive and display high quality video.
- the video can be displayed as it is received live and a graphical zoom control can be used to dynamically control the area of the source image that is to be transmitted in full resolution.
- a handheld wireless device captures the video with an attached video camera and microphone and the device transmits the video images live as they are captured.
- a single handheld wireless video transmitter can transmit to multiple handheld wireless receivers.
- a plurality of handheld wireless video devices which capture, transmit, receive, and display video over a network are used for mobile video conferencing.
- the video data is transferred as a video file or streamed from a video server contain pre-recorded video files.
- the compression and decompression steps of the present invention provides a means of digitally compressing a video signal in real time, communicating the encoded data stream over a transmission channel, and decoding each frame and displaying the decompressed video frames in real time.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Human Computer Interaction (AREA)
- Computer Networks & Wireless Communication (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Description
- This application is a continuation of co-pending U.S. patent application Ser. No. 11/262,106, filed on Oct. 27, 2005, published Jun. 1, 2006, as U.S. patent application publication 2006/0114987, entitled “HANDHELD VIDEO TRANSMISSION AND DISPLAY,” which hereby is incorporated by reference.
- U.S. patent application Ser. No. 11/262,106 is a continuation in part of co-pending U.S. patent application Ser. No. 09/467,721, filed on Dec. 20, 1999, and entitled “VARIABLE GENERAL PURPOSE COMPRESSION FOR VIDEO IMAGES (ZLN)”, now U.S. Pat. No. 7,233,619, which hereby is incorporated by reference.
- This application and application Ser. No. 09/467,721 claim priority under 35 U.S.C. § 119(e) of U.S. provisional application Ser. No. 60/113,051, filed on Dec. 21, 1998, and entitled “METHODS OF ZERO LOSS (ZL) COMPRESSION AND ENCODING OF GRAYSCALE IMAGES”, which hereby is incorporated by reference.
- My U.S. patent application Ser. No. 09/312,922, filed on May 17, 1999, and entitled “SYSTEM FOR TRANSMITTING VIDEO IMAGES OVER A COMPUTER NETWORK TO A REMOTE RECEIVER,” now U.S. patent Ser. No ______, is also hereby incorporated by reference.
- My U.S. patent application Ser. No. 09/433,978, now U.S. Pat. No. 6,803,931, filed on Nov. 4, 1999, and entitled GRAPHICAL USER INTERFACE INCLUDING ZOOM CONTROL REPRESENTING IMAGE AND MAGNIFICATION OF DISPLAYED IMAGE”, is also hereby incorporated by reference. A co-pending divisional application of U.S. Pat. No. 6,803,931, is U.S. patent application Ser. No. 10/890,079, filed on Jul. 13, 2004, published on Dec. 9, 2004 as publication No. 2004/0250216, and entitled GRAPHICAL USER INTERFACE INCLUDING ZOOM CONTROL REPRESENTING IMAGE AND MAGNIFICATION OF DISPLAYED IMAGE”, and is also hereby incorporated by reference.
- My U.S. patent application Ser. No. 09/470,566, now U.S. Pat. No. 7,016,417, filed on Dec. 22, 1999, and entitled GENERAL PURPOSE COMPRESSION FOR VIDEO IMAGES (RHN)”, describes a compression method known as the “RHN” method, and is also hereby incorporated by reference.
- My co-pending U.S. patent application Ser. No. 09/473,190, filed on Dec. 20, 1999, and entitled “ADDING DOPPLER ENHANCEMENT TO GRAYSCALE COMPRESSION (ZLD)” is also hereby incorporated by reference.
- My co-pending U.S. patent application Ser. No. 10/154,775, filed on May 24, 2002, published as US 2003/0005428, and entitled “GLOBAL MEDIA EXCHANGE” is also hereby incorporated by reference.
- U.S. patent application Ser. No. 09/436,432, filed on Nov. 8, 1999, and entitled “SYSTEM FOR TRANSMITTING VIDEO IMAGES OVER A COMPUTER NETWORK TO A REMOTE RECEIVER,” now U.S. Pat. No. 7,191,462, is wholly owned by the inventor of the present invention.
- 1. Field of the Invention
- This invention relates to handheld devices for video transmission, including video capture, wired and wireless file transfer and live streaming, and display. Embodiments of the invention relate to data compression, specifically to the compression and decompression of video and still images, and relate to graphical user interfaces for controlling video transmission and display.
- 2. Description of Prior Art
- In the last few years, there have been tremendous advances in the speed of computer processors and in the availability of bandwidth of worldwide computer networks such as the Internet. These advances have led to a point where businesses and households now commonly have both the computing power and network connectivity necessary to have point-to-point digital communications of audio, rich graphical images, and video. However the transmission of video signals with the full resolution and quality of television is still out of reach. In order to achieve an acceptable level of video quality, the video signal must be compressed significantly without losing either spatial or temporal quality.
- A number of different approaches have been taken but each has resulted in less than acceptable results. These approaches and their disadvantages are disclosed by Mark Nelson in a book entitled The Data Compression Book, Second Edition, published by M&T Book in 1996. Mark Morrision also discusses the state of the art in a book entitled The Magic of Image Processing, published by Sams Publishing in 1993.
- Video Signals
- Standard video signals are analog in nature. In the United States, television signals contain 525 scan lines of which 480 lines are visible on most televisions. The video signal represents a continuous stream of still images, also known as frames, that are fully scanned, transmitted and displayed at a rate of 30 frames per second. This frame rate is considered full motion.
- A television screen has a 4:3 aspect ratio.
- When an analog video signal is digitized each of the 480 lines is sampled 640 times, and each sample is represented by a number. Each sample point is called a picture element, or pixel. A two dimensional array is created that is 640 pixels wide and 480 pixels high. This 640×480 pixel array is a still graphical image that is considered to be full frame. The human eye can perceive 16.7 thousand colors. A pixel value comprised of 24 bits can represent each perceivable color. A graphical image made up of 24-bit pixels is considered to be full color. A single, second-long, full frame, full color video requires over 220 millions bits of data.
- The transmission of 640×480 pixels×24 bits per
pixel times 30 frames requires the transmission of 221, 184,000 million bits per second. A T1 Internet connection can transfer up to 1.54 million bits per second. A high-speed (56 Kb) modem can transfer data at a maximum rate of 56 thousand bits per second. The transfer of full motion, full frame, full color digital video over a T1 Internet connection, or 56 Kb modem, will require an effective data compression of over 144:1, or 3949:1, respectively. - A video signal typically will contain some signal noise. In the case where the image is generated based on sampled data, such as an ultrasound machine, there is often noise and artificial spikes in the signal. A video signal recorded on magnetic tape may have fluctuations due the irregularities in the recording media. Florescent or improper lighting may cause a solid background to flicker or appear grainy. Such noise exists in the real world but may reduce the quality of the perceived image and lower the compression ratio that could be achieved by conventional methods.
- Basic Run-length Encoding
- An early technique for data compression is run-length encoding where a repeated series of items are replaced with one sample item and a count for the number of times the sample repeats. Prior art shows run-length encoding of both individual bits and bytes. These simple approaches by themselves have failed to achieve the necessary compression ratios.
- Variable Length Encoding
- In the late 1940s, Claude Shannon at Bell Labs and R.M. Fano at MIT pioneered the field of data compression. Their work resulted in a technique of using variable length codes where codes with low probabilities have more bits, and codes with higher probabilities have fewer bits. This approach requires multiple passes through the data to determine code probability and then to encode the data. This approach also has failed to achieve the necessary compression ratios.
- D. A. Huffman disclosed a more efficient approach of variable length encoding known as Huffman coding in a paper entitled “A Method for Construction of Minimum Redundancy Codes,” published in 1952. This approach also has failed to achieve the necessary compression ratios.
- Arithmetic, Finite Context, and Adaptive Coding
- In the 1980s, arithmetic, finite coding, and adaptive coding have provided a slight improvement over the earlier methods. These approaches require extensive computer processing and have failed to achieve the necessary compression ratios.
- Dictionary-Based Compression
- Dictionary-based compression uses a completely different method to compress data. Variable length strings of symbols are encoded as single tokens. The tokens form an index to a dictionary. In 1977, Abraham Lempel and Jacob Ziv published a paper entitled, “A Universal Algorithm for Sequential Data Compression” in IEEE Transactions on Information Theory, which disclosed a compression technique commonly known as LZ77. The same authors published a 1978 sequel entitled, “Compression of Individual Sequences via Variable-Rate Coding,” which disclosed a compression technique commonly known as LZ78 (see U.S. Pat. No. 4,464,650). Terry Welch published an article entitled, “A Technique for High-Performance Data Compression,” in the June 1984 issue of IEEE Computer, which disclosed an algorithm commonly known as LZW, which is the basis for the GIF algorithm (see U.S. Pat. Nos. 4,558,302, 4,814,746, and 4,876,541). In 1989, Stack Electronics implemented a LZ77 based method called QIC-122 (see U.S. Pat. No. 5,532,694, U.S. Pat. No. 5,506,580, and U.S. Pat. No. 5,463,390).
- These lossless (method where no data is lost) compression methods can achieve up to 10:1 compression ratios on graphic images typical of a video image. While these dictionary-based algorithms are popular, these approaches require extensive computer processing and have failed to achieve the necessary compression ratios.
- JPEG and MPEG
- Graphical images have an advantage over conventional computer data files: they can be slightly modified during the compression/decompression cycle without affecting the perceived quality on the part of the viewer. By allowing some loss of data, compression ratios of 25:1 have been achieved without major degradation of the perceived image. The Joint Photographic Experts Group (JPEG) has developed a standard for graphical image compression. The JPEG lossy (method where some data is lost) compression algorithm first divides the color image into three color planes and divides each plane into 8 by 8 blocks, and then the algorithm operates in three successive stages:
-
- (a) A mathematical transformation known as Discrete Cosine Transform (DCT) takes a set of points from the spatial domain and transforms them into an identical representation in the frequency domain.
- (b) A lossy quantization is performed using a quantization matrix to reduce the precision of the coefficients.
- (c) The zero values are encoded in a zig-zag sequence (see Nelson, pp. 341-342).
- JPEG can be scaled to perform higher compression ratio by allowing more loss in the quantization stage of the compression. However this loss results in certain blocks of the image being compressed such that areas of the image have a blocky appearance and the edges of the 8 by 8 blocks become apparent because they no longer match the colors of their adjacent blocks. Another disadvantage of JPEG is smearing. The true edges in an image get blurred due to the lossy compression method.
- The Moving Pictures Expert Group (MPEG) uses a combination of JPEG based techniques combined with forward and reverse temporal differencing. MPEG compares adjacent frames and, for those blocks that are identical to those in a previous or subsequent frame, only a description of the previous or subsequent identical block is encoded. MPEG suffers from the same blocking and smearing problems as JPEG.
- These approaches require extensive computer processing and have failed to achieve the necessary compression ratios without unacceptable loss of image quality and artificially induced distortion.
- QuickTime: CinePak, Sorensen, H.263
- Apple Computer, Inc. released a component architecture for digital video compression and decompression, named QuickTime. Any number of methods can be encoded into a QuickTime compressor/decompressor (codec). Some popular codec are CinePak, Sorensen, and H.263. CinePak and Sorensen both require extensive computer processing to prepare a digital video sequence for playback in real time; neither can be used for live compression. H.263 compresses in real time but does so by sacrificing image quality resulting in severe blocking and smearing.
- Fractal and Wavelet Compression
- Extremely high compression ratios are achievable with fractal and wavelet compression algorithms. These approaches require extensive computer processing and generally cannot be completed in real time.
- Sub-Sampling
- Sub-sampling is the selection of a subset of data from a larger set of data. For example, when every other pixel of every other row of a video image is selected, the resulting image has half the width and half the height. This is image sub-sampling. Other types of sub-sampling include frame sub-sampling, area sub-sampling, and bit-wise sub-sampling.
- Image Stretching
- If an image is to be enlarged but maintain the same number of pixels per inch, data must be filled in for the new pixels that are added. Various methods of stretching an image and filling in the new pixels to maintain image consistency are known in the art. Some methods known in the art are dithering (using adjacent colors that appear to be blended color), and error diffusion, “nearest neighbor”, bilinear and bicubic.
- Portable Hand Held Devices: Pen-based Computers and PDAs
- In the early 1990s, a number of pen based computers were developed. These portable computers were characterized by a display screen that could be also used as an input device when touched or stroked with a pen or finger. For example in 1991, NCR developed a “notepad” computer, the NCR 3125. Early pen-based computers ran three operating systems: DOS, Microsoft's Windows for Pen Computing and Go Corp.'s PenPoint. In 1993, Apple developed the Newton MessagePad, an early personal digital assistant (PDA). Palm developed the Palm Pilot in 1996. Later, in 2002, Handspring released the Treo which runs the Palm OS and features a Qwerty keyboard. In 2000, the Sony Clie, used the Palm OS and could play audio files. Later versions included a built-in camera and could capture and play Apple QuickTime™ video. Compaq (now Hewlett Packard) developed the iPAQ in 2000. The iPAQ and other PocketPCs run a version of Windows CE. Some PocketPC and PDA have wireless communication capabilities.
- In 2001, Apple released a music player, called the iPod, featuring a small, internal hard disk drive that could hold over 1000 songs and fit in your pocket. The original iPod has a display, a set of controls, and ports for connecting to a computer, such as a Macintosh or PC, via Firewire, and for connecting to headphones. However, the original iPod did not have a color display, a built-in camera, built-in speakers, built-in microphone or wireless communications.
- Portable Hand Held Devices: Cell Phone and Picture Phones
- The first cellular telephones had simple LCD displays suitable for displaying only a limited amount of text. More recently, cell phones have been developed which have larger, higher resolution displays that are both grayscale and color. Some cell phones have been equipped with built-in cameras with the ability to save JPEG still photos to internal memory. In April 2002, Samsung introduced a cell phone with a built-in still photo camera and a color display. The Samsung SCH-X590 can store up to 100 photos in its memory and can transfer still photos wirelessly.
- Cell phones can be used as wireless modems. Initially they had limited data bandwidth. Next, digital cell phones were developed. By early 2002, bandwidth was typically 60-70 Kbps. Higher bandwidth wireless networks are being developed.
- Hand Held Devices are Limited is Size and Weight
- Hand held devices are limited in size and weight. Many users are only willing to use a handheld device that weights a few ounces and can fit inside a typical shirt pocket, or even worn on their waist or arm. These size and weight limitation prevent handheld devices from having the electronic circuitry, processors, and batteries found in laptops and other larger computers. These limitations have made it impossible to provide full frame, full motion video display or live transmission on handheld devices.
- PDAs, PocketPCs, and Picture Phones are Limited by Battery Life, Processor Speed, and Network Bandwidth
- The existing, commercially available hand held devices have not been able to support live or streaming video for a number of reasons. Uncompressed full-motion, full frame video requires extremely high bandwidth that is not available to handheld portable devices. In order to reduce the bandwidth, lossy compression such as MPEG has been used to reduce the size of the video stream. While MPEG is effective in desktop computers with broadband connections to the Internet, decoding and displaying MPEG encoded video is very processor intensive. The processors of existing handheld devices are slower or less powerful than those used in desktop computers. If MPEG were used in a handheld device, the processor would quickly drains the battery of most handheld devices. Further, the higher bandwidth wireless communications interfaces would also place a large strain on the already strained batteries. Live video transmission and reception would be even more challenging. For this reason, handheld device have not been able to transmit or receive streaming, or especially, live video.
- What is needed is an enhanced handheld device that is capable of receiving streaming and live video. Further a handheld device that could capture and transmit live video would provide live coverage of events that would otherwise not be able to be seen. With handheld video devices that both transmit and receive live video, handheld wireless videoconferencing could become a reality. Also a video compression method that requires significantly reduced processing power and would be less draining on the battery of a handheld device is needed. Additionally since, handheld video display screens which are smaller than typical computer screens, a user of a handheld video receiver needs to be able control the portion of a video be transmitted to allow a smaller, higher quality video to be received and viewed on the handheld screen with dimensions smaller than the original video.
- In accordance with the present invention a handheld device comprises a black and white or color video display screen, speakers or headphones for hearing audio associated with the video display, controls for user input, a memory for storing compressed video data, and a processor for running computer programs which decompress the compressed video data and play the video on the display screen, and the video's audio on speakers and/or headphones. Further, some embodiments of the present invention include a microphone and video camera for inputting audio and video. A plurality of handheld video devices are connected to a network for exchanging video file, streaming video from a pre-recorded video file or live transmission from one device to one or more devices in remote locations. The network connections can be wired or wireless.
- One embodiment of the present invention comprises a video camera that can be removably mounted on an iPod-type device to add the video capture capability. Further the separate camera unit could include a microphone or speakers. Further, wireless communications could be added to the separate camera unit or as yet another removable unit.
- Further, the present invention includes a method of compression of a video stream comprising steps of sub-sampling a video frame, and run-length encoding the sub-sampled pixel values, whereby the method can be executed in real time, and whereby the compressed representation of pixels saves substantial space on a storage medium and requires substantially less time and bandwidth to be transported over a communications link. The present invention includes a corresponding method for decompressing the encoded data.
- Further, the present invention includes a zoom control that is graphically displayed on the display screen and receives input from either the touch screen or the controls of the handheld device. A user may use the zoom control to send remote control commands to a transmitting device to dynamically specify an area to be transmitted. Alternatively, the user may use the zoom control to magnify video that is being played from a file.
- Accordingly, beside the objects and advantages of the method described above, some additional objects and advantages of the present invention are:
-
- (a) to provide a handheld device for capturing audio and video which can be transmitted to another video display device.
- (b) to provide a handheld device for displaying video that has been received from a video capture and transmission device.
- (c) to provide a handheld wireless video conferencing system comprising handheld devices which act as both transmitters and receivers connected over a data network.
- (d) to provide an add-on module that will allow an iPod-type device to capture, transmit, or receive video.
- (e) to provide a graphical zoom control on a hand held video display device whereby the user can remotely control the area of the video that is being transmitted in high resolution.
- (f) to provide a graphical zoom control on a hand held video display device whereby the user can magnify a video being displayed.
- (g) to provide a method of compressing and decompressing video signals so that the video information can be transported across a digital communications channel in real time.
- (h) to provide a method of compressing and decompressing video signals such that compression can be accomplished with software on commercially available computers without the need for additional hardware for either compression or decompression.
- (i) to provide a high quality video image without the blocking and smearing defects associated with prior art lossy methods.
- (j) to provide a high quality video image that suitable for use in medical applications.
- (k) to enhance images by filtering noise or recording artifacts.
- (l) to provide a method of compression of video signals such that the compressed representation of the video signals is substantially reduced in size for storage on a storage medium.
- (m) to provide a level of encryption so that images are not directly viewable from the data as contained in the transmission.
- In the drawings, closely related figures have the same number but different alphabetic suffixes.
-
FIG. 1 shows the high level steps of compression and decompression of an image. -
FIGS. 2A to 2H show alternatives for selecting a pixel value for encoding. -
FIG. 3A shows the variable encoding format. -
FIG. 3B shows an example of a code where N is 5 bits wide and U is 3 bits wide. -
FIG. 4A shows the flowchart for the compression method. -
FIG. 4B shows an image and a corresponding stream of pixels. -
FIGS. 5A to 5C shows the formats for the run-length encoding of the RHN method. -
FIG. 6 shows a series of codes and the resulting encoded stream. -
FIG. 7 shows a series of codes and the resulting encoded stream of the RHN method. -
FIG. 8A shows examples of variable formats. -
FIG. 8B shows a format that preserves 9 bits of color. -
FIG. 9 shows the flow chart for the decompression method. -
FIG. 10 shows image stretching by interpolation. -
FIGS. 11A and 11B show an encryption table and a decryption table. -
FIGS. 12A and 12B show machines for compressing and decompressing, respectively. -
FIG. 12C shows a compressor and decompressor connected to a storage medium. -
FIG. 12D shows a compressor and decompressor connected to a communications channel. -
FIG. 13A shows elements of a compressor. -
FIG. 13B shows an embodiment of an encoding circuit. -
FIG. 13C shows a generic pixel sub-sampler. -
FIGS. 13D through 13J show embodiments of pixel sub-samplers. -
FIGS. 14A through 14C shows embodiments of a machine element for variably altering the number of bits. -
FIG. 15 shows elements of a decompressor. -
FIG. 16A shows elements for setting width, height, frame rate, brightness, and contrast which are variably altered by a receiver. -
FIG. 16B shows elements for setting the number of pixel bits that are variably altered by a receiver. -
FIG. 17 shows a lossless compression step for further compression of an encoded data buffer. -
FIG. 18 shows images being enlarged by stretching. -
FIGS. 19A through 19C show various network configuration comprising handheld video devices. -
FIGS. 20A through 20D show various embodiments of handheld video devices. -
FIGS. 21A through 21C show handheld video devices comprising graphical zoom controls. -
- 100 compression steps
- 110 sub-sampling step
- 130 encoding step
- 140 encoded data
- 150 decompression steps
- 160 decoding step
- 180 image reconstitution step
- 200 32 bit pixel value
- 202 blue channel
- 204 green channel
- 206 red channel
- 208 alpha channel
- 210 24 bit pixel value
- 212 blue component
- 214 green component
- 216 red component
- 220 RGB averaging diagram
- 222 blue value
- 224 green value
- 226 red value
- 228 averaged value
- 230 blue selection diagram
- 232 blue instance
- 234 green instance
- 236 red instance
- 240 selected blue value
- 250 green selection diagram
- 260 selected green value
- 270 red selection diagram
- 280 selected red value
- 290 grayscale pixel
- 292 grayscale blue
- 294 grayscale green
- 296 grayscale red
- 298 selected grayscale value
- 299 filtered pixel value
- 300 N
- 301 U
- 302 W
- 310
pixel bit 7 - 312
pixel bit 6 - 314
pixel bit 5 - 316
pixel bit 4 - 318
pixel bit 3 - 320
pixel bit 2 - 322
pixel bit 1 - 324
pixel bit 0 - 325 8 bit pixel
- 330 5 bit sample
- 332
sample bit 4 - 334
sample bit 3 - 336
sample bit 2 - 338
sample bit 1 - 340
sample bit 0 - 350 3 low order bits
- 360 formatted code
- 362 encoded
bit 4 - 364 encoded
bit 3 - 366 encoded
bit 2 - 368 encoded
bit 1 - 370 encoded
bit 0 - 380 3 bit count value
- 400 encode flowchart
- 402 encode entry
- 403 encode initialization step
- 404 get pixel step
- 405 get value step
- 406 lookup encoded value step
- 408 compare previous
- 410 increment counter step
- 412 check count overflow
- 414 new code step
- 416 check end of data
- 418 set done
- 420 counter overflow step
- 422 check done
- 428 encode exit
- 430 image
- 440 image width
- 450 image height
- 460 pixel stream
- 500 code byte
- 510 flag bit
- 520 repeat code
- 530 count
- 550 data code
- 560 wasted bits
- 565
data bit 6 - 570
data bit 5 - 575
data bit 4 - 580
data bit 3 - 585
data bit 2 - 590
data bit 1 - 595
data bit 0 - 610 decimal values
- 620 first value
- 622 second value
- 624 third value
- 626 fourth value
- 628 fifth value
- 630 sixth value
- 632 seventh value
- 640 binary code
- 650 first byte
- 651 first data
- 652 first count
- 653 second byte
- 654 second data
- 655 second count
- 656 third byte
- 657 third data
- 658 third count
- 740 RHN binary code
- 803 ZL3 format
- 804 ZL4 format
- 805 ZL5 format
- 808 ZL8 format
- 809 ZL9 format
- 812 ZL12 format
- 820 ZL9C format
- 900 decode entry
- 901 decode initialize step
- 902 get code step
- 908 decode lookup step
- 909 check zero count
- 910 place pixel step
- 914 reset counter step
- 916 check length
- 918 decode exit
- 920 decode flowchart
- 1010 first adjacent pixel
- 1012 second adjacent pixel
- 1014 first subsequent adjacent pixel
- 1016 second subsequent adjacent pixel
- 1052, 1054, 1056, 1058, 1060 interpolated pixels
- 1100 encryption table
- 1110 decryption table
- 1200 video frames
- 1205 a first video frame
- 1205 b second video frame
- 1205 n nth video frame
- 1210 compressor
- 1215 video signal
- 1220 series of encoded data
- 1225 encoded data buffer
- 1225 a first encoded data
- 1225 b second encoded data
- 1225 n nth encoded data
- 1230 received encoded data
- 1230 a first received encoded data
- 1230 b second received encoded data
- 1230 n nth received encoded data
- 1235 encoded data stream
- 1238 received encoded data
- 1240 I/O device
- 1245 input encoded data stream
- 1250 decompressor
- 1260 decoded video frame
- 1260 a first decoded video frame
- 1260 b second decoded video frame
- 1260 n nth decoded video frame
- 1268 decoded video frames
- 1270 video sequence
- 1280 storage medium
- 1290 communications channel
- 1310 video digitizer
- 1320
path 1320 - 1330 video memory
- 1331 scan
- 1332 pixel index
- 1340
path 1340 - 1350 encoding circuit
- 1360
path 1360 - 1370 encoded data
- 1380 pixel sub-sampler
- 1380 a 24 to 5 bit sub-sampler
- 1380 b 24-bit RGB to S bit sub-sampler
- 1380 c 32-bit RGB to 5 bit sub-sampler
- 1380 d color 9-bit sub-sampler
- 1380 e YUV sub-sampler
- 1380 f 36-bit RGB to 24 bit sub-sampler
- 1380 g 15-bit sub-sampler output
- 1382 pixel extractor
- 1383 value path
- 1384 coder
- 1385
path 1385 - 1390 data/count
- 1392 code index
- 1395
path 1395 - 1400 24-bit to variable bit sub-sampler
- 1401 generic 3-bit sub-sampler
- 1402 generic 4-bit sub-sampler
- 1403 generic 8-bit sub-sampler
- 1404 generic 10-bit sub-sampler
- 1410 number of bits selector
- 1420 number of bits indicator
- 1430 36-bit to variable bit sub-sampler
- 1440 24/36 bit variable bit sub-sampler
- 1450 second selector
- 1460 selection logic
- 1470 selection signal
- 1510 decoding circuit
- 1520 decoded pixel values
- 1530 decoder pixel index
- 1540 image memory
- 1600 transmitter
- 1610 receiver
- 1615 setting control path
- 1620 frame sub-sampler
- 1621
path 1621 - 1630 selected frame
- 1632 pixel from frame
- 1640 transmitter pixel sub-sampler
- 1642
path 1642 - 1650 run length encoder
- 1660 settings
- 1661 brightness
- 1662 contrast
- 1663 height
- 1664 width
- 1665 frame rate
- 1670 frame selector
- 1675 frame select indicator
- 1680 number of pixel bits setting
- 1690 alternate transmitter
- 1700 run-length encoding step
- 1710 run-length encoded output
- 1720 further lossless compression step
- 1730 further lossless compression
- 1800 unstretched frame
- 1810 enlarged image
- 1820 stretching step
- 1901 a first video
- 1901 b first reflected video
- 1902 a second video
- 1902 b second reflected video
- 1910 network
- 1910 a wired network
- 1910 b wireless network
- 1910 c combined network
- 1920 a first node
- 1920 b second node
- 1920 c third node
- 1920 d fourth node
- 1920 e fifth node
- 1930 reflector
- 1940 point-to-point transmission
- 1942 first indirect path
- 1944 second indirect path
- 2010 first handheld device
- 2012 display
- 2012 b second display
- 2012 d phone display
- 2014 controls
- 2014 d phone controls
- 2016 wireless port
- 2016 b second wireless port
- 2016 c integrated wireless port
- 2016 d cellular port
- 2020 headphone
- 2021 right speaker
- 2021 b right built-in speaker
- 2021 c right integrated speaker
- 2021 d right phone speaker
- 2021 e phone earphone
- 2022 microphone
- 2022 b built-in microphone
- 2022 c integrated microphone
- 2022 d phone microphone
- 2023 left speaker
- 2023 b left built-in speaker
- 2023 c left integrated speaker
- 2023 d left phone speaker
- 2024 speaker/microphone cable
- 2030 camera
- 2030 b built-in camera
- 2030 c integrated camera
- 2030 d phone camera
- 2032 lens
- 2034 camera cable
- 2040 second handheld device
- 2050 wireless connection
- 2051 wired connection
- 2051 a first wired connection
- 2051 b second wired connection
- 2052 video source
- 2054 video transmitter
- 2056 video storage
- 2060 integrated handheld device
- 2062 A/V module
- 2064 wireless module
- 2070 cellular integrated device
- 2100 zoom control
- 2102 a inner region
- 2102 b second inner region
- 2102 c third inner region
- 2104 a magnification factor
- 2104 b second magnification factor
- 2104 c third magnification factor
- 2106 a outer region
- 2106 b second outer region
- 2106 c second outer region
- 2110 a video display window
- 2110 b alternate video display window
-
FIG. 1 -Compression and Decompression Steps -
FIG. 1 illustrates a sequence ofcompression steps 100 and a sequence of decompression steps 150 of the present invention. The compression steps 100 comprise asub-sampling step 110 and anencoding step 130. After completion of the compression steps 100, a stream of encodeddata 140 is output to either a storage medium or a transmission channel. The decompression steps 150 comprise adecoding step 160 wherein the stream of encodeddata 140 is processed and animage reconstitution step 180. -
FIGS. 2A to 2H Selecting Pixel Values for Encoding -
FIGS. 2A to 2G illustrate alternatives for selecting a pixel value for encoding. The sub-sampling step 110 (FIG. 1 ) includes sub-sampling of a pixel value to obtain a variable selected number of bits. - Video digitizing hardware typical has the options of storing the pixel values as a 32
bit pixel value 200 or a 24bit pixel value 210, shown inFIG. 2A andFIG. 2B , respectively. The 32bit pixel value 200 is composed of ablue channel 202, agreen channel 204, ared channel 206, and analpha channel 208. Each channel contain 8 bits and can represent 256 saturation levels for the particular color channel. For each channel the saturation intensity value of zero represents the fully off state, and the saturation intensity value of “255” represents the fully on state. A common alternative not shown is a sixteen-bit format where the three color channels contain 5 bits each and the alpha channel is a single bit. The present invention anticipates the use of the color channels of 16 bit pixel value is a manner substantially the same as the 32-bit pixel value 200 except the number of bits per channel is 5 instead of 8. - The 24-
bit pixel value 210 is composed of ablue component 212, agreen component 214, and ared component 216. There is no component for the alpha channel in the 24bit pixel value 210. Regardless of the structure, theblue channel 202 is equivalent to theblue component 212, thegreen channel 204 is equivalent to thegreen component 214, and thered channel 206 is equivalent to thered component 216. - In the present invention, the 32
bit pixel value 200 alternative is preferred due to the consistent alignment of 32 bit values in most computer memories; however for simplicity of illustration thealpha channel 208 will be omitted inFIGS. 2C to 2G. - If the video signal is digitized in color, the three color components may have different values. For example in
FIG. 2C , a RGB averaging diagram 220 illustrates ablue value 222 of 35 decimal, agreen value 224 of 15, and ared value 226 of 10. One alternative is to sub sample from 24 bits to 8 bits by averaging the three color values to obtain an averagedvalue 228 that, in this example, has the value of 20. (10+15+35)/3=20. This will produce a grayscale image. Alternatively, a color image can be preserved by sampling bits from each color component (seeFIG. 8B ). -
FIG. 2D illustrates another alternative for selecting an 8 bit value in a blue selection diagram 230. In this example, ablue instance 232 has the value of 35, agreen instance 234 has the value of 15, and ared instance 236 has the value of 10. In this alternative theblue instance 232 is always selected as a selectedblue value 240. -
FIG. 2E illustrates another alternative for selecting an 8 bit value in a green selection diagram 250. In this alternative thegreen instance 234 is always selected as a selectedgreen value 260. -
FIG. 2F illustrates another alternative for selecting an 8 bit value in a red selection diagram 270. In this alternative thered instance 236 is always selected as a selectedred value 280. - If the video signal being digitized is grayscale, the three color components will have the same values. For example in
FIG. 2G , agrayscale pixel 290 comprises a grayscale blue 292 with a value of decimal 40, a grayscale green 294 with a value of 40, and a grayscale red with a value of 40. Because the values are all the same, it makes no difference which grayscale color component is selected, a selectedgrayscale value 298 will have the value of 40 in this example. - The preferred embodiment of this invention uses the low order byte of the pixel value, which is typically the blue component as shown in
FIG. 2D . -
FIG. 2H illustrates a filteredpixel value 299 of 8 bits that may be selected by one of the alternatives described above. In these examples, the filteredpixel value 299 is equivalent to items referenced bynumerals bit pixel value 200 or the 24bit pixel value 210 contributes a reduction in data size of 4:1 or 3:1, respectively. This reduction recognizes that for some images, such as medical images or grayscale images, no relevant information is lost. - For additional compression, the filtered
pixel value 299 can variably select any number of bits. For example, selection of the most significant four bits instead of all eight bits filters noise that may show up in the low order bits may be very suitable for an image such as one produced by an ultrasound medical device. An example of this is shown byZL4 804 inFIG. 8A . - FIGS. 3A and 3—Encoding Formats
- Speed of compression and decompression may be enhanced if the algorithms fit into computer memory native storage elements such as 8 bit bytes, 16 bit words, or 32 bit double words, or some other size for which the computer architecture is optimized.
- A grayscale image may be stored at a higher bit level than the actual values require. This may occur when an image is generated by an imaging technology such as radar, ultrasound, x-ray, magnetic resonance, or similar electronic technology. For example an ultrasound machine may only produce 16 levels of grayscale, requiring 4 bits of data per pixel, but the image digitizing may be performed at 8 to 12 bits per pixel. In this example, the low order bits (4 to 8) respectively provide no significant image data.
- In the present invention, a fast and efficient compression and encoding method is implemented by using unused bits to store a repeat count for repeated values.
- The most significant N bits of the pixel value are selected where N is the number of significant bits (determined by data analysis or by user selection). If N is less than W, where W is a native machine data type such as 8 bit byte, 16 bit word, or 32 bit double word or some other size for which the computer architecture is optimized, then W-N equals the number of unneeded bits, U. A repeat count, C, can contain a value from 1 to CMAX where CMA is 2 to the power of U. For example, if U equals 4, C can be a number from 1 to 16. In practice the maximum value will be encoded as a zero because the high order bit is truncated. In the example, decimal 16 has a binary value “10000” will be stored as “0000”.
- For example, when W is 8, value pairs for N and U could include without limitation (2,6), (3,5), (4,4), (5,3), and (6,2). When W is 16, value pairs for N and U could include without limitation (2,14), (3,13), (4,12), (5,11), (6,10), (7, 9), (8, 8), (9, 7), (10, 6), (11, 5), (12,4), (13, 3), and (14, 2). When W is 32, value pairs for N and U could include without limitation all combinations of values pairs for N and U where N+U equals 32 and N>1 and U>1. When W is not a multiple of 8, value pairs for N and U could include without limitation all combinations of values pairs for N and U where N+U equals W and N>1 and U>1.
-
FIG. 3A shows the encoded format whereN 300 represent the N most significant bits of thepixel value 299,U 301 represents the bits that are not used for the data and are used for the repeat count, andW 302 where W is the width of the encoded data and equal to sum of N and U -
FIG. 3B illustrates bit sub-sampling where N's 300 bit width is 5, U's 301 bit width is 3, andW 302 is 8. Thehigh order 5 bits 310-318 of an 8bit pixel 325 are extracted to form a fivebit sample 330. The lower 3 bits of 330 are ignoredbits 350. In the formattedcode 360, the ignoredbits 350 are replaced with therepeat count value 380. - Encoding
- The most significant N bits of each pixel are selected from the image to obtain value V.
- In the encryption embodiment of this invention V may be used to select an encoded value, E, from the encoding table. E is also a N-bit value. The number of elements in the encode table 1100 (
FIG. 11 ) is 2 to the Nth power. - In the other embodiments of this invention V is used as E.
- E is saved as the prior value, P. For each subsequent pixel, the encoded value, E, is obtained and compared to the prior value, P. If the prior value, P, is the same as E, then a repeat counter, C, is incremented; otherwise the accumulated repeat count, C, for the prior value, P, is merged with P and placed in an array A that implements the encoded data 140 (
FIG. 1 ) buffer. For example, if W is 8 and N is 4 and C is 10, U is 4, CMAX is 16, and ((P<<U)|C) is the merged value. If the repeat count, C, is greater CMAX, then CMAX is merged with P ((P<<U)|CMAX) and placed in the encoded data 140 (FIG. 1 ) buffer, A. CMAX is subtracted from C and merged values are placed in A until C is less than CMAX. All pixels are processed in this manner until the final value is compressed and encoded. The length, L, of the encoded data 140 (FIG. 1 ) is also placed in the encodeddata 140 buffer. -
FIG. 4A —Encode Flowchart -
FIG. 4A illustrates the encodeflowchart 400 which represents the details of the encryption embodiment of the encoding step 130 (FIG. 1 ) for the present invention. - The encoding begins at an encode
entry 402. In an encodeinitialization step 403, a prior value P is set to a known value, preferably decimal “255” or hexadecimal 0xFF, a repeat counter C is set to zero, an encoded length L is set to 0, and a completion flag “Done” is set to a logical value of false. Next, aget pixel step 404 obtains a pixel from the image being encoded. At aget value step 405, a value V is set to the N bitfiltered pixel value 299 as derived from the pixel using one of the methods shown inFIGS. 2C to 2G, preferably the fastest as explained above, and extracting the N most significant bits. At a lookup encodedvalue step 406, an encoded value E is set to the value of one of the codes 1105 (FIG. 11A ) of the encode table 1100 as indexed by V. (In the non-encrypted embodiment of this invention,step 406 is bypassed because V is used as E) Next, a compare previous 408 decision is made by comparing the values of E and P. If the values are the same, anincrement counter step 410 is executed and flow continues to theget pixel step 404 that obtains the next pixel from the image. - If the encode value E does not match the prior value P, then a
check count overflow 412 decision is made. If the counter C is less than or equal to CMAX, then anew code step 414 is executed, otherwise acounter overflow step 420 is executed. - At
step 414, the counter C is masked and bit-wise OR-ed with P shifted left by U bit positions and is placed in the A at the next available location as indexed by the encoded length L. Then, continuing insideflowchart step 414, L is incremented, the repeat count C is set to 1 and the prior value P is set to E. Afterstep 414, a “check end of data” decision is made by checking to see if there are any more pixels in the image, and, if not, if the last value has been processed. Because this method utilizes a readahead technique step 414 must be executed one more time after the end of data is reached to process the last run-length. If there is more data in the image, flow continues to a check of the completion flag “Done” atstep 422. If the check indicates that the process is not completed, flow continues to step 404. - If the end of data is reached but the completion flag “Done” is still false, flow continues to a set done
step 418. Atstep 418, the completion flag “Done” is set to logical true, and flow continues todecision 412 where the last run-length will be output and flow will eventually exit throughstep 414,decision 416,decision 422, and then terminate at encodeexit 428. - It is possible for the repeat count C to become larger than CMAX requiring more bits than allocated by this method. This situation is handled by making the
check count overflow 412 decision and executing thecounter overflow step 420. Atstep 420, the counter C is masked and bit-wise OR-ed with P shifted left by U bit positions and is placed in the A at the next available location as indexed by the encoded length L. Then, continuing insideflowchart step 414, L is incremented, and the repeat count C is decrement by CMAX. Afterstep 420, flow continues to thecheck count overflow 412 decision. Thus when the encode value E repeats more than CMAX times, multiple sets of repeat counts and encoded values are output to the encodeddata 140 buffer. - This entire process is repeated for each image or video frame selected during optional image sub-sampling (see 110 in
FIG. 1 ) and the encoded length L is transmitted with the encoded data associated with each frame. The encoded length varies from frame to frame depending on the content of the image being encoded. -
FIG. 4 —Image and Pixel Stream -
FIG. 4B illustrates an image and its corresponding stream of pixels. Arectangular image 430 is composed of rows and columns of pixels. Theimage 430 has awidth 440 and aheight 450, both measured in pixels. In this illustrative embodiment, pixels in a row are accessed from left to right. Rows are accessed from top to bottom. Some pixels in the image are labeled from A to Z. Pixel A is the first pixel and pixel Z is the last pixel. Scanning left to right and top to bottom will produce apixel stream 460. In thepixel stream 460, pixels A and B are adjacent. Also pixels N and 0 are adjacent even though they appear on different rows in the image. If adjacent pixels have the same code the process inFIG. 4A will consider them in the same run. - Because the video signal being digitized is analog there will be some loss of information in the analog to digital conversion. The video digitizing hardware can be configured to sample the analog data into the
image 430 with almost anywidth 440 and anyheight 450. The present invention achieves most of its effective compression by sub-sampling the data image with thewidth 440 value less than the conventional 640 and theheight 450 value less than the convention 480. In a preferred embodiment of the invention, for use in a medical application with T1 Internet transmission bandwidth, image dimensions are sub-sampled at 320 by 240. However an image dimension sub-sampling resolution of 80 by 60 may be suitable for some video application. -
FIGS. 5A to 5C—Run-length Encoding Formats of the RHN Method -
FIGS. 5A to 5C show use of a different structure than the present invention.FIGS. 5A to 5C show the formats for the run-length encoding of RHN. InFIG. 5A , acode byte 500, with its high order bit designated as aflag bit 510. -
FIG. 5B shows arepeat code 520 comprising a Boolean value one in itsflag bit 510 and a 7 bit count 530 in the remaining 7 low order bits. The seven bit count 530 can represent 128 values with a zero representing “128” and 1 through 127 being their own value. -
FIG. 5C shows adata code 550 comprising: -
- 1. a Boolean value zero in its
flag bit 510 - 2. two unused data bits: data bit 6 reference by 565 and data bit 5 reference by 570, and
- 3. five bits,
data bits 4 to 0, reference by 575, 580, 585, 590, and 595, respectively.
- 1. a Boolean value zero in its
-
FIG. 5C shows that in every byte of theRHN data code 550 two bits are unused and one bit is used for the flag bit, so that only five of the eight bits are used for data. The remaining three bits are wastedbits 560. The present invention uses a different structure by placing the repeat count in bits that the RHN format would not have used for data (U). The corresponding ZLN format, ZL5 (where N is 5, U is 3, and W is 8), always uses five bits for data and the remaining 3 bits for the repeat count. In practice, repeat counts are small and often can fit in 3 bits, so this embodiment of the present invention will result in superior compression performance over the RHN method. - In addition, the present invention provides for a larger count when the bit filtering is larger. For example, the alternate ZLN format where each byte contains 4 data bits, ZL4 (where N is 4 and U is 4), allows for a four bits of repeat count. For example, in practice, ZIA is superior to RHN on a typical ultrasound image containing 16 shades of gray.
-
FIG. 6 —Encoded Data Stream -
FIG. 6 shows a series of exemplarydecimal values 610 comprising afirst value 620 equal to decimal 0, asecond value 622 equal to 0, athird value 624 equal to 0, afourth value 626 equal to 0, afifth value 628 equal to 0, asixth value 630 equal to 2, and aseventh value 632 equal to 10. The value of zero is merely exemplary and could be any binary value. After the encoding step 130 (FIG. 1 ), the corresponding encoded data 140 (FIG. 1 ) would be compressed down to three bytes ofbinary code 640 comprising afirst byte 650, asecond byte 653, and athird byte 656 each containing a merged value and count, (651, 652), (654, 655), and (657, 658), respectively. Thefirst data 651 has a binary value of “00000” which equals the exemplary repeated decimal value. Thefirst count 652 has a binary value “101” which equals decimal five representing the run-length of the repeating value in the first five of the decimal values 610. Thesecond data 654 has a binary value of “00010” which equals the non-repeated decimal value two. Thesecond count 655 has a value of 1. Thethird data 657 has a binary value of “01010” which equals the non-repeated decimal value ten. Thethird count 658 has a value of 1. -
FIG. 7 —RHN Codes and Encoded Stream -
FIG. 7 shows the same series of decimal values 610 (FIG. 6 ) comprising thefirst value 620 equal to decimal 0, thesecond value 622 equal to 0, thethird value 624 equal to 0, thefourth value 626 equal to 0, the fifth value 728 equal to 0, the sixth value 730 equal to 2, and the seventh value 732 equal to 10. After encoding by RHN, the corresponding encoded data 140 (FIG. 1 ) would be compressed down to four bytes of RHNbinary code 740. - The embodiment of the present invention shown in
FIG. 6 only requires three bytes to encode the same data. In this example, the present invention is 25% better than the RHN format. - FIGS. 8A and 8—ZLN Formats
- The ZLN method of the present invention provides for variable formats. The values of
N 300,U 301, andW 302 can be dynamically changed between frames. For ease of communication a format is named with the prefix “ZL” and a digit representing the value of N. For example, “ZL5” refers to a format where bit width of N is equal to 5. There are multiple values of U depending of the W. To also specify the bit width of U a hyphen and a number can be appended. For example, “ZL5-13” represents a format where N=5 and U= - 13. “ZL5-3” is a common format and may be imprecisely referred to as “ZL5.”
-
FIG. 8A shows a number of formats with adjacent labels:ZL3 803,ZM4 804,ZL5 805,ZL8 808,ZL9 809, andZL12 812. Data bits are represented by “D,” and count bits are represented by “C”. -
FIG. 8B shows how the most significant 3 bits of each color component (216, 214, and 212 ofFIG. 2B ) are extracted and formatted in ZL9-7C format (the “C” append indicates that the color is preserved). With three red bits represented by “R”, three green bits represented “G” and three blue bits represented by “B”. - Decoding
- To decode the compressed array, the decoder has a decode table that corresponds with the encode table. For W*4 bit color pixels, the decode table contains the appropriate alpha, red, green, and blue values. For W*3 bit color pixels, the alpha value is not used. The compressed array is processed W bits at a time as X. The repeat count, C, is extracted from X by masking off the data value (C=X & (((2**N)−1)<<U)). The encoded value, E, is extracted from X by masking off the count (E=X & ((2**U)−1)). The encoded value, E may be used to index into the decryption. The decoded pixels are placed in a reconstructed image and repeated C times. Each element of the compressed array, A, is processed until its entire length, L, has been processed.
-
FIG. 9 —Decode Flowchart -
FIG. 9 illustrates thedecode flowchart 920 which presents the details of the decryption embodiment of the decode step 160 (FIG. 1 ) and the image reconstitution step 180 (FIG. 1 ). - The decoding begins at a
decode entry 900. In a “decode initialization”step 901, a repeat counter C is set to one, an encoded length L is set to the value obtained with the encoded data 140 (FIG. 1 ), and an index I is set to 0. Next, a “get code”step 902 obtains a signed byte X from the encoded data 140 (FIG. 1 ) array A. The index I is incremented. The count (for example the 3-bit count 380 as shown inFIG. 3B ) is extracted from X by masking off the data bits and placed in the repeat counter C (C=X & ((2**N)−1<<U). The value of E is extracted from X by masking off the count bits (E=X & (2**U)−1). In practice, the count mask and value mask can be pre-computed with the following two lines of code in the C programming language: - valueMask=−1<<U;
- countMask=˜valueMask;
- In this illustrative decryption embodiment of the present invention, flow goes to a “decode lookup”
step 908 where the value of E is used to index into the decode table 1110 (FIG. 11 ) to obtain a pixel value V. In the other embodiments where E is not encrypted, E is used as V and step 908 is bypassed. Flow continues to a “check zero count” 909 decision. - The 909 decision always fails the first time ensuring that a
place pixel step 910 is executed. Theplace pixel step 910 places the pixel value V in the next location of the decompressed image and decrements the repeat counter C and returns to the 909 decision. The pixel value V is placed repeatedly until C decrements to zero. Then the 909 decision branches flow to a “reset counter”step 914. Atstep 914 the repeat counter is reset to 1. - Flow continues to the “check length” 916 decision where the index I is compared to the encoded length L to determine if there are more codes to be processed. If I is less than L flow returns to step 902, otherwise the decode process terminates at a “decode exit” 918.
- The entire decode process is repeated for each encoded frame image.
-
FIG. 10 —Interpolation -
FIG. 10 illustrates interpolation when twoadjacent pixels adjacent pixels -
Pixels - 1. 1052 between 1010 and 1012
- 2. 1054 between 1010 and 1014
- 3. 1058 between 1012 and 1016
- 4. 1056 between 1054 and 1058
-
Pixel 1060 can be calculated on the interpolation for the subsequent row. -
FIG. 11 —Encryption - By using corresponding encoding and decoding tables the data can be encrypted and decrypted without using actual values. Encryption provides a level of security for the encoded
data 140 while in storage or transit. -
FIG. 11 shows an example of an encryption table 1100, where N is 3 and W is 8, and a decryption table 1110, where N is 3 and U is 5. - The encode table 1100 is 2 the power of N in length. If the target color image format is W*4 bit color, then the decode table 1110 has W bits for alpha, red, green, and blue each, respectively. If the target color image format is W*3 bit color, then the alpha value is not used. If the image is W bit grayscale then only the grayscale value is used to create the decompressed and decoded image.
- The corresponding table elements are mapped to each other. For example, 0 could encode to 22 as long as the 22nd element of the decode table returns (θxff<<24|θ<<16 |θ<<8 |θ).
- When these versions of the tables are used, the encode and decode processes and their speed of execution are substantially the same but the encoded data 140 (
FIG. 1 ) becomes a cipher and has a higher level of security. It should be recognized by one with ordinarily skill in the art that there are other embodiments of the present invention with different encryption/decryption table rearrangements. - FIGS. 12A through 12D—Compression and Decompression Devices
-
FIGS. 12A and 12B show devices for compressing and decompressing, respectively, a stream video frames. -
FIG. 12A shows avideo signal 1215 being compressed and encoded by acompressor 1210 to form an encodeddata stream 1235, which is sent to an I/O device 1240. Thevideo signal 1215 comprises a series ofvideo frames 1200, shown asfirst video frame 1205 a,second video frame 1205 b, . . . throughnth video frame 1205 n. The encodeddata stream 1235 comprises a series of encodeddata 1220, shown as first encoded data 1225 a, second encoded data 1225 b, . . . , through nth encoded data 1225 n. -
FIG. 12B shows an input encodeddata stream 1245 being received from an I/O device 1240, and then, decoded and decompressed by adecompressor 1250 to form avideo sequence 1270. The input encodeddata stream 1245 comprises received encodeddata 1238, shown as first received encodeddata 1230 a, second received encodeddata 1230 b, . . . , through nth received encodeddata 1230 n. Thevideo sequence 1270 comprises a series of decodedvideo frames 1268, shown as first decodedvideo frame 1260 a, second decodedvideo frame 1260 b, . . . , through nth decodedvideo frame 1260 n. -
FIG. 12C shows an embodiment where the I/O device 1240 ofFIGS. 12A and 12B is astorage medium 1280. The encodeddata stream 1235 from thecompressor 1210 is stored in thestorage medium 1280. Thestorage medium 1280 provides the input encodeddata stream 1245 as input to thedecompressor 1250. -
FIG. 12D shows an embodiment where the I/O device 1240 ofFIGS. 12A and 12B is acommunications channel 1290. The encodeddata stream 1235 from thecompressor 1210 is transmitted over thecommunications channel 1290. Thecommunications channel 1290 provides the input encodeddata stream 1245 as input to thedecompressor 1250. - FIGS. 13A through 13J—Compressor Details, Encoding Circuit, and Bitwise Pixel Sub-Samplers
-
FIG. 13A shows details of an embodiment of thecompressor 1210, which comprises avideo digitizer 1310, avideo memory 1330, anencoding circuit 1350, and encodeddata 1370. Eachvideo frame 1205 in the series ofvideo frames 1200 is digitized by thevideo digitizer 1310 and stored alongpath 1320 in thevideo memory 1330. Theencoding circuit 1350 access the digitized video frame viapath 1340 and outputs the encodeddata 1370 alongpath 1360. The encodeddata 1225 corresponding to eachvideo frame 1205 is then output from thecompressor 1210. -
FIG. 13B shows further details of an embodiment of theencoding circuit 1350. Apixel sub-sampler 1380 scans each pixel from the digitized video frame in thevideo memory 1330. Apixel index 1332 is used to drive ascan 1331 signal to select each pixel from the video memory, in a predetermined sequence. A novel aspect of the present invention is that the compression method can be accomplished with a single scan of the video memory for each frame. Thepixel sub-sampler 1380 selects a predetermined number of bits from each pixel and outputs the data value alongpath 1385. Alternatively, thepixel sub-sampler 1380 encodes the sub-sampled data by using a lookup table similar toFIG. 11A .Different pixel sub-samplers 1380 will be discussed in reference toFIGS. 13C through 13J . The data/count 1390 unit increments the count each time the output of thepixel sub-sampler 1380 is the same; otherwise, when the output of thepixel sub-sampler 1380 is different (or when the counter reaches the maximum count value, the data and count are combined as a code and output alongpath 1395 to the encodeddata 1225 for the frame currently in thevideo memory 1330. The location of the code in the encodeddata 1225 is selected by thecode index 1392 signal. -
FIG. 13C shows further details of ageneric pixel sub-sampler 1380. When a pixel is scanned from video memory alongpath 1340, it has an original pixel bit width, P.A pixel extractor 1382 extracts a subset of bits from each pixel with a value bit width, V, alongvalue path 1383. The value bit width V is less than the pixel bit widthP. A coder 1384 takes the V bits from thepixel path 1383 and outputs a code with an encoded bit width, E, as the data value alongpath 1385. One embodiment of the coder is a null coder, or pass-through coder. Another embodiment of the coder uses an encryption table to encrypt the data value as an encrypted data value. -
FIGS. 13D through 13J show embodiments of pixel sub-samplers. -
FIG. 13D illustrates a 24 to 5 bit sub-sampler 1380 a, where the pixel bit width, P, is 24; the value bit width, V, output from thepixel extractor 1382 is 8 (seeFIG. 2H ); and the encoded bit width, E, output from thecoder 1384 is 5. In this embodiment, the extracted 8 bits could be any component of the grayscale (e.g.FIG. 2G ) or thehigh order 8 bits of the 24-bit value. -
FIG. 13E illustrates a 24-bit RGB to 5 bit sub-sampler 1380 b, where the pixel bit width, P, is 24 divided into 8 bits of red, green, and blue (RGB, seeFIG. 2B ); the value bit width, V, output from thepixel extractor 1382 is 8; and the encoded bit width, E, output from thecoder 1384 is 5. In this embodiment, the extracted 8 bits could be an average (e.g.FIG. 2C ) or one of the colors (e.g.FIGS. 2D, 2E , or 2F). -
FIG. 13F illustrates a 32-bit RGB to 5 bit sub-sampler 1380 c, where the pixel bit width, P, is 32 divided into 8 bits of red, green, blue, and alpha (seeFIG. 2A ); the value bit width, V, output from thepixel extractor 1382 is 8; and the encoded bit width, E, output from thecoder 1384 is 5. In this embodiment, the extracted 8 bits could be an average (e.g.FIG. 2C ) or one of the colors (e.g.FIGS. 2D, 2E , or 2F). -
FIG. 13G illustrates a color 9-bit sub-sampler 1380 d, where the pixel bit width, P, is 24 divided into 8 bits each of red, green, and blue; the value bit width, V, output from thepixel extractors 1382 is 9; and the encoded bit width, E, output from thecoder 1384 is 9. In this embodiment, thehigh order 3 bits of each color component are selected (e.g. ZL9C shownFIG. 8B ). -
FIG. 13H illustrates aYUV sub-sampler 1380 e, where the pixel bit width, P, is 24 divided into 8 bits for each of YUV; the value bit width, V, output from thepixel extractors 1382 is 8; and the encoded bit width, E, output from thecoder 1384 is 5. In this embodiment, four bits of the Y value is extracted and 2 bits of each of the U and V values are extracted. This 8 bit value is further coded as a 5 bit value. -
FIG. 13I illustrates a 36-bit RGB to 24 bit sub-sampler 1380 f, where the pixel bit width, P, is 36 divided into 12 bits each of red, green, and blue; the value bit width, V, output from thepixel extractors 1382 is 24; and the encoded bit width, E, output from thecoder 1384 is also 24. In this embodiment, thehigh order 8 bits of each 12-bit color component are selected. -
FIG. 13J illustrates a 15-bit sub-sampler 1380 g, where the pixel bit width, P, is 24 divided into 8 bits from each color component; the value bit width, V, output from thepixel extractor 1382 is 15; and the encoded bit width, E, output from thecoder 1384 is 15. In this embodiment, thehigh order 5 bits of each 8-bit color component are selected. - FIGS. 14A through 14C—Variable Selection of Bit-wise Sub-sampling
-
FIGS. 14A through 14C shows embodiments of a device for variably altering the number of bits. -
FIG. 14A illustrates 24-bit to variable bit sub-sampler 1400. When a pixel is scanned from video memory alongpath 1340, it has an original pixel bit width, P, equal to 24 bits. These 24 bits are passed as input to a number of sub-samplers. The variable number of bits is selected by a number ofbits selector 1410 as indicated by a number ofbits indicator 1420 and outputs a code with an variable encoded bit width, E, as the data value alongpath 1385. A user atremote receiver 1610 sets the number of bits indicator 1420 (see discussion regardingFIGS. 16A and 16B ). The variable bit sub-sampler comprises a generic 3-bit sub-sampler 1401, a generic 4-bit sub-sampler 1402, generic 8-bit sub-sampler 1403, and generic 10-bit sub-sampler 1404 which are embodiments of the generic sub-sampler shown inFIG. 13C with specific values for E. The variable bit sub-sampler further comprises nested sub-samplers: the 24 to 5 bit sub-sampler 1380 a ofFIG. 13D , the 1380 d ofFIG. 13G , and the 15-bit sub-sampler 1380 g ofFIG. 13J . This is illustrative of the types of bit sub-samplers that can be variably selected. - Likewise,
FIG. 14B illustrates a 36-bit to variable bit sub-sampler 1430, where P is 36 and the number of bit that can be selected are 12, 15, or 24, respectively. -
FIG. 14C shows that the 24 bit to variable bit sub-sampler 1400 ofFIG. 14A and the 36-bit to variable bit sub-sampler 1430 ofFIG. 14B can be further combined to form at 24/36 bit variable bit sub-sampler 1440 where asecond selector 1450 is used to selected either the 24 bit inputs or the 36 bit inputs usingselection logic 1460 that also receives the number ofbits indicator 1420. Aselection signal 1470 enables either the output of 24-bit to variable bit sub-sampler 1400 or the output of 36-bit to variable bit sub-sampler 1430.Sub-samplers bits indicator 1420 as shown inFIG. 14A andFIG. 14B . In this way any number of bits may reasonably be selected from either a 36 or 24-bit pixel bit width. -
FIG. 15 —Decompressor Elements -
FIG. 15 shows details of an embodiment of thedecompressor 1250, which comprises adecoding circuit 1510 which inputs received encodeddata 1230 and outputs decodedpixel values 1520 to animage memory 1540. Adecoder pixel index 1530 selects the location in theimage memory 1540 to store the decoded pixels values 1520. Theimage memory 1540 delivers each decodedvideo frame 1260 to the video display. - FIGS. 16A and 16B—Parameters Altered by a Remote Receiver
-
FIG. 16A shows a system for setting width, height, frame rate, brightness, and contrast in atransmitter 1600 which are variably altered by areceiver 1610. The receiver sends commands to thetransmitter 1600 via settingcontrol path 1615. The commands alter thetransmitter settings 1660. - The
settings 1660 includebrightness 1661,contrast 1662,height 1663,width 1664, andframe rate 1665. Thebrightness 1661,contrast 1662,height 1663, andwidth 1664 setting alter the attributes of each frame as it is digitized in aframe sub-sampler 1620. Thebrightness 1661 andcontrast 1662 settings alter the video digitizer 1310 (FIG. 13A ) as it senses the video frame. Theheight height frame rate 1665 setting alters theframe selector 1670 which drives the frameselect indicator 1675 to optionally sub-sample frames from a sequence of video frames; this is frame sub-sampling. - The
frame sub-sampler 1620 outputs a selectedframe 1630 alongpath 1621. Thetransmitter pixel sub-sampler 1640 scans the selectedframe 1630 getting each pixel fromframe 1632 and outputs data values alongpath 1642 to arun length encoder 1650. The encodeddata stream 1235 is then transmitted to theremote receiver 1610. -
FIG. 16B shows additional elements of a system for setting the number of pixel bits in analternate transmitter 1690 which is variably altered by areceiver 1610. The receiver sends commands to thetransmitter 1600 via settingcontrol path 1615. The commands alter thetransmitter settings 1660. The settings include a number of pixel bits setting 1680 which affect the number of bits selected by thetransmitter pixel sub-sampler 1640. Thepixel sub-sampler 1640 could be any pixel sub-sampler, for example, seeFIGS. 13C through 13J and 14A through 14C. Thetransmitter pixel sub-sampler 1640 scans the selected frame 1630 (as inFIG. 16A ) getting each pixel fromframe 1632 and outputs data values alongpath 1642 to arun length encoder 1650. The encodeddata stream 1235 is then transmitted to theremote receiver 1610. - These embodiments illustrate the novel feature of the present invention of allowing a user at a
remote receiver 1610 to control aspects of thetransmitter -
FIG. 17 —Further Lossless Compression Step -
FIG. 17 shows a lossless compression step for further compressing an encoded data buffer. After a run-length encoding step 1700 in the transmitter, a run-length encodedoutput 1710 can be further processed with a furtherlossless compression step 1720 resulting in furtherlossless compression output 1730. The furtherlossless compression step 1720 could be implemented as a variable length coding, arithmetic coding, or other compression step known in the art. -
FIG. 18 —Image Stretching -
FIG. 18 shows images being enlarged by stretching. Anunstretched frame 1800 is stretched during stretchingstep 1820 resulting in anenlarged image 1810. When a frame is image sub-sampled or area sub-sampled, the remaining data can be stretched to fill the full display area on thereceiver 1610. This results in an interpolated image or magnified image, respectively. - FIGS. 19A through 19C—Handheld Video Transmission Networks
-
FIGS. 19A through 19C show various network configuration comprising handheld video devices. -
FIG. 19A illustrates an exemplary network 1910 comprising afirst node 1920 a, asecond node 1920 b, and anoptional reflector 1930. The network 1910 is shown as awired network 1910 a. Thefirst node 1920 a is displaying afirst video 1901 a of a man. Thesecond node 1920 b is displaying asecond video 1902 a of a woman. This illustrates a videoconference between the man at thesecond node 1920 b and the woman at thefirst node 1920 a. In the first mode of operation, the respective videos are transmitted over a point-to-point transmission 1940 path between the two nodes over the network 1910. In another mode of operation each of the videos is transmitted to the reflector where both videos are displayed as first reflectedvideo 1901 b and second reflectedvideo 1902 b. Thesecond video 1902 a originates at thefirst node 1920 a is transmitted to the reflector over firstindirect path 1942. Thesecond video 1901 a originates at thesecond node 1920 b is transmitted to the reflector over secondindirect path 1944. The reflector then retransmits the two videos to the respective display nodes, 1920 a and 1920 b, over the indirect paths. In other configurations, the reflector would also transmit the combined video to other nodes participating in the videoconference. -
FIG. 19B shows an example of three nodes,third node 1920 c,fourth node 1920 d, andfifth node 1920 e in a wireless network. The wireless connections are shown as waves. The three nodes operate in the same manner as the three nodes inFIG. 19A . -
FIG. 19C shows an example of a combinednetwork 1910 c where five nodes are connect in a network comprised of both awired network 1910 a and awireless network 1910 b. Any of the five nodes could transmit video to any of the other nodes in the combined network. Any node, for examplethird node 1920 c as shown, could act as areflector 1930. - In another embodiment of the present invention, any node could act as a video server and transmit pre-recorded video to one or more other nodes.
- These illustrations are exemplary. In practice, combined networks could consist of any number of nodes. Any of the nodes in the network could be a handheld video device.
- FIGS. 20A through 20D—Handheld Video Devices
-
FIGS. 20A through 20D show various embodiments of handheld video devices. -
FIG. 20A shows a handheld video transmitter comprising avideo source 2052, avideo transmitter 2054, andvideo storage 2056. -
FIG. 20B shows two handheld video devices in communication over either awireless connection 2050 or awired connection 2051. - A
first handheld device 2010 comprises adisplay 2012,manual controls 2014, awireless port 2016, and a firstwired connection 2051 a. While either thewireless port 2016 or thewired connection 2051 a could be present, only one of the two would be necessary to receive video from or transmit video to other nodes in the network 1910. In this example, the first handheld device is shown as an iPod-type device with an internal hard disk drive. Thefirst handheld device 2010 further comprises aheadphone 2020, connected via a speaker/microphone cable 2024, and acamera 2030, connected via acamera cable 2034. Theheadphone 2020 comprises aright speaker 2021, amicrophone 2022, and aleft speaker 2023. Thecamera 2030 has alens 2032 and internal circuitry that converts the light that passes through thelens 2032 into digital video data. - In the best mode for this embodiment, the iPod-type device is implemented using a standard Apple iPod (enhanced with an audio input for the microphone and, optionally, with a wireless port, and appropriate software), and the
camera 2030 is implemented using an iBot Firewire camera manufactured by Orange Micro, a lower performing Connectix USB camera, or similar camera. Alternatively, if the iPod-type device were only used of viewing video, the Apple iPod could be used without hardware modification. In another variation, the microphone could be build into the camera (not shown) instead of the headphones. - A
second handheld device 2040 comprises asecond display 2012 b, asecond wireless port 2016 b, and a secondwired connection 2051 b. While either thewireless port 2016 b or thewired connection 2051 b could be present, only one of the two would be necessary to receive video from or transmit video to other nodes in the network 1910. In this example, the second handheld device is shown as a device with a touch screen. Thesecond handheld device 2040 further comprises a right built-inspeaker 2021 b, a built-inmicrophone 2022 b, a left built-inspeaker 2023 b, and a built-incamera 2030 b withlens 2032. - The configuration of the
second handheld device 2040 has the advantage of eliminating the cables for the external headphone and camera of thefirst handheld device 2010 by having all elements built-in. - These two devices are exemplary. A two-device handheld videoconferencing network could have two identical handheld devices, such as the
first handheld device 2010. Further, a single device with a camera (as shown) could transmit video for display on any number of hand held devices that do not have cameras or microphones. -
FIG. 20C illustrates anintegrated handheld device 2060 comprising aniPod type device 2010, an A/V module 2062 and anoptional wireless module 2064. TheiPod type device 2010 comprisesdisplay 2012, controls 2014, and awired connection 2051. The A/V module 2062 comprises a rightintegrated speaker 2021 c, anintegrated microphone 2022 c, a leftintegrated speaker 2023 c, and aintegrated camera 2030 c withlens 2032. The A/V module 2062 could be manufactured and marketed separately (as shown) as an add-on module for standard iPods, or could be incorporated into the iPod packaging as an enhanced iPod-type device. Thewireless module 2064 comprises anintegrated wireless port 2016 c. Thewireless module 2064 also could be manufactured and marketed separately (as shown) as an add-on module for standard iPods, or could be incorporated into the iPod packaging as an enhanced iPod-type device. - The configuration of the
integrated handheld device 2060 has the advantage of eliminating the cables for the external headphone and camera of thefirst handheld device 2010 by having all elements integrated into removably attached modules that form a single unit when attached. The user can configure the standard iPod based on the user's intended use. If only a wireless connection is needed, only thewireless module 2064 can be attached to the iPod; in this configuration video can be received and displayed but not transmitted. If only video transmission is necessary and a wired connection is convenient, thewireless module 2064 can be omitted. Either configuration provides a single integrated unit that can be carried in the user's pocket and can store and display videos. -
FIG. 20D illustrates an cellularintegrated device 2070 comprisingphone display 2012 d, phone controls 2014 d (including a number keypad), acellular port 2016 d, aright phone speaker 2021 d, aphone earphone 2021 e,phone microphone 2022 d, leftphone speaker 2023 d, and aphone camera 2030 d withlens 2032. - Any of the handheld devices shown in
FIGS. 20A through 20D could be nodes in video transmission networks, such as those shown inFIGS. 12D and 19A through 19C. Each transmitting device preferably would include acompressor 1210 as shown inFIGS. 12A and 12D . Each receiving device preferably would include adecompressor 1250 as shown inFIGS. 12B and 12D . Thecompressor 1210 anddecompressor 1250 preferably would implement one or more embodiments of the compression methods discussed above. - FIGS. 21A through 21C—Handheld Video Devices with Graphical Zoom Control
-
FIGS. 21A through 21C show exemplary handheld video devices comprising graphical zoom controls. - A graphical user interface (GUI) graphically corresponds to a video display window 2110 through which a single image or a stream of video frames is displayed. The GUI and the video display window 2110 are displayed on a display 2012 (or 2012 b or 2012 d). The GUI includes a
zoom control 2100 having an inner region 2102 positioned within an outer region 2106. Thezoom control 2100 is a graphical way for the user of a remote receiver 1610 (seeFIGS. 16A and 16B ) to send remote control commands to set the parameters of a video transmitter (1600 or 1690) for control the area of the video to be compressed and transmitted. -
FIG. 21A shows an embodiment of the iPod-type handheld device 2010 ofFIG. 20C displaying azoom control 2100 having aninner region 2102 a positioned within anouter region 2106 a. The zoomed video image is show invideo display window 2110 a. In this embodiment thezoom control 2100 is displayed on top of thevideo display window 2110 a. The size and position of theinner region 2102 a relative to the outer region 1206 a shows the user which portion of the original video is being received and magnified. Only the selected portion of the original video (in this example, the hair and top of the face) needs to be transmitted in full resolution or high quality. A low resolution, or thumbnail version of the original video frame is optionally displayed in theouter region 2106 a. The thumbnail can be updated at a rate slower than the frame rate of the magnified video, such as once or twice a second. Themagnification factor 2104 a shows thetext 2× showing that the portion being displayed in thevideo display window 2110 a is being displayed at twice the size. -
FIG. 21B shows an embodiment of the cellularintegrated device 2070 ofFIG. 20D displaying azoom control 2100 having an secondinner region 2102 b positioned within an secondouter region 2106 b. The zoomed video image is shown in alternatevideo display window 2110 b. In this embodiment, thezoom control 2100 is displayed outside and below the alternatevideo display window 2110 b. The size and position of the secondinner region 2102 b relative to the second outer region 1206 b shows the user which portion of the original video is being received and magnified. Only the selected portion of the original video (in this example, the lower face and tie) needs to be transmitted in full resolution or high quality. A low resolution, or thumbnail version of the original video frame is optionally displayed in the secondouter region 2106 b. Thesecond magnification factor 2104 b shows thetext 2× showing that the portion being displayed in the alternatevideo display window 2110 b is being displayed at twice the size. -
FIG. 21C shows an embodiment of thesecond handheld device 2040 ofFIG. 20B displaying azoom control 2100 having an thirdinner region 2102 c positioned within an thirdouter region 2106 c. The zoomed video image is shown in avideo display window 2110 a shown filling the second display 2112 b. In this embodiment, thezoom control 2100 is displayed over thevideo display window 2110 a. The size and position of the thirdinner region 2102 c relative to the third outer region 1206 c shows the user which portion of the original video is being received and magnified. Only the selected portion of the original video (in this example, the right shoulder of the woman) needs to be transmitted in full resolution or high quality. A low resolution, or thumbnail version of the original video frame is optionally displayed in the thirdouter region 2106 c. Thethird magnification factor 2104 c shows thetext 3× showing that the portion being displayed in thevideo display window 2110 a is being displayed at three times the size. In this embodiment the controls (similar in function to controls 2014) are incorporated into a touch screen of thesecond display 2012 b. The user enters zoom in, zoom out, and pan commands by tapping the thirdinner region 2102 c or the third outer region 2106, or by selecting and dragging the outline of the thirdinner region 2102 c. - Operation of Graphical Zoom Controls
- A user controls aspects and changes parameters of the image displayed within the video display window 2110 using the
controls 2014 to enter input commands within thezoom control 2100 by selecting appropriate parts of the controls 2104 (or regions of thezoom control 2100 on a touch screen or with a pointing device). Thecontrols 2014 can be a touch screen, touch pad, iPod-like scroll pad, remote control or other device, depending on the configuration of the handheld device. - The size of the inner region 2102 relative to the outer region 2106 represents the magnification of the portion of the image being displayed within the video display window 2110. A magnification factor 104 representing the current magnification of the image being displayed within the video display window 2110 from the original image is displayed within the inner region 2102. The magnification of the image being displayed is increased by tapping within the inner region 2102, or while in zoom control mode, pressing the “zoom in” button on a iPod-type control 2104 or
cell phone control 2014 d. As the magnification is thus increased, the size of the inner region 2102 is decreased appropriately relative to the outer region 2106 and the magnification factor 104 is appropriately incremented. The magnification of the image being displayed is decreased by tapping outside of the inner region but inside of the outer region, or while in zoom control mode clicking the “zoom out” button on a iPod-type control 2104 orcell phone control 2014 d. As the magnification is thus decreased, the size of the inner region 102 is increased appropriately relative to the outer region 2106 and the magnification factor 104 is appropriately decremented. - The position of the inner region 2102 within the outer region 2106 represents the portion of the entire original image being displayed within the video display window 2110. The portion of the image being displayed within the video display window 2110 is changed by moving the inner region 2102 to the desired position within the outer region 2106 using the touch screen, a pointing device, or the
controls - The
display 2012 including the video display window 2110 and a graphical user interface including thezoom control 2100, according to the present invention. Thezoom control 2100 of the present invention preferably includes two regions 2102 and 2106. The outer region 2106 forms the outer edge of thezoom control 2100 and represents the entire available original image. The inner region 2102, is included and positioned within the outer region 2106 and represents a region of interest of the original image currently being displayed within the video display window 2110. Within the inner region 2102, a magnification factor 104 is optionally displayed, representing the current magnification being applied to the image displayed within the video display window 2110. - The magnification factor 104 is changed by using the touch screen or controls 2014 (or 2014 d) to zoom in or zoom out. By zooming in a number of times, the inner region 102 becomes continually smaller in size and the magnification factor 104 is incremented a number of times equal to the number of times that the control zoomed in.
- A user zooms out on a specific portion of the image to decrease the magnification factor 104; the inner region 102 becomes appropriately larger in size and the magnification factor 104 is decremented. By zooming out a number of times, the inner region 102 becomes increasingly larger with each zoom out and the magnification factor 104 is decremented a number of times equal to the number of times the user zooms out, until the magnification factor is equal to 1.
- The inner region 2102 also has a pan or positional feature within the outer region 2106, such that the position of the inner region 2102 within the outer region 2106 represents the portion of the entire original image that is being displayed within the video display window 2110. The position of the inner region 2102 is changed within the outer region 2106 by using the touch screen, a pointing device, or controls 2014 to move the inner region 2102 to the desired position within the outer region 2106. Accordingly, the inner region 2102 graphically represents what portion of the entire image is currently being displayed within the video display window 2110 and what magnification factor 104 is currently being used to make this selected portion of the original image fit within the video display window 2110.
- Advantages
- Video Coverage of Remote Events
- The present invention will allow low cost, portable, video transmission of events of interest whenever and wherever they happen. These handheld wireless video transmitters will be able to provide news coverage of wars, natural disasters, terrorist attacks, traffic and criminal activities in a way that has never before been possible.
- Improved Continuous Communication
- The present invention will enabled enhanced personal communication between friends, family, and co-workers in ways never before possible.
- Improved Entertainment and Education
- The present invention will enabled the transmission of video-based entertainment and education in ways never before possible. User will be able to use pocket-sized, handheld device to watch video that are downloaded from a global media exchange, streamed from a video server, or transmitted live from a performance, classroom, laboratory, or field experience.
- Improved Healthcare
- The present invention would enable a physician or medical specialist to receive medical quality video any time in any location. For example, a critical emergency room ultrasound study could be monitored while it is being performed by less skilled emergency room personnel ensuring that the best medical image is acquired. A rapid diagnosis can be made and the results of a study can be verbally dictated for immediate transcription and use within the hospital.
- Further, the present invention could be used to transmit medical quality video from a remote, rural location, including a battle ground. It could also be used to transmit guidance and advice from an expert physician into a remote, rural location.
- Thus, the present invention can improve medical care, reduce the turnaround for analysis of medical studies, reduce the turnaround for surgery, and provide medical professionals with continuous access to medical quality imaging.
- Noise Filtering and Image Enhancement
- The removal of the least significant bits of pixel values results in high quality decompressed images when the original image is generated by an electronic sensing device, such as an ultrasound machine, which is generating only a certain number of bits of grayscale resolution. By variably altering the number of most significant bits, various filters can be implemented to enhance the image quality. Such a noise filter can be beneficial when the image is generated by an imaging technology such as radar, ultrasound, x-ray, magnetic resonance, or similar technology. Variations can be made to enhance the perceived quality of the decompressed image. Therefore, altering the number of data bits selected and altering the width of the repeat count is anticipated by this invention and specific values in the examples should not be construed as limiting the scope of this invention.
- Dynamic Variable Formats
- While a video stream is being viewed a viewer on the decoding end of the transmission can vary the settings for the compressor. Different tradeoffs between image spatial and temporal quality can be made. As the contents of the video signal change an appropriate format can be selected. Control signals can be sent back to the compressor via a communications link.
- Execution Speed
- The preferred embodiment of this invention uses a number of techniques to reduce the time required to compress and decompress the data.
- The methods require only a single sequential pass through the data. Both the compression steps 100 and the decompression steps 150 access a pixel once and perform all calculations.
- When selecting the filtered
pixel value 299, the preferred embodiment selects the low order byte from the 32bit pixel value 200 or the 24bit pixel value 210 so that an additional shift operation or addressing operation is avoided. - The shift operation is a fast and efficient way to convert a byte or word to the filtered
pixel value 299. - General Purpose
- The lossless compression of the sampled data achieved by the preferred embodiment of the present invention results in high quality video streams that have general purpose application in a number of areas including, without limitation, video conferencing, surveillance, manufacturing, rich media advertising, and other forms of video transmission, storage, and processing.
- Lossless Nature/No Artifacts
- Once the analog signal is sub-sampled and filtered to select a filtered pixel value that eliminates some of the real world defects, the methods of the present invention compress and decompress the data with no irreversible data loss. Unlike JPEG and MPEG, the decompressed image never suffers from artificially induced blocking or smearing or other artifacts that are result of the lossy compression algorithm itself. As a result even a small sub-sample of the image remains clear and true to the perceived quality of the original image.
- Superior Features over RHN Format
- When compared against the RHN format, the format and methods of the present invention provide a number of advantages, including, but not limited to, faster speed and smaller size of encoded data, better performance for both medical and typical video images, and a typically closer representation of the original video signal.
- Accordingly, the reader will see that handheld wireless devices are used to receive and display high quality video. The video can be displayed as it is received live and a graphical zoom control can be used to dynamically control the area of the source image that is to be transmitted in full resolution. In other embodiments, a handheld wireless device captures the video with an attached video camera and microphone and the device transmits the video images live as they are captured. A single handheld wireless video transmitter can transmit to multiple handheld wireless receivers. A plurality of handheld wireless video devices which capture, transmit, receive, and display video over a network are used for mobile video conferencing. In other embodiments the video data is transferred as a video file or streamed from a video server contain pre-recorded video files.
- Further the compression and decompression steps of the present invention provides a means of digitally compressing a video signal in real time, communicating the encoded data stream over a transmission channel, and decoding each frame and displaying the decompressed video frames in real time.
- Furthermore, the present invention has additional advantages in that:
- 1. it enables live video transmission and display on pocket-sized handheld devices;
- 2. it enables wireless videoconferencing with portable, handheld video devices;
- 3. it provides an iPod-type device which is able to display high quality color video;
- 4. it provides an iPod-type device which is able to be used as a wireless video transmitter or receiver.
- 5. it enables video coverage of remote events or catastrophic events;
- 6. it improves interpersonal communication, productivity, and effectiveness;
- 7. it improves education;
- 8. it improves entertainment;
- 9. it improves and expands healthcare at lower costs;
- 10. it provides a means of filtering real world defects from the video image and enhancing the image quality;
- 11. it allows for execution of both the compression and decompression steps using software running on commonly available computers without special compression or decompression hardware;
- 12. it provides decompressed images that have high spatial quality that are not distorted by artifacts of the compression algorithms being used;
- 13. it provides a variably scalable means of video compression; and
- 14. it provides a means for reducing the space required in a storage medium.
- Although the descriptions above contain many specifics, these should not be construed as limiting the scope of the invention but as merely providing illustrations of some of the preferred embodiments of this invention. For example, the physical layout, cable type, connectors, packaging, and location of the video display or video camera can all be altered without affecting the basic elements of the claimed embodiments. Further, bit ordering can be altered and the same relative operation, relative performance, and relative perceived image quality will result. Also, these processes can each be implemented as a hardware apparatus that will improve the performance significantly.
- Thus the scope of the invention should be determined by the appended claims and their legal equivalents, and not solely by the examples given.
Claims (26)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/823,493 US20070247515A1 (en) | 1998-12-21 | 2007-06-27 | Handheld video transmission and display |
US12/157,292 US20080250459A1 (en) | 1998-12-21 | 2008-06-07 | Handheld wireless video receiver |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11305198P | 1998-12-21 | 1998-12-21 | |
US09/467,721 US7233619B1 (en) | 1998-12-21 | 1999-12-20 | Variable general purpose compression for video images (ZLN) |
US11/262,106 US8290034B2 (en) | 1998-12-21 | 2005-10-27 | Video transmission and display including bit-wise sub-sampling video compression |
US11/823,493 US20070247515A1 (en) | 1998-12-21 | 2007-06-27 | Handheld video transmission and display |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/262,106 Continuation US8290034B2 (en) | 1998-12-21 | 2005-10-27 | Video transmission and display including bit-wise sub-sampling video compression |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/157,292 Continuation US20080250459A1 (en) | 1998-12-21 | 2008-06-07 | Handheld wireless video receiver |
Publications (1)
Publication Number | Publication Date |
---|---|
US20070247515A1 true US20070247515A1 (en) | 2007-10-25 |
Family
ID=38619094
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/262,106 Expired - Fee Related US8290034B2 (en) | 1998-12-21 | 2005-10-27 | Video transmission and display including bit-wise sub-sampling video compression |
US11/823,493 Abandoned US20070247515A1 (en) | 1998-12-21 | 2007-06-27 | Handheld video transmission and display |
US12/157,292 Abandoned US20080250459A1 (en) | 1998-12-21 | 2008-06-07 | Handheld wireless video receiver |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/262,106 Expired - Fee Related US8290034B2 (en) | 1998-12-21 | 2005-10-27 | Video transmission and display including bit-wise sub-sampling video compression |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/157,292 Abandoned US20080250459A1 (en) | 1998-12-21 | 2008-06-07 | Handheld wireless video receiver |
Country Status (1)
Country | Link |
---|---|
US (3) | US8290034B2 (en) |
Cited By (22)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080267437A1 (en) * | 2007-04-27 | 2008-10-30 | Siemens Audiologische Technik Gmbh | Sound transmission apparatus |
US20090251423A1 (en) * | 2008-04-04 | 2009-10-08 | Lg Electronics Inc. | Mobile terminal using proximity sensor and control method thereof |
US20100022271A1 (en) * | 2008-07-22 | 2010-01-28 | Samsung Electronics Co. Ltd. | Apparatus and method for controlling camera of portable terminal |
US20100211655A1 (en) * | 2007-10-26 | 2010-08-19 | Soren Borup Jensen | Assembly comprising a handheld device |
US20100299703A1 (en) * | 2008-01-23 | 2010-11-25 | Liveu Ltd. | Live Uplink Transmissions And Broadcasting Management System And Method |
US20110018961A1 (en) * | 2009-07-24 | 2011-01-27 | Huboro Co., Ltd. | Video call device and method |
US20110115976A1 (en) * | 2006-09-26 | 2011-05-19 | Ohayon Rony Haim | Remote transmission system |
US20110316964A1 (en) * | 2010-06-28 | 2011-12-29 | Yosuke Nakanishi | Wireless communication device |
US20120173622A1 (en) * | 2011-01-04 | 2012-07-05 | Samsung Electronics Co., Ltd. | Social screen casting |
US8787966B2 (en) | 2012-05-17 | 2014-07-22 | Liveu Ltd. | Multi-modem communication using virtual identity modules |
EP2945416A1 (en) | 2014-05-13 | 2015-11-18 | Cellxion Limited | Method and apparatus for transmission of data over a plurality of networks |
US9338650B2 (en) | 2013-03-14 | 2016-05-10 | Liveu Ltd. | Apparatus for cooperating with a mobile device |
US9369921B2 (en) | 2013-05-31 | 2016-06-14 | Liveu Ltd. | Network assisted bonding |
US9379756B2 (en) | 2012-05-17 | 2016-06-28 | Liveu Ltd. | Multi-modem communication using virtual identity modules |
US9476731B1 (en) * | 2014-01-22 | 2016-10-25 | Flight Plan LLC | Apparatus and methods for accessing an atlas application and a computer readable medium having the atlas application stored thereon and executable by the apparatus |
US9742975B2 (en) | 2010-09-13 | 2017-08-22 | Contour Ip Holding, Llc | Portable digital video camera configured for remote image acquisition control and viewing |
US9980171B2 (en) | 2013-03-14 | 2018-05-22 | Liveu Ltd. | Apparatus for cooperating with a mobile device |
US20180160140A1 (en) * | 2016-12-06 | 2018-06-07 | Hitachi, Ltd. | Arithmetic unit, transmission program, and transmission method |
US10986029B2 (en) | 2014-09-08 | 2021-04-20 | Liveu Ltd. | Device, system, and method of data transport with selective utilization of a single link or multiple links |
US11088947B2 (en) | 2017-05-04 | 2021-08-10 | Liveu Ltd | Device, system, and method of pre-processing and data delivery for multi-link communications and for media content |
US11342001B2 (en) * | 2020-01-10 | 2022-05-24 | Nokia Technologies Oy | Audio and video processing |
US11873005B2 (en) | 2017-05-18 | 2024-01-16 | Driveu Tech Ltd. | Device, system, and method of wireless multiple-link vehicular communication |
Families Citing this family (118)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7472353B1 (en) * | 1999-12-16 | 2008-12-30 | Ricoh Co., Ltd. | Remote console for network application servers |
US10915296B2 (en) * | 2000-11-01 | 2021-02-09 | Flexiworld Technologies, Inc. | Information apparatus that includes a touch sensitive screen interface for managing or replying to e-mails |
US9836257B2 (en) | 2001-01-19 | 2017-12-05 | Flexiworld Technologies, Inc. | Mobile information apparatus that includes intelligent wireless display, wireless direct display, or transfer of digital content for playing over air the digital content at smart televisions, television controllers, or audio output devices |
US11204729B2 (en) | 2000-11-01 | 2021-12-21 | Flexiworld Technologies, Inc. | Internet based digital content services for pervasively providing protected digital content to smart devices based on having subscribed to the digital content service |
US10860290B2 (en) * | 2000-11-01 | 2020-12-08 | Flexiworld Technologies, Inc. | Mobile information apparatuses that include a digital camera, a touch sensitive screen interface, support for voice activated commands, and a wireless communication chip or chipset supporting IEEE 802.11 |
US6947995B2 (en) | 2000-11-20 | 2005-09-20 | Flexiworld Technologies, Inc. | Mobile and pervasive output server |
US20030017846A1 (en) * | 2001-06-12 | 2003-01-23 | Estevez Leonardo W. | Wireless display |
US8301503B2 (en) * | 2001-07-17 | 2012-10-30 | Incucomm, Inc. | System and method for providing requested information to thin clients |
US7466992B1 (en) | 2001-10-18 | 2008-12-16 | Iwao Fujisaki | Communication device |
US7107081B1 (en) | 2001-10-18 | 2006-09-12 | Iwao Fujisaki | Communication device |
US7127271B1 (en) | 2001-10-18 | 2006-10-24 | Iwao Fujisaki | Communication device |
US8229512B1 (en) | 2003-02-08 | 2012-07-24 | Iwao Fujisaki | Communication device |
US8241128B1 (en) | 2003-04-03 | 2012-08-14 | Iwao Fujisaki | Communication device |
US20040252965A1 (en) * | 2003-06-10 | 2004-12-16 | Rafael Moreno | Portable video storage and playback device |
US20040252966A1 (en) * | 2003-06-10 | 2004-12-16 | Holloway Marty M. | Video storage and playback system and method |
US8090402B1 (en) | 2003-09-26 | 2012-01-03 | Iwao Fujisaki | Communication device |
US7917167B1 (en) | 2003-11-22 | 2011-03-29 | Iwao Fujisaki | Communication device |
US8041348B1 (en) | 2004-03-23 | 2011-10-18 | Iwao Fujisaki | Communication device |
US8434116B2 (en) | 2004-12-01 | 2013-04-30 | At&T Intellectual Property I, L.P. | Device, system, and method for managing television tuners |
US7734548B2 (en) * | 2004-12-06 | 2010-06-08 | At&T Intellectual Property, I,L.P. | Methods, systems, and products for providing electronic media |
US8208954B1 (en) | 2005-04-08 | 2012-06-26 | Iwao Fujisaki | Communication device |
KR100630149B1 (en) * | 2005-06-07 | 2006-10-02 | 삼성전자주식회사 | Method for zooming of picture in wireless terminal |
US7908627B2 (en) | 2005-06-22 | 2011-03-15 | At&T Intellectual Property I, L.P. | System and method to provide a unified video signal for diverse receiving platforms |
US7792528B2 (en) | 2005-06-24 | 2010-09-07 | Aylus Networks, Inc. | Method and system for provisioning IMS networks with virtual service organizations having distinct service logic |
US20060291412A1 (en) | 2005-06-24 | 2006-12-28 | Naqvi Shamim A | Associated device discovery in IMS networks |
US7561535B2 (en) * | 2005-06-24 | 2009-07-14 | Aylus Networks, Inc. | System and method for providing dynamic call models for users as function of the user environment in an IMS network |
US7672297B2 (en) * | 2005-06-24 | 2010-03-02 | Aylus Networks, Inc. | Mediation system and method for hybrid network including an IMS network |
US7864936B2 (en) * | 2005-06-24 | 2011-01-04 | Aylus Networks, Inc. | Method of avoiding or minimizing cost of stateful connections between application servers and S-CSCF nodes in an IMS network with multiple domains |
US7724753B2 (en) * | 2005-06-24 | 2010-05-25 | Aylus Networks, Inc. | Digital home networks having a control point located on a wide area network |
US20060291487A1 (en) * | 2005-06-24 | 2006-12-28 | Aylus Networks, Inc. | IMS networks with AVS sessions with multiple access networks |
US7379664B2 (en) * | 2005-07-26 | 2008-05-27 | Tinkers & Chance | Remote view and controller for a camera |
US8977636B2 (en) | 2005-08-19 | 2015-03-10 | International Business Machines Corporation | Synthesizing aggregate data of disparate data types into data of a uniform data type |
US8266220B2 (en) | 2005-09-14 | 2012-09-11 | International Business Machines Corporation | Email management and rendering |
US8694319B2 (en) | 2005-11-03 | 2014-04-08 | International Business Machines Corporation | Dynamic prosody adjustment for voice-rendering synthesized data |
FR2893810B1 (en) * | 2005-11-23 | 2008-02-01 | Ercom Engineering Reseaux Comm | METHOD FOR TESTING A COMMUNICATION NETWORK OVER A TERMINAL |
US20070143307A1 (en) * | 2005-12-15 | 2007-06-21 | Bowers Matthew N | Communication system employing a context engine |
US8352323B2 (en) | 2007-11-30 | 2013-01-08 | Blaze Mobile, Inc. | Conducting an online payment transaction using an NFC enabled mobile communication device |
US8693995B2 (en) | 2007-12-13 | 2014-04-08 | Michelle Fisher | Customized mobile applications for special interest groups |
US8271107B2 (en) | 2006-01-13 | 2012-09-18 | International Business Machines Corporation | Controlling audio operation for data management and data rendering |
US9135339B2 (en) | 2006-02-13 | 2015-09-15 | International Business Machines Corporation | Invoking an audio hyperlink |
US7505978B2 (en) * | 2006-02-13 | 2009-03-17 | International Business Machines Corporation | Aggregating content of disparate data types from disparate data sources for single point access |
US7996754B2 (en) * | 2006-02-13 | 2011-08-09 | International Business Machines Corporation | Consolidated content management |
EP1830361A1 (en) * | 2006-03-02 | 2007-09-05 | Sony Corporation | Image displaying method and video playback apparatus |
US9092542B2 (en) * | 2006-03-09 | 2015-07-28 | International Business Machines Corporation | Podcasting content associated with a user account |
US9361299B2 (en) | 2006-03-09 | 2016-06-07 | International Business Machines Corporation | RSS content administration for rendering RSS content on a digital audio player |
US8510277B2 (en) * | 2006-03-09 | 2013-08-13 | International Business Machines Corporation | Informing a user of a content management directive associated with a rating |
US8849895B2 (en) * | 2006-03-09 | 2014-09-30 | International Business Machines Corporation | Associating user selected content management directives with user selected ratings |
EP2004197A4 (en) * | 2006-03-31 | 2009-08-19 | Univ North Carolina State | Light activated antiviral materials and devices and methods for decontaminating virus infected environments |
US9026117B2 (en) | 2006-05-16 | 2015-05-05 | Aylus Networks, Inc. | Systems and methods for real-time cellular-to-internet video transfer |
US8730945B2 (en) * | 2006-05-16 | 2014-05-20 | Aylus Networks, Inc. | Systems and methods for using a recipient handset as a remote screen |
US8611334B2 (en) * | 2006-05-16 | 2013-12-17 | Aylus Networks, Inc. | Systems and methods for presenting multimedia objects in conjunction with voice calls from a circuit-switched network |
US8432899B2 (en) * | 2007-02-22 | 2013-04-30 | Aylus Networks, Inc. | Systems and methods for enabling IP signaling in wireless networks |
US20070277088A1 (en) * | 2006-05-24 | 2007-11-29 | Bodin William K | Enhancing an existing web page |
US8286229B2 (en) * | 2006-05-24 | 2012-10-09 | International Business Machines Corporation | Token-based content subscription |
US9030968B2 (en) * | 2006-06-16 | 2015-05-12 | Alcatel Lucent | System and method for processing a conference session through a communication channel |
US20080117966A1 (en) * | 2006-08-10 | 2008-05-22 | Topiwala Pankaj N | Method and compact apparatus for video capture and transmission with a common interface |
US9196241B2 (en) * | 2006-09-29 | 2015-11-24 | International Business Machines Corporation | Asynchronous communications using messages recorded on handheld devices |
US20080092172A1 (en) * | 2006-09-29 | 2008-04-17 | Guo Katherine H | Method and apparatus for a zooming feature for mobile video service |
US20080088440A1 (en) * | 2006-10-17 | 2008-04-17 | Simon Palushaj | Wireless remote assistance |
US20080161686A1 (en) * | 2006-10-31 | 2008-07-03 | Nahi Halmann | Methods and apparatus for controlling handheld medical devices |
CN101202906A (en) * | 2006-12-11 | 2008-06-18 | 国际商业机器公司 | Method and equipment for processing video stream in digital video broadcast system |
US9318100B2 (en) * | 2007-01-03 | 2016-04-19 | International Business Machines Corporation | Supplementing audio recorded in a media file |
US8219402B2 (en) | 2007-01-03 | 2012-07-10 | International Business Machines Corporation | Asynchronous receipt of information from a user |
CN101689357B (en) | 2007-04-11 | 2015-03-04 | Red.Com公司 | Video camera |
US8237830B2 (en) | 2007-04-11 | 2012-08-07 | Red.Com, Inc. | Video camera |
US20080320538A1 (en) * | 2007-04-16 | 2008-12-25 | Gad Liwerant | Methods and systems for transmitting and accessing video data |
CA2684481A1 (en) * | 2007-04-17 | 2008-10-30 | Aylus Networks, Inc. | Systems and methods for real-time cellular-to-internet video transfer |
US7856226B2 (en) * | 2007-04-17 | 2010-12-21 | Aylus Networks, Inc. | Systems and methods for IMS user sessions with dynamic service selection |
US7890089B1 (en) | 2007-05-03 | 2011-02-15 | Iwao Fujisaki | Communication device |
US20080291260A1 (en) * | 2007-05-24 | 2008-11-27 | John Dignan | Portable video conferencing device |
US20080317010A1 (en) * | 2007-06-22 | 2008-12-25 | Aylus Networks, Inc. | System and method for signaling optimization in ims services by using a service delivery platform |
KR101405933B1 (en) * | 2007-07-12 | 2014-06-12 | 엘지전자 주식회사 | Portable terminal and method for displaying position information in the portable terminal |
JP2009033015A (en) * | 2007-07-30 | 2009-02-12 | Fujifilm Corp | Solid-state image pickup device and image pickup apparatus |
US8676273B1 (en) | 2007-08-24 | 2014-03-18 | Iwao Fujisaki | Communication device |
US7711864B2 (en) * | 2007-08-31 | 2010-05-04 | Apple Inc. | Methods and systems to dynamically manage performance states in a data processing system |
US20090091649A1 (en) * | 2007-10-05 | 2009-04-09 | Anderson Leroy E | Electronic document viewer |
US8639214B1 (en) | 2007-10-26 | 2014-01-28 | Iwao Fujisaki | Communication device |
US20090154570A1 (en) * | 2007-11-19 | 2009-06-18 | Avot Media, Inc. | Method and system to stream and render video data on processing units of mobile devices that have limited threading capabilities |
US9204111B2 (en) * | 2008-03-10 | 2015-12-01 | Eomax Corporation | Modular imaging system with wireless transmission and locking connector |
EP2101497A1 (en) * | 2008-03-12 | 2009-09-16 | Thomson Licensing | Method and apparatus for transmitting an image in a wireless network |
US8543157B1 (en) | 2008-05-09 | 2013-09-24 | Iwao Fujisaki | Communication device which notifies its pin-point location or geographic area in accordance with user selection |
US10831093B1 (en) * | 2008-05-19 | 2020-11-10 | Spatial Cam Llc | Focus control for a plurality of cameras in a smartphone |
US20110098083A1 (en) * | 2008-05-19 | 2011-04-28 | Peter Lablans | Large, Ultra-Thin And Ultra-Light Connectable Display For A Computing Device |
US8359068B1 (en) * | 2008-06-27 | 2013-01-22 | Cisco Technology, Inc. | Cellphone video imaging |
US8340726B1 (en) | 2008-06-30 | 2012-12-25 | Iwao Fujisaki | Communication device |
US8452307B1 (en) | 2008-07-02 | 2013-05-28 | Iwao Fujisaki | Communication device |
US8682848B2 (en) * | 2008-07-08 | 2014-03-25 | Broadcom Corporation | Method and system for automatic detection of multimedia settings |
US8290427B2 (en) * | 2008-07-16 | 2012-10-16 | Centurylink Intellectual Property Llc | System and method for providing wireless security surveillance services accessible via a telecommunications device |
KR20100041108A (en) * | 2008-10-13 | 2010-04-22 | 삼성전자주식회사 | Moving picture continuous capturing method using udta information and portable device supporting the same |
US20110161514A1 (en) * | 2009-12-29 | 2011-06-30 | Nokia Corporation | Method and apparatus for delegating computationally intensive functions |
US8908774B2 (en) * | 2010-02-11 | 2014-12-09 | Mediatek Inc. | Method and video receiving system for adaptively decoding embedded video bitstream |
US10285656B2 (en) * | 2010-10-18 | 2019-05-14 | Carestream Health, Inc. | X-ray imaging system and method |
US8650604B2 (en) | 2010-10-27 | 2014-02-11 | Samsung Electronics Co., Ltd. | Method and system for synchronization of audio/video (A/V) stream format change in wireless communication systems |
FR2986931A1 (en) * | 2012-02-10 | 2013-08-16 | Damien Guerin | Method for transmitting audio-visual content produced during surgical operation, involves reproducing audio-visual output stream at terminal of requesting user, where transmission and reproduction of output stream takes place in real-time |
US8965172B2 (en) * | 2012-04-06 | 2015-02-24 | Realtek Semiconductor Inc. | Multi-screen video playback system and related computer program product for dynamically generating scaled video |
WO2014014238A1 (en) * | 2012-07-17 | 2014-01-23 | Samsung Electronics Co., Ltd. | System and method for providing image |
KR102091137B1 (en) * | 2012-07-17 | 2020-03-20 | 삼성전자주식회사 | System and method for rpoviding image |
US9222613B2 (en) | 2012-08-22 | 2015-12-29 | Atmos Energy Corporation | Remote camera and adapter therefor |
TW201424380A (en) | 2012-12-07 | 2014-06-16 | Ind Tech Res Inst | Coding system, coding method, decoding system and decoding method for image and message |
US10021431B2 (en) | 2013-01-04 | 2018-07-10 | Omnivision Technologies, Inc. | Mobile computing device having video-in-video real-time broadcasting capability |
US9131284B2 (en) | 2013-01-04 | 2015-09-08 | Omnivision Technologies, Inc. | Video-in-video video stream having a three layer video scene |
JP2016508700A (en) | 2013-02-14 | 2016-03-22 | レッド.コム,インコーポレイテッド | Video camera |
RU2531466C1 (en) * | 2013-08-26 | 2014-10-20 | Борис Иванович Волков | Universal television system |
KR102249819B1 (en) * | 2014-05-02 | 2021-05-10 | 삼성전자주식회사 | System on chip and data processing system including the same |
US20150350565A1 (en) * | 2014-05-29 | 2015-12-03 | Opentv, Inc. | Techniques for magnifying a high resolution image |
US10334276B2 (en) * | 2015-12-28 | 2019-06-25 | Ati Technologies Ulc | Method and apparatus for determining the severity of corruption in a picture |
KR102620350B1 (en) | 2017-07-05 | 2024-01-02 | 레드.컴, 엘엘씨 | Video image data processing in electronic devices |
GB2567427B (en) * | 2017-10-06 | 2020-10-07 | Imagination Tech Ltd | Data compression |
CN108174272B (en) * | 2017-12-29 | 2021-01-22 | 广州虎牙信息科技有限公司 | Method and device for displaying interactive information in live broadcast, storage medium and electronic equipment |
US11151748B2 (en) * | 2018-07-13 | 2021-10-19 | Electronics And Telecommunications Research Institute | 3D point cloud data encoding/decoding method and apparatus |
US11218632B2 (en) * | 2019-11-01 | 2022-01-04 | Qualcomm Incorporated | Retractable panoramic camera module |
WO2021218921A1 (en) * | 2020-04-27 | 2021-11-04 | Guangdong Oppo Mobile Telecommunications Corp., Ltd. | System and method for extraction of a video thumbnail from a video file |
CN111836104B (en) * | 2020-07-09 | 2022-01-28 | 海信视像科技股份有限公司 | Display apparatus and display method |
CN112135008A (en) * | 2020-10-16 | 2020-12-25 | 深圳市中江天华科技有限公司 | Zynq FPGA-based low-illumination handheld terminal and system thereof |
CN114726480B (en) * | 2022-03-08 | 2023-07-25 | 科大讯飞股份有限公司 | Data encoding method and related device, electronic equipment and storage medium |
CN115100581B (en) * | 2022-08-24 | 2022-12-20 | 有米科技股份有限公司 | Video reconstruction model training method and device based on text assistance |
CN116095262B (en) * | 2023-04-11 | 2023-08-22 | 北京仁光科技有限公司 | Mobile processing device, processing method and system for processing video signal source |
CN116600042B (en) * | 2023-07-17 | 2023-09-22 | 中国人民解放军国防科技大学 | Communication method, device and system between intelligent mobile terminal equipment and computer |
Citations (50)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4301469A (en) * | 1980-04-30 | 1981-11-17 | United Technologies Corporation | Run length encoder for color raster scanner |
US4302775A (en) * | 1978-12-15 | 1981-11-24 | Compression Labs, Inc. | Digital video compression system and methods utilizing scene adaptive coding with rate buffer feedback |
US4385363A (en) * | 1978-12-15 | 1983-05-24 | Compression Labs, Inc. | Discrete cosine transformer |
US4394774A (en) * | 1978-12-15 | 1983-07-19 | Compression Labs, Inc. | Digital video compression system and methods utilizing scene adaptive coding with rate buffer feedback |
US4410916A (en) * | 1979-08-24 | 1983-10-18 | Compression Labs, Inc. | Dual mode facsimile coding system and method |
US4546385A (en) * | 1983-06-30 | 1985-10-08 | International Business Machines Corporation | Data compression method for graphics images |
US4550437A (en) * | 1981-06-19 | 1985-10-29 | Hitachi, Ltd. | Apparatus for parallel processing of local image data |
US4646356A (en) * | 1984-06-29 | 1987-02-24 | International Business Machines Corporation | Method for converting a bit map of an image to a run length or run end representation |
US4698672A (en) * | 1986-10-27 | 1987-10-06 | Compression Labs, Inc. | Coding system for reducing redundancy |
US4704628A (en) * | 1986-07-16 | 1987-11-03 | Compression Labs, Inc. | Combined intraframe and interframe transform coding system |
US4743959A (en) * | 1986-09-17 | 1988-05-10 | Frederiksen Jeffrey E | High resolution color video image acquisition and compression system |
US5014710A (en) * | 1988-09-13 | 1991-05-14 | Acuson Corporation | Steered linear color doppler imaging |
US5046027A (en) * | 1988-11-08 | 1991-09-03 | Massachusetts General Hospital | Apparatus and method for processing and displaying images in a digital procesor based system |
US5047853A (en) * | 1990-03-16 | 1991-09-10 | Apple Computer, Inc. | Method for compresssing and decompressing color video data that uses luminance partitioning |
US5271072A (en) * | 1989-06-30 | 1993-12-14 | Canon Kabushiki Kaisha | Image reduction of binary images using filtering processing |
US5287452A (en) * | 1990-03-23 | 1994-02-15 | Eastman Kodak Company | Bus caching computer display system |
US5309232A (en) * | 1992-02-07 | 1994-05-03 | At&T Bell Laboratories | Dynamic bit allocation for three-dimensional subband video coding |
US5339392A (en) * | 1989-07-27 | 1994-08-16 | Risberg Jeffrey S | Apparatus and method for creation of a user definable video displayed document showing changes in real time data |
US5416602A (en) * | 1992-07-20 | 1995-05-16 | Automated Medical Access Corp. | Medical image system with progressive resolution |
US5471989A (en) * | 1994-10-12 | 1995-12-05 | Advanced Technology Laboratories, Inc. | Ultrasonic diagnostic imaging with enhanced zoom |
US5552832A (en) * | 1994-10-26 | 1996-09-03 | Intel Corporation | Run-length encoding sequence for video signals |
US5581613A (en) * | 1992-01-07 | 1996-12-03 | Canon Kabushiki Kaisha | Color image processing apparatus and method |
US5583561A (en) * | 1994-06-07 | 1996-12-10 | Unisys Corporation | Multi-cast digital video data server using synchronization groups |
US5619995A (en) * | 1991-11-12 | 1997-04-15 | Lobodzinski; Suave M. | Motion video transformation system and method |
US5621660A (en) * | 1995-04-18 | 1997-04-15 | Sun Microsystems, Inc. | Software-based encoder for a software-implemented end-to-end scalable video delivery system |
US5646618A (en) * | 1995-11-13 | 1997-07-08 | Intel Corporation | Decoding one or more variable-length encoded signals using a single table lookup |
US5684968A (en) * | 1995-06-16 | 1997-11-04 | International Business Machines Corporation | Method and apparatus for processing multiple images concurrently |
US5696940A (en) * | 1995-09-29 | 1997-12-09 | Intel Corporation | Apparatus and method for sharing first-in first-out memory space between two streams of data |
US5715823A (en) * | 1996-02-27 | 1998-02-10 | Atlantis Diagnostics International, L.L.C. | Ultrasonic diagnostic imaging system with universal access to diagnostic information and images |
US5721815A (en) * | 1995-06-07 | 1998-02-24 | International Business Machines Corporation | Media-on-demand communication system and method employing direct access storage device |
US5754820A (en) * | 1991-07-09 | 1998-05-19 | Kabushiki Kaisha Toshiba | Microprocessor system with cache memory for eliminating unnecessary invalidation of cache data |
US5794072A (en) * | 1996-05-23 | 1998-08-11 | Vlsi Technology, Inc. | Timing method and apparatus for interleaving PIO and DMA data transfers |
US5809145A (en) * | 1996-06-28 | 1998-09-15 | Paradata Systems Inc. | System for distributing digital information |
US5812788A (en) * | 1995-07-21 | 1998-09-22 | Intel Corporation | Encoding/decoding video signals using quantization tables based on explicitly encoded base and scale matrices |
US5812119A (en) * | 1992-10-09 | 1998-09-22 | Hudson Soft Co., Ltd. | Image processing system and method for formatting compressed image data |
US5828856A (en) * | 1994-01-28 | 1998-10-27 | Apple Computer, Inc. | Dual bus concurrent multi-channel direct memory access controller and method |
US5860068A (en) * | 1997-12-04 | 1999-01-12 | Petabyte Corporation | Method and system for custom manufacture and delivery of a data product |
US5882206A (en) * | 1995-03-29 | 1999-03-16 | Gillio; Robert G. | Virtual surgery system |
US5897498A (en) * | 1996-09-25 | 1999-04-27 | Atl Ultrasound, Inc. | Ultrasonic diagnostic imaging system with electronic message communications capability |
US5920317A (en) * | 1996-06-11 | 1999-07-06 | Vmi Technologies Incorporated | System and method for storing and displaying ultrasound images |
US5959639A (en) * | 1996-03-08 | 1999-09-28 | Mitsubishi Denki Kabushiki Kaisha | Computer graphics apparatus utilizing cache memory |
US5966728A (en) * | 1992-01-02 | 1999-10-12 | International Business Machines Corp. | Computer system and method for snooping date writes to cacheable memory locations in an expansion memory device |
US5973750A (en) * | 1996-05-11 | 1999-10-26 | K.K. Video Research | Television channel selection monitoring apparatus |
US5999655A (en) * | 1996-07-11 | 1999-12-07 | U.S. Philips Corporation | Method and apparatus for transmission of video pictures which are segmented to form maps of picture blocks of variable block sizes |
US6005979A (en) * | 1997-01-13 | 1999-12-21 | Hewlett-Packard Co. | System of data compression by subsampling, and preferably adaptive trim accounting, for sending images to a printer |
US6009346A (en) * | 1998-01-02 | 1999-12-28 | Electromagnetic Bracing Systems, Inc. | Automated transdermal drug delivery system |
US6018713A (en) * | 1997-04-09 | 2000-01-25 | Coli; Robert D. | Integrated system and method for ordering and cumulative results reporting of medical tests |
US6025854A (en) * | 1997-12-31 | 2000-02-15 | Cognex Corporation | Method and apparatus for high speed image acquisition |
US6054990A (en) * | 1996-07-05 | 2000-04-25 | Tran; Bao Q. | Computer system with handwriting annotation |
US6058215A (en) * | 1997-04-30 | 2000-05-02 | Ricoh Company, Ltd. | Reversible DCT for lossless-lossy compression |
Family Cites Families (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
AU656401B2 (en) * | 1991-04-24 | 1995-02-02 | Michael Sussman | Digital document magnifier |
US6592629B1 (en) | 1996-11-21 | 2003-07-15 | Ricoh Company, Ltd. | Remote document image storage and retrieval system for a multifunctional peripheral |
NL1005084C2 (en) | 1997-01-24 | 1998-07-27 | Oce Tech Bv | A method for performing an image editing operation on run-length encoded bitmaps. |
US6384862B1 (en) | 1997-03-12 | 2002-05-07 | Telefoaktiebolaget L M Ericsson | Imaging system and method for interactive control of image quality |
US6339616B1 (en) | 1997-05-30 | 2002-01-15 | Alaris, Inc. | Method and apparatus for compression and decompression of still and motion video data based on adaptive pixel-by-pixel processing and adaptive variable length coding |
US6064324A (en) | 1997-06-18 | 2000-05-16 | Nippon Telegraph And Telephone Corporation | Digital signal encoding and decoding method and apparatus without transmitting information on quantization width |
US6181711B1 (en) | 1997-06-26 | 2001-01-30 | Cisco Systems, Inc. | System and method for transporting a compressed video and data bit stream over a communication channel |
US6335990B1 (en) | 1997-07-03 | 2002-01-01 | Cisco Technology, Inc. | System and method for spatial temporal-filtering for improving compressed digital video |
KR100323441B1 (en) | 1997-08-20 | 2002-06-20 | 윤종용 | Mpeg2 motion picture coding/decoding system |
US6091777A (en) | 1997-09-18 | 2000-07-18 | Cubic Video Technologies, Inc. | Continuously adaptive digital video compression system and method for a web streamer |
US6115485A (en) | 1997-10-06 | 2000-09-05 | General Electric Company | Introducing reduced data set information into a primary image data set |
US6904174B1 (en) | 1998-12-11 | 2005-06-07 | Intel Corporation | Simplified predictive video encoder |
US6084598A (en) | 1998-04-23 | 2000-07-04 | Chekerylla; James | Apparatus for modifying graphic images |
US6144392A (en) | 1998-04-30 | 2000-11-07 | Ati Technologies, Inc. | Method and apparatus for formatting a texture in a frame buffer |
WO1999059472A1 (en) | 1998-05-18 | 1999-11-25 | Intracom Corporation | System for transmitting video images over a computer network to a remote receiver |
US7257158B1 (en) | 1998-05-18 | 2007-08-14 | Kendyl A. Román | System for transmitting video images over a computer network to a remote receiver |
US6230241B1 (en) | 1998-09-09 | 2001-05-08 | Cisco Technology, Inc. | Apparatus and method for transferring data in a data communications device |
US6219358B1 (en) | 1998-09-11 | 2001-04-17 | Scientific-Atlanta, Inc. | Adaptive rate control for insertion of data into arbitrary bit rate data streams |
US6063032A (en) | 1998-09-28 | 2000-05-16 | Scimed Systems, Inc. | Ultrasound imaging with zoom having independent processing channels |
US7016417B1 (en) | 1998-12-23 | 2006-03-21 | Kendyl A. Roman | General purpose compression for video images (RHN) |
US6324599B1 (en) | 1999-01-11 | 2001-11-27 | Oak Technology | Computer system and method for tracking DMA transferred data within a read-ahead local buffer without interrupting the host processor |
JP2000268111A (en) | 1999-03-17 | 2000-09-29 | Patent & License Exchange Inc | Online transaction system and method for patent and license |
US6338119B1 (en) | 1999-03-31 | 2002-01-08 | International Business Machines Corporation | Method and apparatus with page buffer and I/O page kill definition for improved DMA and L1/L2 cache performance |
US6571392B1 (en) | 1999-04-20 | 2003-05-27 | Webtv Networks, Inc. | Receiving an information resource from the internet if it is not received from a broadcast channel |
US7308413B1 (en) | 1999-05-05 | 2007-12-11 | Tota Michael J | Process for creating media content based upon submissions received on an electronic multi-media exchange |
US8004572B2 (en) | 1999-05-17 | 2011-08-23 | Zin Stai Pte. In, Llc | System for transmitting a video stream over a computer network to a remote receiver |
US6651113B1 (en) | 1999-12-22 | 2003-11-18 | Intel Corporation | System for writing data on an optical storage medium without interruption using a local write buffer |
US6894702B2 (en) * | 2002-06-06 | 2005-05-17 | Microsoft Corporation | Dropout control in subpixel rendering |
-
2005
- 2005-10-27 US US11/262,106 patent/US8290034B2/en not_active Expired - Fee Related
-
2007
- 2007-06-27 US US11/823,493 patent/US20070247515A1/en not_active Abandoned
-
2008
- 2008-06-07 US US12/157,292 patent/US20080250459A1/en not_active Abandoned
Patent Citations (50)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4302775A (en) * | 1978-12-15 | 1981-11-24 | Compression Labs, Inc. | Digital video compression system and methods utilizing scene adaptive coding with rate buffer feedback |
US4385363A (en) * | 1978-12-15 | 1983-05-24 | Compression Labs, Inc. | Discrete cosine transformer |
US4394774A (en) * | 1978-12-15 | 1983-07-19 | Compression Labs, Inc. | Digital video compression system and methods utilizing scene adaptive coding with rate buffer feedback |
US4410916A (en) * | 1979-08-24 | 1983-10-18 | Compression Labs, Inc. | Dual mode facsimile coding system and method |
US4301469A (en) * | 1980-04-30 | 1981-11-17 | United Technologies Corporation | Run length encoder for color raster scanner |
US4550437A (en) * | 1981-06-19 | 1985-10-29 | Hitachi, Ltd. | Apparatus for parallel processing of local image data |
US4546385A (en) * | 1983-06-30 | 1985-10-08 | International Business Machines Corporation | Data compression method for graphics images |
US4646356A (en) * | 1984-06-29 | 1987-02-24 | International Business Machines Corporation | Method for converting a bit map of an image to a run length or run end representation |
US4704628A (en) * | 1986-07-16 | 1987-11-03 | Compression Labs, Inc. | Combined intraframe and interframe transform coding system |
US4743959A (en) * | 1986-09-17 | 1988-05-10 | Frederiksen Jeffrey E | High resolution color video image acquisition and compression system |
US4698672A (en) * | 1986-10-27 | 1987-10-06 | Compression Labs, Inc. | Coding system for reducing redundancy |
US5014710A (en) * | 1988-09-13 | 1991-05-14 | Acuson Corporation | Steered linear color doppler imaging |
US5046027A (en) * | 1988-11-08 | 1991-09-03 | Massachusetts General Hospital | Apparatus and method for processing and displaying images in a digital procesor based system |
US5271072A (en) * | 1989-06-30 | 1993-12-14 | Canon Kabushiki Kaisha | Image reduction of binary images using filtering processing |
US5339392A (en) * | 1989-07-27 | 1994-08-16 | Risberg Jeffrey S | Apparatus and method for creation of a user definable video displayed document showing changes in real time data |
US5047853A (en) * | 1990-03-16 | 1991-09-10 | Apple Computer, Inc. | Method for compresssing and decompressing color video data that uses luminance partitioning |
US5287452A (en) * | 1990-03-23 | 1994-02-15 | Eastman Kodak Company | Bus caching computer display system |
US5754820A (en) * | 1991-07-09 | 1998-05-19 | Kabushiki Kaisha Toshiba | Microprocessor system with cache memory for eliminating unnecessary invalidation of cache data |
US5619995A (en) * | 1991-11-12 | 1997-04-15 | Lobodzinski; Suave M. | Motion video transformation system and method |
US5966728A (en) * | 1992-01-02 | 1999-10-12 | International Business Machines Corp. | Computer system and method for snooping date writes to cacheable memory locations in an expansion memory device |
US5581613A (en) * | 1992-01-07 | 1996-12-03 | Canon Kabushiki Kaisha | Color image processing apparatus and method |
US5309232A (en) * | 1992-02-07 | 1994-05-03 | At&T Bell Laboratories | Dynamic bit allocation for three-dimensional subband video coding |
US5416602A (en) * | 1992-07-20 | 1995-05-16 | Automated Medical Access Corp. | Medical image system with progressive resolution |
US5812119A (en) * | 1992-10-09 | 1998-09-22 | Hudson Soft Co., Ltd. | Image processing system and method for formatting compressed image data |
US5828856A (en) * | 1994-01-28 | 1998-10-27 | Apple Computer, Inc. | Dual bus concurrent multi-channel direct memory access controller and method |
US5583561A (en) * | 1994-06-07 | 1996-12-10 | Unisys Corporation | Multi-cast digital video data server using synchronization groups |
US5471989A (en) * | 1994-10-12 | 1995-12-05 | Advanced Technology Laboratories, Inc. | Ultrasonic diagnostic imaging with enhanced zoom |
US5552832A (en) * | 1994-10-26 | 1996-09-03 | Intel Corporation | Run-length encoding sequence for video signals |
US5882206A (en) * | 1995-03-29 | 1999-03-16 | Gillio; Robert G. | Virtual surgery system |
US5621660A (en) * | 1995-04-18 | 1997-04-15 | Sun Microsystems, Inc. | Software-based encoder for a software-implemented end-to-end scalable video delivery system |
US5721815A (en) * | 1995-06-07 | 1998-02-24 | International Business Machines Corporation | Media-on-demand communication system and method employing direct access storage device |
US5684968A (en) * | 1995-06-16 | 1997-11-04 | International Business Machines Corporation | Method and apparatus for processing multiple images concurrently |
US5812788A (en) * | 1995-07-21 | 1998-09-22 | Intel Corporation | Encoding/decoding video signals using quantization tables based on explicitly encoded base and scale matrices |
US5696940A (en) * | 1995-09-29 | 1997-12-09 | Intel Corporation | Apparatus and method for sharing first-in first-out memory space between two streams of data |
US5646618A (en) * | 1995-11-13 | 1997-07-08 | Intel Corporation | Decoding one or more variable-length encoded signals using a single table lookup |
US5715823A (en) * | 1996-02-27 | 1998-02-10 | Atlantis Diagnostics International, L.L.C. | Ultrasonic diagnostic imaging system with universal access to diagnostic information and images |
US5959639A (en) * | 1996-03-08 | 1999-09-28 | Mitsubishi Denki Kabushiki Kaisha | Computer graphics apparatus utilizing cache memory |
US5973750A (en) * | 1996-05-11 | 1999-10-26 | K.K. Video Research | Television channel selection monitoring apparatus |
US5794072A (en) * | 1996-05-23 | 1998-08-11 | Vlsi Technology, Inc. | Timing method and apparatus for interleaving PIO and DMA data transfers |
US5920317A (en) * | 1996-06-11 | 1999-07-06 | Vmi Technologies Incorporated | System and method for storing and displaying ultrasound images |
US5809145A (en) * | 1996-06-28 | 1998-09-15 | Paradata Systems Inc. | System for distributing digital information |
US6054990A (en) * | 1996-07-05 | 2000-04-25 | Tran; Bao Q. | Computer system with handwriting annotation |
US5999655A (en) * | 1996-07-11 | 1999-12-07 | U.S. Philips Corporation | Method and apparatus for transmission of video pictures which are segmented to form maps of picture blocks of variable block sizes |
US5897498A (en) * | 1996-09-25 | 1999-04-27 | Atl Ultrasound, Inc. | Ultrasonic diagnostic imaging system with electronic message communications capability |
US6005979A (en) * | 1997-01-13 | 1999-12-21 | Hewlett-Packard Co. | System of data compression by subsampling, and preferably adaptive trim accounting, for sending images to a printer |
US6018713A (en) * | 1997-04-09 | 2000-01-25 | Coli; Robert D. | Integrated system and method for ordering and cumulative results reporting of medical tests |
US6058215A (en) * | 1997-04-30 | 2000-05-02 | Ricoh Company, Ltd. | Reversible DCT for lossless-lossy compression |
US5860068A (en) * | 1997-12-04 | 1999-01-12 | Petabyte Corporation | Method and system for custom manufacture and delivery of a data product |
US6025854A (en) * | 1997-12-31 | 2000-02-15 | Cognex Corporation | Method and apparatus for high speed image acquisition |
US6009346A (en) * | 1998-01-02 | 1999-12-28 | Electromagnetic Bracing Systems, Inc. | Automated transdermal drug delivery system |
Cited By (48)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9203498B2 (en) | 2006-09-26 | 2015-12-01 | Liveu Ltd. | Virtual broadband transmitter and virtual broadband receiver |
US8488659B2 (en) | 2006-09-26 | 2013-07-16 | Liveu Ltd. | Remote transmission system |
US9826565B2 (en) | 2006-09-26 | 2017-11-21 | Liveu Ltd. | Broadband transmitter, broadband receiver, and methods thereof |
US8649402B2 (en) | 2006-09-26 | 2014-02-11 | Liveu Ltd. | Virtual broadband receiver and method of receiving data |
US8964646B2 (en) | 2006-09-26 | 2015-02-24 | Liveu Ltd. | Remote transmission system |
US8942179B2 (en) | 2006-09-26 | 2015-01-27 | Liveu Ltd. | Virtual broadband receiver, and system and method utilizing same |
US20110115976A1 (en) * | 2006-09-26 | 2011-05-19 | Ohayon Rony Haim | Remote transmission system |
US7948933B2 (en) | 2006-09-26 | 2011-05-24 | Liveu Ltd. | Remote transmission system |
US8848697B2 (en) | 2006-09-26 | 2014-09-30 | Liveu Ltd. | Remote transmission system |
US8811292B2 (en) | 2006-09-26 | 2014-08-19 | Liveu Ltd. | Remote transmission system |
US9538513B2 (en) | 2006-09-26 | 2017-01-03 | Liveu Ltd. | Virtual broadband transmitter, virtual broadband receiver, and methods thereof |
US8737436B2 (en) | 2006-09-26 | 2014-05-27 | Liveu Ltd. | Remote transmission system |
US8467337B1 (en) | 2006-09-26 | 2013-06-18 | Liveu Ltd. | Remote transmission system |
US20080267437A1 (en) * | 2007-04-27 | 2008-10-30 | Siemens Audiologische Technik Gmbh | Sound transmission apparatus |
US20100211655A1 (en) * | 2007-10-26 | 2010-08-19 | Soren Borup Jensen | Assembly comprising a handheld device |
US20100299703A1 (en) * | 2008-01-23 | 2010-11-25 | Liveu Ltd. | Live Uplink Transmissions And Broadcasting Management System And Method |
US9712267B2 (en) | 2008-01-23 | 2017-07-18 | Liveu Ltd. | Live uplink transmissions and broadcasting management system and method |
US10601533B2 (en) | 2008-01-23 | 2020-03-24 | Liveu Ltd. | Live uplink transmissions and broadcasting management system and method |
US10153854B2 (en) | 2008-01-23 | 2018-12-11 | Liveu Ltd. | Live uplink transmissions and broadcasting management system and method |
US9154247B2 (en) | 2008-01-23 | 2015-10-06 | Liveu Ltd. | Live uplink transmissions and broadcasting management system and method |
US8373666B2 (en) * | 2008-04-04 | 2013-02-12 | Lg Electronics Inc. | Mobile terminal using proximity sensor and control method thereof |
US20090251423A1 (en) * | 2008-04-04 | 2009-10-08 | Lg Electronics Inc. | Mobile terminal using proximity sensor and control method thereof |
US8411128B2 (en) * | 2008-07-22 | 2013-04-02 | Samsung Electronics Co., Ltd. | Apparatus and method for controlling camera of portable terminal |
US20100022271A1 (en) * | 2008-07-22 | 2010-01-28 | Samsung Electronics Co. Ltd. | Apparatus and method for controlling camera of portable terminal |
US20110018961A1 (en) * | 2009-07-24 | 2011-01-27 | Huboro Co., Ltd. | Video call device and method |
US20110316964A1 (en) * | 2010-06-28 | 2011-12-29 | Yosuke Nakanishi | Wireless communication device |
US10356304B2 (en) | 2010-09-13 | 2019-07-16 | Contour Ip Holding, Llc | Portable digital video camera configured for remote image acquisition control and viewing |
US11076084B2 (en) | 2010-09-13 | 2021-07-27 | Contour Ip Holding, Llc | Portable digital video camera configured for remote image acquisition control and viewing |
US11831983B2 (en) | 2010-09-13 | 2023-11-28 | Contour Ip Holding, Llc | Portable digital video camera configured for remote image acquisition control and viewing |
US9742975B2 (en) | 2010-09-13 | 2017-08-22 | Contour Ip Holding, Llc | Portable digital video camera configured for remote image acquisition control and viewing |
US20120173622A1 (en) * | 2011-01-04 | 2012-07-05 | Samsung Electronics Co., Ltd. | Social screen casting |
US9379756B2 (en) | 2012-05-17 | 2016-06-28 | Liveu Ltd. | Multi-modem communication using virtual identity modules |
US8787966B2 (en) | 2012-05-17 | 2014-07-22 | Liveu Ltd. | Multi-modem communication using virtual identity modules |
US9980171B2 (en) | 2013-03-14 | 2018-05-22 | Liveu Ltd. | Apparatus for cooperating with a mobile device |
US9338650B2 (en) | 2013-03-14 | 2016-05-10 | Liveu Ltd. | Apparatus for cooperating with a mobile device |
US10667166B2 (en) | 2013-03-14 | 2020-05-26 | Liveu Ltd. | Apparatus for cooperating with a mobile device |
US10206143B2 (en) | 2013-05-31 | 2019-02-12 | Liveu Ltd. | Network assisted bonding |
US9369921B2 (en) | 2013-05-31 | 2016-06-14 | Liveu Ltd. | Network assisted bonding |
US9476731B1 (en) * | 2014-01-22 | 2016-10-25 | Flight Plan LLC | Apparatus and methods for accessing an atlas application and a computer readable medium having the atlas application stored thereon and executable by the apparatus |
US9792705B1 (en) * | 2014-01-22 | 2017-10-17 | Flight Plan LLC | Method for providing graphic map information, an apparatus for performing the method, and a computer readable medium having a program stored thereon that is executable by the apparatus in performing the method |
WO2015173240A1 (en) | 2014-05-13 | 2015-11-19 | Cellxion Limited | Method and apparatus for transmission of data over a plurality of networks |
EP2945416A1 (en) | 2014-05-13 | 2015-11-18 | Cellxion Limited | Method and apparatus for transmission of data over a plurality of networks |
US10986029B2 (en) | 2014-09-08 | 2021-04-20 | Liveu Ltd. | Device, system, and method of data transport with selective utilization of a single link or multiple links |
US20180160140A1 (en) * | 2016-12-06 | 2018-06-07 | Hitachi, Ltd. | Arithmetic unit, transmission program, and transmission method |
US10757439B2 (en) * | 2016-12-06 | 2020-08-25 | Hitachi, Ltd. | Arithmetic unit, transmission program, and transmission method |
US11088947B2 (en) | 2017-05-04 | 2021-08-10 | Liveu Ltd | Device, system, and method of pre-processing and data delivery for multi-link communications and for media content |
US11873005B2 (en) | 2017-05-18 | 2024-01-16 | Driveu Tech Ltd. | Device, system, and method of wireless multiple-link vehicular communication |
US11342001B2 (en) * | 2020-01-10 | 2022-05-24 | Nokia Technologies Oy | Audio and video processing |
Also Published As
Publication number | Publication date |
---|---|
US8290034B2 (en) | 2012-10-16 |
US20060114987A1 (en) | 2006-06-01 |
US20080250459A1 (en) | 2008-10-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8290034B2 (en) | Video transmission and display including bit-wise sub-sampling video compression | |
US8416847B2 (en) | Separate plane compression using plurality of compression methods including ZLN and ZLD methods | |
US7991052B2 (en) | Variable general purpose compression for video images (ZLN) | |
US8170095B2 (en) | Faster image processing | |
US7701365B2 (en) | Encoding device and method, composite device and method, and transmission system | |
TWI415462B (en) | A system and method for selective image capture, transimission and reconstruction | |
US7479957B2 (en) | System and method for scalable portrait video | |
US8665943B2 (en) | Encoding device, encoding method, encoding program, decoding device, decoding method, and decoding program | |
US6904176B1 (en) | System and method for tiled multiresolution encoding/decoding and communication with lossless selective regions of interest via data reuse | |
US8068544B2 (en) | Compression with doppler enhancement | |
US7016417B1 (en) | General purpose compression for video images (RHN) | |
US20100321466A1 (en) | Handheld Wireless Digital Audio and Video Receiver | |
US6389160B1 (en) | Hybrid wavelet and JPEG system and method for compression of color images | |
JP2007312399A (en) | Image encoding device and image decoding device, and image display device and method utilizing the same | |
JP2006074130A (en) | Image decoding method, image decoding apparatus, and imaging apparatus | |
KR20020070721A (en) | Streaming device for moving picture | |
JP2005223852A (en) | Image-encoding device and method, and image-decoding device and method | |
Baotang et al. | A Remainder Set Near-Lossless Compression Method for Bayer Color Filter Array Images | |
JP6431301B2 (en) | Movie processing apparatus, method, and computer program | |
JP2005221983A (en) | Image encoding device and image decoding device, and device and method for image display capable of using the same devices | |
Li et al. | Throughput-quality tradeoff in tethered video camera design | |
US20170374368A1 (en) | Video Processor, Method, Computer Program | |
Shan et al. | A New Compression Method for Bayer Color Filter Array Images | |
Choi et al. | A Development of a Medical Information Transmisson System in Moving Picture Form (MedMpeg) | |
US20060056718A1 (en) | Method, device and computer program for encoding digital image |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: ZIN STAI PTE. IN, LLC, DELAWARE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ROMAN, KENDYL A.;REEL/FRAME:021679/0251 Effective date: 20081006 Owner name: ZIN STAI PTE. IN, LLC,DELAWARE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ROMAN, KENDYL A.;REEL/FRAME:021679/0251 Effective date: 20081006 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |
|
AS | Assignment |
Owner name: INTELLECTUAL VENTURES ASSETS 186 LLC, DELAWARE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:OL SECURITY LIMITED LIABILITY COMPANY;REEL/FRAME:062756/0114 Effective date: 20221222 |
|
AS | Assignment |
Owner name: INTELLECTUAL VENTURES ASSETS 186 LLC, DELAWARE Free format text: SECURITY INTEREST;ASSIGNOR:MIND FUSION, LLC;REEL/FRAME:063295/0001 Effective date: 20230214 Owner name: INTELLECTUAL VENTURES ASSETS 191 LLC, DELAWARE Free format text: SECURITY INTEREST;ASSIGNOR:MIND FUSION, LLC;REEL/FRAME:063295/0001 Effective date: 20230214 |