US20070067570A1 - Data processing methods and systems - Google Patents

Data processing methods and systems Download PDF

Info

Publication number
US20070067570A1
US20070067570A1 US11/465,469 US46546906A US2007067570A1 US 20070067570 A1 US20070067570 A1 US 20070067570A1 US 46546906 A US46546906 A US 46546906A US 2007067570 A1 US2007067570 A1 US 2007067570A1
Authority
US
United States
Prior art keywords
entries
cache
sample information
target sample
entry
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
Application number
US11/465,469
Inventor
Chan-Hung Su
Yu-Cheng Hsieh
Jf Yeh
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
MediaTek Inc
Original Assignee
MediaTek Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by MediaTek Inc filed Critical MediaTek Inc
Priority to US11/465,469 priority Critical patent/US20070067570A1/en
Assigned to MEDIATEK INC. reassignment MEDIATEK INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: HSIEH, YU-CHENG, SU, CHAN-HUNG, YEH, JF
Publication of US20070067570A1 publication Critical patent/US20070067570A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/85Assembly of content; Generation of multimedia applications
    • H04N21/854Content authoring
    • H04N21/85406Content authoring involving a specific file format, e.g. MP4 format
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/70Information retrieval; Database structures therefor; File system structures therefor of video data
    • G06F16/71Indexing; Data structures therefor; Storage structures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/432Content retrieval operation from a local storage medium, e.g. hard-disk
    • H04N21/4325Content retrieval operation from a local storage medium, e.g. hard-disk by playing back content from the storage medium
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/433Content storage operation, e.g. storage operation in response to a pause request, caching operations
    • H04N21/4331Caching operations, e.g. of an advertisement for later insertion during playback

Definitions

  • the present disclosure relates generally to data processing, and more particularly to methods and systems for processing and accessing metadata in a media file.
  • Media files such as MPEG-4 files, comprise media data and metadata of the media data.
  • the metadata provides data sample information to media applications for processing media data in the media file.
  • media files are defined to be organized with several structural elements.
  • MPEG-4 files are composed of structural elements called boxes.
  • Each box may comprise media data, metadata or other sub-boxes.
  • a sample table box STBL
  • STBL records time and file information of media data. According to the time and file information in the STBL box, applications can obtain the time, type, data size, and position in the media file and further perform the playback or random-seek functions toward the media file, accordingly.
  • the STBL box also includes several sub-boxes comprising a decoding time to sample box (STTS) as shown in FIG.
  • STTS decoding time to sample box
  • STSZ sample size box
  • STSC sample to chunk box
  • STCO chunk offset box
  • STSS sync sample box
  • STSD sample description table
  • the STTS box contains at least one entry for recording the time duration of samples of media data.
  • FIG. 1 shows a STTS box 100 , comprising 5 entries with total 45 samples in the media data. It should be noted that data in the STTS box is recorded using the concept of run-length coding to reduce the size thereof. That is, the time duration for media sample # 1 ⁇ # 6 , # 7 ⁇ # 20 , # 21 ⁇ # 31 , # 32 ⁇ # 33 , and # 34 ⁇ # 45 is 66, 67, 63, 64, and 66 time units, respectively, and the total time duration of the 45 sample of the media data is 2947 time units.
  • the media samples in the media data are grouped into chunks.
  • the STSC box records the mapping relationship between samples and chunks. Based on the mapping relationship recorded in the STSC box, one can identify in which chunk a target sample resides, and further obtain other related data using the chunk information.
  • FIG. 3 shows a STSC 300 , in which the number of samples in chunk # 1 ⁇ # 2 , chunk # 3 ⁇ # 5 , chunk # 6 ⁇ # 8 , and chunk # 9 and the latter is 3, 4, 7, and 6, respectively.
  • data in the STSC is recorded using the concept of run-length coding to reduce the size thereof. To locate a specific sample, a specific chunk corresponding to the specific sample is sought by performing a linear search by accumulating the number of samples from the first chunk. The calculation is time-consuming if the number of entries in the STSC box is large.
  • target sample information corresponding to the target sample is provided.
  • the media data stream has a plurality of samples and corresponding sample information recorded in at least one entry, wherein the sample information for a predetermined number of the entries is calculated and the calculated result is stored in at least one cache entry.
  • One of the cache entries is located by comparing the target sample information with the calculated result of respective cache entries. After locating the cache entries, the target sample from the entries is located according to the located cache entry.
  • An embodiment of a data processing system comprises a media data stream, at least one cache entry, and a processing unit.
  • the media data stream comprises a plurality of samples and corresponding sample information recorded in at least one entry.
  • the sample information for a predetermined number of the entries is calculated and the calculated result is stored in the cache entry.
  • the processing unit receives target sample information corresponding to a target sample, locates one of the cache entries by comparing the target sample information with the calculated result of respective cache entries, and after locating the cache entries, locates the target sample from the entries according to the located cache entry.
  • Data processing methods may take the form of program code embodied in a tangible media.
  • the program code When the program code is loaded into and executed by a machine, the machine becomes an apparatus for practicing the disclosed method.
  • FIG. 1 shows an example of a STTS
  • FIG. 2 shows an example of a STSS
  • FIG. 3 shows an example of a STSC
  • FIG. 4 is a schematic diagram illustrating an embodiment of entries in the STTS box and its corresponding pre-calculated cache entries
  • FIGS. 5 A ⁇ 5 D shows an example of incremental processing
  • FIG. 6 is a flowchart showing an embodiment of a data processing method
  • FIG. 7 is a flowchart showing another embodiment of a data processing method.
  • FIG. 8 is a schematic diagram of an audio file.
  • FIG. 9 is an embodiment of a pre-calculated cache table.
  • Data processing methods and systems are provided, in which pre-calculated cache entry, shared cache pool and incremental processing are employed.
  • the data processing methods and systems are used to decode MPEG-4 files, which is well-defined in ISO standard and is however not limited in the present invention. An overview of the MPEG-4 files is provided in a standard specification of ISO 14496-12, which is incorporated herein by reference in its entirety for all purposes.
  • the data processing methods and systems are used to decode MP3 data.
  • the data processing methods and systems can be implemented to decode other types of audio data without metadata, such as AAC, AMR/AWB).
  • FIG. 4 is a schematic diagram illustrating an embodiment of entries in the STTS box and its corresponding pre-calculated cache entries. Each cache entry records the accumulated total time duration of a group of STTS entries. The former group of STTS entries is a sub-set of the latter groups. As shown in FIG.
  • the accumulated time duration and sample count of the STTS entries E 1 to E 3 are recorded by cache entry CE 1
  • the accumulated time duration and sample count of the STTS entries E 1 to E 6 are recorded by cache entry CE 2
  • the accumulated time duration and sample count of the STTS entries E 1 to E 9 are recorded by cache entry CE 3
  • the accumulated time duration and sample count of the STTS entries E 1 to E 12 are recorded by cache entry CE 4
  • the accumulated time duration and sample count of the STTS entries E 1 to E 15 are recorded by cache entry CE 5 .
  • the time duration recorded in cache entry CE 2 is the time duration recorded in CE 1 plus the total time duration of 15 samples ( 121 ), and the sample count recorded in cache entry CE 2 is the sample count recorded in CE 1 plus 15.
  • the calculation for other cache entries is similar thereto. It should be noted that the calculation of the cache entries could be calculated in advance.
  • the cache entry CE N is checked, such that the duration recorded in CE N is greater than T and the duration recorded in CE N-1 is smaller than T.
  • the cache entry can be located by a binary search. If CE N-1 records the time duration from E 1 to E X , and CE N records the time duration from E 1 to E y . it is trivial that the sample data which we are looking for must resides in the STTS entries E x to E y . Then a linear search is applied in the STTS entries E x to E y to locate the wanted sample data.
  • the cache entry CE N is checked, such that the accumulated sample count recorded in CE N is greater than K and the accumulated sample count recorded in CE N-1 is smaller than K.
  • the cache entry can be located by a binary search. If CE N-1 records the sample count from E 1 to E x , and CE N records the sample count from E 1 to E y , it is trivial that the sample data which we are looking for must resides in the STTS entries E x to E y . Then a linear search is applied in the STTS entries E x to E y to locate the wanted sample data and it's decoding time.
  • pre-calculated cache With the use of the pre-calculated cache, the frequencies of accessing media files can be greatly reduced since the pre-calculated data can be stored in memory. It is also understood that the use of pre-calculated cache entry can be also applied to STSS and STSC. In STSC, the cache entry records the total number of samples in the chunks covered by the current and prior cache entries.
  • FIG. 8 is a schematic diagram of an audio file.
  • the audio file contains several frames, i.e. X frames.
  • the audio file is evenly divided into Y segments.
  • the end point of each of the Y segments is referred to as a recording point.
  • the value X can vary for different audio files.
  • the value Y is preset in accordance to a preserved storage space for a pre-calculated cache table.
  • the number of segments and the size of the pre-calculated cache table are pre-determined and fixed where the size of each of the Y segments varies according to the value X of the audio file. For example, it is assumed that Y is 100 for each audio file to be decoded. In other words, the pre-calculated cache table would comprise 100 entries.
  • each segment would comprise 100 frames.
  • each segment would comprise 50 frames.
  • audio file 80 comprises 1000 frames.
  • Y is set to be 10.
  • Audio file 80 is divided into segments 801 ⁇ 810 , each of them comprises 100 frames. Accordingly, segment 801 comprises frames 1 ⁇ 100 , and segment 802 comprises frames 101 ⁇ 200 . Frames comprised in any of segments 801 ⁇ 810 can be determined on the analogy of this.
  • FIG. 9 is an embodiment of a pre-calculated cache table.
  • Each cache entry records an offset value corresponding to an end point of a particular segment.
  • the number of entries comprised in the cache table is the same with the preset value Y.
  • cache table 900 would comprise 10 entries, wherein entry 901 corresponds to segment 801 , entry 902 corresponds to segment 802 .
  • Each entry of the cache table 90 corresponds to a segment of audio file 800 .
  • the left column specifies accumulated number of frames at the end point of a segment corresponding to the entry
  • the right column specifies an offset of the end point specified at the left column. It should be noted that the offset values recorded in the cache entries could be calculated in advance.
  • the frame duration is fixed; that is, given a decoding time T, we can easily find the corresponding frame F.
  • one of the cache entries is first located. For example, as shown in FIG. 9 , the present invention first determines in which cache entry the audio frame resides by comparing F with the accumulated frame count. If the wanted frame F is the 205 th frame, it is clearly that F resides in the file with offset range from 63484 to 99876. That is, after the cache entry is located, the segment 902 corresponding to the located cache entry is further searched to locate the offset corresponding to the specific decoding time.
  • the number of corresponding cache entries to each box might be either fixed or dynamically decided according to each box size.
  • the total size of cache memory might be limited and the allocation of the cache entries for each box can be determined using a shared cache pool model.
  • the number of cache entries for a box is determined according to the number of entries in the boxes requiring cache entries in the order of initialization. For example, to allocate a certain amount of cache entries to the STTS box, the STSS box and the STSC box, the system will firstly allocate a first ratio of the cache entries to the STSS box. The first ratio could be the number of STSS entries divided by the total entry count of the 3 tables. In some embodiments, the number of cache entries allocated to the STSS box can be further limited to a pre-defined maximum number. Then, the system will allocate a second ratio of the cache entries to the STSC box.
  • the second ratio could be the number of STSC entries divided by the total entry count of the 3 tables.
  • the number of cache entries allocated to the STSC box can also be further limited to a pre-defined maximum number.
  • the system will allocate the rest of the cache entries to the STTS box. It should be noted that the order of cache allocation is not limited in the present invention. Any order of cache allocation should be covered in the present invention.
  • the calculation of cache entries will need a certain amount of time. For example, if complete cache entries for the STTS box must be prepared before a playback, the accumulated total time duration of a group of STTS entries for respective cache entries must be calculated.
  • the calculation of cache entries is performed with the concept of incremental processing. In incremental processing, a part of the cache entries is calculated before the playback of media data, and the rest of the cache entries are calculated progressively during playback. If the data sought by users is not found in the currently ready cache entries, the calculation of cache entries is performed forward until the data is covered by the cache entries.
  • FIGS. 5 A ⁇ 5 D shows an example of incremental processing.
  • the memory space 511 of the memory 510 is allocated to the STSS box for its corresponding cache entries
  • the memory space 512 of the memory 510 is allocated to the STSC box for its corresponding cache entries
  • the memory space 513 of the memory 510 is allocated to the STTS box for its corresponding cache entries.
  • FIG. 5A before the playback of media data (see playback status 500 ), only a part of the cache entries are calculated.
  • the rest of the cache entries for respective boxes are calculated progressively during playback, as shown in FIG. 5B . Since the calculation is accomplished progressively during playback, each time only a small part of the cache entries are calculated (as shown in FIG.
  • FIG. 6 is a flowchart showing an embodiment of a data processing method.
  • a STTS box is used as an example, rather a limitation to the invention.
  • step S 602 To locate a sample date with the specific decoding time received in step S 601 , in step S 602 , one of the cache entries is firstly located.
  • step S 603 after the cache entry is located, a sample corresponding to the decoding time can be easily found by a linear search.
  • the method of the present invention only needs to search through the group corresponding to the cache entry for the target sample by accumulating the time durations of respective samples in the STTS entries until the sum of the accumulated time duration of samples equals or exceeds the target decoding time. Therefore, total search time can be reduced.
  • the sample is sought for playback, it is also determined whether the sample can be randomly accessed. As described, there are random accessible samples and non-random accessible samples among the media data.
  • a random accessible sample means the sample can be sought and decoded without regard to other samples. If the desired sample is not a random accessible one, a random access point (random accessible sample) closest to (equal to or less than) the sample is sought from the STSS, and a decoding process begins from the random accessible sample, until the desired sample is encountered.
  • FIG. 7 is a flowchart showing another embodiment of a data processing method.
  • a STSC box is used as an example, rather a limitation to the invention.
  • step S 702 To locate a sample with a sample number received in step S 701 , in step S 702 , one of the cache entries is firstly located.
  • step S 703 after the cache entry is located, a chunk number that the sample belonged to is located by a linear search.
  • the method of the present invention only needs to search through the group corresponding to the cache entry for the target chunk number. It is understood that if the sample is sought for playback, related information of the sample is further retrieved from a sample description table (STSD) according to a corresponding sample description index of the located chunk number.
  • STSD sample description table
  • Data processing methods may take the form of program code (i.e., executable instructions) embodied in tangible media, such as products, floppy diskettes, CD-ROMS, hard drives, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine thereby becomes an apparatus for practicing the methods.
  • the methods may also be embodied in the form of program code transmitted over some transmission medium, such as electrical wiring or cabling, through fiber optics, or via any other form of transmission, wherein, when the program code is received and loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the disclosed methods.
  • the program code When implemented on a general-purpose processor, the program code combines with the processor to provide a unique apparatus that operates analogously to application specific logic circuits.
  • the first few entries of the cache table are established before the playback. During the playback, other entries are established.
  • the establishment of cache table can be in the lead from the playback operation. If a user wants to rush the playback operation forward, the established cache table can be used to facilitate locating of the specific forward target.
  • the established cache table can be overwritten when another audio file is to be decoded.
  • the established cache table can be copied to another storage position when another audio file is to be decoded.
  • the copied cache table can be stored for further use.
  • the stored cache table can be utilized, and the establishment of the cache table needs not to be repeated.

Abstract

Data processing methods and systems for accessing a target sample in a media data stream. The media data stream has a plurality of samples and corresponding sample information recorded in at least one entry, wherein the sample information for a predetermined number of the entries is calculated and the calculated result is stored in at least one cache entry. Target sample information corresponding to the target sample is provided. One of the cache entries is located by comparing the target sample information with the calculated result of respective cache entries. After locating the cache entry, the target sample from the entries is located corresponding to the located cache entry.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This is a continuation-in-part application of copending application Ser. No. 11/230,402 filed Sep. 20, 2005, entitled Data Processing Methods and Systems.
  • BACKGROUND
  • The present disclosure relates generally to data processing, and more particularly to methods and systems for processing and accessing metadata in a media file.
  • Media files, such as MPEG-4 files, comprise media data and metadata of the media data. The metadata provides data sample information to media applications for processing media data in the media file. Generally, media files are defined to be organized with several structural elements. For example, MPEG-4 files are composed of structural elements called boxes. Each box may comprise media data, metadata or other sub-boxes. For example, a sample table box (STBL) records time and file information of media data. According to the time and file information in the STBL box, applications can obtain the time, type, data size, and position in the media file and further perform the playback or random-seek functions toward the media file, accordingly. The STBL box also includes several sub-boxes comprising a decoding time to sample box (STTS) as shown in FIG. 1, a sample size box (STSZ), a sample to chunk box (STSC) as shown in FIG. 3, a chunk offset box (STCO), a sync sample box (STSS) as shown in FIG. 2, sample description table (STSD), and others.
  • The STTS box contains at least one entry for recording the time duration of samples of media data. FIG. 1 shows a STTS box 100, comprising 5 entries with total 45 samples in the media data. It should be noted that data in the STTS box is recorded using the concept of run-length coding to reduce the size thereof. That is, the time duration for media sample # 1˜#6, #7˜#20, #21˜#31, #32˜#33, and #34˜#45 is 66, 67, 63, 64, and 66 time units, respectively, and the total time duration of the 45 sample of the media data is 2947 time units.
  • Traditionally, a linear search through these boxes is performed to help locating a specific sample with a target decoding time. A linear search means that the time duration of respective samples from the very first media sample is accumulated until the accumulated time duration equals or exceeds the target decoding time. For example, to locate a specific sample with a specific decoding time 2000, a linear search is performed by accumulating the time duration of the first thirty samples. Since the total time duration of the first thirty samples is 1964 (6*66+14*67+10*63=1964) and the total time duration of the first thirty-one samples is 2027 (6*66+14*67+11*63=2027) which exceeds the specific decoding time 2000, sample #30 is then located. The linear search calculation is time-consuming if there are large number of entries in these boxes.
  • In addition, the media samples in the media data are grouped into chunks. The STSC box records the mapping relationship between samples and chunks. Based on the mapping relationship recorded in the STSC box, one can identify in which chunk a target sample resides, and further obtain other related data using the chunk information. FIG. 3 shows a STSC 300, in which the number of samples in chunk # 1˜#2, chunk # 3˜#5, chunk # 6˜#8, and chunk # 9 and the latter is 3, 4, 7, and 6, respectively. Similarly, data in the STSC is recorded using the concept of run-length coding to reduce the size thereof. To locate a specific sample, a specific chunk corresponding to the specific sample is sought by performing a linear search by accumulating the number of samples from the first chunk. The calculation is time-consuming if the number of entries in the STSC box is large.
  • SUMMARY
  • Data processing methods and systems are provided.
  • In an embodiment of a data processing method for accessing a target sample in a media data stream, target sample information corresponding to the target sample is provided. The media data stream has a plurality of samples and corresponding sample information recorded in at least one entry, wherein the sample information for a predetermined number of the entries is calculated and the calculated result is stored in at least one cache entry. One of the cache entries is located by comparing the target sample information with the calculated result of respective cache entries. After locating the cache entries, the target sample from the entries is located according to the located cache entry.
  • An embodiment of a data processing system comprises a media data stream, at least one cache entry, and a processing unit. The media data stream comprises a plurality of samples and corresponding sample information recorded in at least one entry. The sample information for a predetermined number of the entries is calculated and the calculated result is stored in the cache entry. The processing unit receives target sample information corresponding to a target sample, locates one of the cache entries by comparing the target sample information with the calculated result of respective cache entries, and after locating the cache entries, locates the target sample from the entries according to the located cache entry.
  • Data processing methods may take the form of program code embodied in a tangible media. When the program code is loaded into and executed by a machine, the machine becomes an apparatus for practicing the disclosed method.
  • DESCRIPTION OF THE DRAWINGS
  • The invention will become more fully understood by referring to the following detailed description with reference to the accompanying drawings, wherein:
  • FIG. 1 shows an example of a STTS;
  • FIG. 2 shows an example of a STSS;
  • FIG. 3 shows an example of a STSC;
  • FIG. 4 is a schematic diagram illustrating an embodiment of entries in the STTS box and its corresponding pre-calculated cache entries;
  • FIGS. 55D shows an example of incremental processing;
  • FIG. 6 is a flowchart showing an embodiment of a data processing method; and
  • FIG. 7 is a flowchart showing another embodiment of a data processing method.
  • FIG. 8 is a schematic diagram of an audio file.
  • FIG. 9 is an embodiment of a pre-calculated cache table.
  • DESCRIPTION
  • Data processing methods and systems are provided, in which pre-calculated cache entry, shared cache pool and incremental processing are employed. In some embodiments, the data processing methods and systems are used to decode MPEG-4 files, which is well-defined in ISO standard and is however not limited in the present invention. An overview of the MPEG-4 files is provided in a standard specification of ISO 14496-12, which is incorporated herein by reference in its entirety for all purposes. In addition, in some embodiments, the data processing methods and systems are used to decode MP3 data. The data processing methods and systems can be implemented to decode other types of audio data without metadata, such as AAC, AMR/AWB).
  • Pre-Calculated Cache Entry:
  • First, the data processing methods and systems used to decode MPEG-4 files are described.
  • FIG. 4 is a schematic diagram illustrating an embodiment of entries in the STTS box and its corresponding pre-calculated cache entries. Each cache entry records the accumulated total time duration of a group of STTS entries. The former group of STTS entries is a sub-set of the latter groups. As shown in FIG. 4, the accumulated time duration and sample count of the STTS entries E1 to E3 are recorded by cache entry CE1, the accumulated time duration and sample count of the STTS entries E1 to E6 are recorded by cache entry CE2, the accumulated time duration and sample count of the STTS entries E1 to E9 are recorded by cache entry CE3, the accumulated time duration and sample count of the STTS entries E1 to E12 are recorded by cache entry CE4, and the accumulated time duration and sample count of the STTS entries E1 to E15 are recorded by cache entry CE5. For example, if STTS entry E4 records 3 samples and the time duration of each is 5, STTS entry E5 records 5 samples and the time duration of each is 10, and STTS entry E6 records 7 samples and the time duration of each is 8, the time duration recorded in cache entry CE2 is the time duration recorded in CE1 plus the total time duration of 15 samples (121), and the sample count recorded in cache entry CE2 is the sample count recorded in CE1 plus 15. The calculation for other cache entries is similar thereto. It should be noted that the calculation of the cache entries could be calculated in advance.
  • To locate the sample data with the specific decoding time T, the cache entry CEN is checked, such that the duration recorded in CEN is greater than T and the duration recorded in CEN-1 is smaller than T. In some embodiments, the cache entry can be located by a binary search. If CEN-1 records the time duration from E1 to EX, and CEN records the time duration from E1 to Ey. it is trivial that the sample data which we are looking for must resides in the STTS entries Ex to Ey. Then a linear search is applied in the STTS entries Ex to Ey to locate the wanted sample data.
  • To obtain the decoding time of a specific sample data SK, the similar method applies. The cache entry CEN is checked, such that the accumulated sample count recorded in CEN is greater than K and the accumulated sample count recorded in CEN-1 is smaller than K. In some embodiments, the cache entry can be located by a binary search. If CEN-1 records the sample count from E1 to Ex, and CEN records the sample count from E1 to Ey, it is trivial that the sample data which we are looking for must resides in the STTS entries Ex to Ey. Then a linear search is applied in the STTS entries Ex to Ey to locate the wanted sample data and it's decoding time.
  • With the use of the pre-calculated cache, the frequencies of accessing media files can be greatly reduced since the pre-calculated data can be stored in memory. It is also understood that the use of pre-calculated cache entry can be also applied to STSS and STSC. In STSC, the cache entry records the total number of samples in the chunks covered by the current and prior cache entries.
  • In addition, the data processing methods and systems used to decode MP3 files are described.
  • FIG. 8 is a schematic diagram of an audio file. In the following embodiment, the audio file contains several frames, i.e. X frames. In addition, the audio file is evenly divided into Y segments. The end point of each of the Y segments is referred to as a recording point. The value X can vary for different audio files. The value Y is preset in accordance to a preserved storage space for a pre-calculated cache table. The number of segments and the size of the pre-calculated cache table are pre-determined and fixed where the size of each of the Y segments varies according to the value X of the audio file. For example, it is assumed that Y is 100 for each audio file to be decoded. In other words, the pre-calculated cache table would comprise 100 entries. In this case, for an audio file comprising 10000 frames, each segment would comprise 100 frames. For an audio file comprising 5000 frames, each segment would comprise 50 frames. As shown in FIG. 8, audio file 80 comprises 1000 frames. Here, Y is set to be 10. Audio file 80 is divided into segments 801˜810, each of them comprises 100 frames. Accordingly, segment 801 comprises frames 1˜100, and segment 802 comprises frames 101˜200. Frames comprised in any of segments 801˜810 can be determined on the analogy of this.
  • FIG. 9 is an embodiment of a pre-calculated cache table. Each cache entry records an offset value corresponding to an end point of a particular segment. The number of entries comprised in the cache table is the same with the preset value Y. For example, when Y equals to 10, cache table 900 would comprise 10 entries, wherein entry 901 corresponds to segment 801, entry 902 corresponds to segment 802. Each entry of the cache table 90 corresponds to a segment of audio file 800. In an entry, the left column specifies accumulated number of frames at the end point of a segment corresponding to the entry, and the right column specifies an offset of the end point specified at the left column. It should be noted that the offset values recorded in the cache entries could be calculated in advance.
  • In MP3 file format, the frame duration is fixed; that is, given a decoding time T, we can easily find the corresponding frame F. To locate the frame F with the specific decoding time T, one of the cache entries is first located. For example, as shown in FIG. 9, the present invention first determines in which cache entry the audio frame resides by comparing F with the accumulated frame count. If the wanted frame F is the 205th frame, it is clearly that F resides in the file with offset range from 63484 to 99876. That is, after the cache entry is located, the segment 902 corresponding to the located cache entry is further searched to locate the offset corresponding to the specific decoding time.
  • Shared Cache Pool:
  • In some embodiments, the number of corresponding cache entries to each box might be either fixed or dynamically decided according to each box size.
  • In some embodiments, the total size of cache memory might be limited and the allocation of the cache entries for each box can be determined using a shared cache pool model. In the shared cache pool, the number of cache entries for a box is determined according to the number of entries in the boxes requiring cache entries in the order of initialization. For example, to allocate a certain amount of cache entries to the STTS box, the STSS box and the STSC box, the system will firstly allocate a first ratio of the cache entries to the STSS box. The first ratio could be the number of STSS entries divided by the total entry count of the 3 tables. In some embodiments, the number of cache entries allocated to the STSS box can be further limited to a pre-defined maximum number. Then, the system will allocate a second ratio of the cache entries to the STSC box. The second ratio could be the number of STSC entries divided by the total entry count of the 3 tables. In some embodiments, the number of cache entries allocated to the STSC box can also be further limited to a pre-defined maximum number. Finally, the system will allocate the rest of the cache entries to the STTS box. It should be noted that the order of cache allocation is not limited in the present invention. Any order of cache allocation should be covered in the present invention.
  • Incremental Processing:
  • First, the data processing methods and systems used to decode MPEG-4 files are described.
  • As mentioned above, with the pre-calculated cache entries, lots of time spent on redundant computation can be reduced. However, if the boxes (STTS, STSS and STSC) are very large, the calculation of cache entries will need a certain amount of time. For example, if complete cache entries for the STTS box must be prepared before a playback, the accumulated total time duration of a group of STTS entries for respective cache entries must be calculated. To reduce the response time caused by calculation of cache entries before playback, the calculation of cache entries is performed with the concept of incremental processing. In incremental processing, a part of the cache entries is calculated before the playback of media data, and the rest of the cache entries are calculated progressively during playback. If the data sought by users is not found in the currently ready cache entries, the calculation of cache entries is performed forward until the data is covered by the cache entries.
  • FIGS. 55D shows an example of incremental processing. In this example, the memory space 511 of the memory 510 is allocated to the STSS box for its corresponding cache entries, the memory space 512 of the memory 510 is allocated to the STSC box for its corresponding cache entries, and the memory space 513 of the memory 510 is allocated to the STTS box for its corresponding cache entries. As shown in FIG. 5A, before the playback of media data (see playback status 500), only a part of the cache entries are calculated. The rest of the cache entries for respective boxes are calculated progressively during playback, as shown in FIG. 5B. Since the calculation is accomplished progressively during playback, each time only a small part of the cache entries are calculated (as shown in FIG. 5C), no time delay in playback will be aware by users. If a target decoding time prior to current decoding time is sought, since the required data can be found in the calculated cache entries, no time delay will be aware by users. If a target decoding time is sought and the required data is not found in the calculated cache entries, the calculation of cache entries is performed forward until the data is covered by the cache entries, as shown in FIG. 5D.
  • FIG. 6 is a flowchart showing an embodiment of a data processing method. In this embodiment, a STTS box is used as an example, rather a limitation to the invention. To locate a sample date with the specific decoding time received in step S601, in step S602, one of the cache entries is firstly located. In step S603, after the cache entry is located, a sample corresponding to the decoding time can be easily found by a linear search. Here, after locating the cache entry, the method of the present invention only needs to search through the group corresponding to the cache entry for the target sample by accumulating the time durations of respective samples in the STTS entries until the sum of the accumulated time duration of samples equals or exceeds the target decoding time. Therefore, total search time can be reduced. It is understood that if the sample is sought for playback, it is also determined whether the sample can be randomly accessed. As described, there are random accessible samples and non-random accessible samples among the media data. A random accessible sample means the sample can be sought and decoded without regard to other samples. If the desired sample is not a random accessible one, a random access point (random accessible sample) closest to (equal to or less than) the sample is sought from the STSS, and a decoding process begins from the random accessible sample, until the desired sample is encountered.
  • FIG. 7 is a flowchart showing another embodiment of a data processing method. In this embodiment, a STSC box is used as an example, rather a limitation to the invention. To locate a sample with a sample number received in step S701, in step S702, one of the cache entries is firstly located. In step S703, after the cache entry is located, a chunk number that the sample belonged to is located by a linear search. Here, after locating the cache entry, the method of the present invention only needs to search through the group corresponding to the cache entry for the target chunk number. It is understood that if the sample is sought for playback, related information of the sample is further retrieved from a sample description table (STSD) according to a corresponding sample description index of the located chunk number.
  • Data processing methods, or certain aspects or portions thereof, may take the form of program code (i.e., executable instructions) embodied in tangible media, such as products, floppy diskettes, CD-ROMS, hard drives, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine thereby becomes an apparatus for practicing the methods. The methods may also be embodied in the form of program code transmitted over some transmission medium, such as electrical wiring or cabling, through fiber optics, or via any other form of transmission, wherein, when the program code is received and loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the disclosed methods. When implemented on a general-purpose processor, the program code combines with the processor to provide a unique apparatus that operates analogously to application specific logic circuits.
  • In addition, the data processing methods and systems used to decode MP3 files are described.
  • As mentioned above, with the pre-calculated cache entries, lots of time spent on computation to locate a specific decoding time can be reduced. However, if the audio file is very large, the calculation of cache entries requires a certain amount of time. To reduce the response time caused by calculation of cache entries before playback, the calculation of cache entries is performed with the concept of incremental processing.
  • In incremental processing, a certain portion of the cache entries are calculated before the playback, and the rest of the cache entries are calculated progressively during playback. If the data sought by users is not found in the currently ready cache entries, the calculation of cache entries is performed forward until the data is covered by the cache entries.
  • For example, when an audio file is to be decoded, the first few entries of the cache table are established before the playback. During the playback, other entries are established. The establishment of cache table can be in the lead from the playback operation. If a user wants to rush the playback operation forward, the established cache table can be used to facilitate locating of the specific forward target.
  • The established cache table can be overwritten when another audio file is to be decoded. In addition, the established cache table can be copied to another storage position when another audio file is to be decoded. For the later example, the copied cache table can be stored for further use. When the same audio file is played next time, the stored cache table can be utilized, and the establishment of the cache table needs not to be repeated.
  • While the invention has been described by way of example and in terms of preferred embodiment, it is to be understood that the invention is not limited thereto. Those skilled in this technology can still make various alterations and modifications without departing from the scope and spirit of this invention. Therefore, the scope of the present invention shall be defined and protected by the following claims and their equivalents.

Claims (55)

1. A data processing method for accessing a target sample in a media data stream, the media data stream having a plurality of samples and corresponding sample information recorded in at least one entry, the method comprising:
providing target sample information corresponding to the target sample, wherein the sample information for a predetermined number of entries is calculated and the calculated result is stored in at least one cache entry;
locating one of the cache entries by comparing the target sample information with the calculated result of respective cache entries; and
after locating the cache entry, locating the target sample from the entries corresponding to the located cache entry.
2. The method of claim 1 further comprising determining the number of the cache entries according to the number of the entries.
3. The method of claim 1 further comprising calculating the sample information for the respective predetermined number of the entries during playback.
4. The method of claim 1 wherein at least one table is provided, wherein the table is a time to sample box (STTS) listing the entries and the corresponding sample information, the sample information comprises a decoding time of samples in the corresponding entry.
5. The method of claim 4 wherein the target sample information comprises a specific decoding time.
6. The method of claim 5 wherein the specific decoding time is between the accumulated time duration recorded in the cache entries prior to the located cache entry, and the accumulated time duration recorded in the located cache entry.
7. The method of claim 1 wherein at least one table is provided, wherein the table comprises a sample to chunk box (STSC), comprising chunks of the media data stream, and the sample information comprises the number of samples in respective chunks.
8. The method of claim 7 wherein the target sample number is between the accumulated number of samples recorded in the cache entries prior to the located cache entry and the accumulated number of samples recorded in the located cache entry.
9. The method of claim 1 wherein the media data stream is of a MPEG-4 file.
10. The method of claim 1, wherein the media data stream is comprised in an audio file with no metadata.
11. The method of claim 10, wherein the media data stream is comprised in an MP3, AAC, or AMR/AWB file.
12. The method of claim 10, further dividing the media data stream into segments, and determining the number of the cache entries according to the number of the segments.
13. The method of claim 10, wherein the sample information comprises offset information of an end point of the corresponding segment.
14. The method of claim 13, further comprising calculating the offset for the entries during playback.
15. The method of claim 10, wherein the target sample information comprises a specific decoding time.
16. The method of claim 10, wherein the target sample is located by locating one of the cache entries by a binary search, and further locating the target sample within the located segment by a linear search.
17. The method of claim 10, further copying the established cache entries.
18. The method of claim 10, further rewriting the cache entries when another audio file is to be processed.
19. A machine-readable storage medium comprising a computer program, which, when executed, causes a device to perform a data processing method for accessing a target sample in a media data stream, the media data stream having a plurality of samples and corresponding sample information recorded in at least one entry, the method comprising:
providing target sample information corresponding to the target sample, wherein the sample information for a predetermined number of entries is calculated and the calculated result is stored in at least one cache entry;
locating one of the cache entries by comparing the target sample information with the calculated result of respective cache entries; and
after locating the cache entry, locating the target sample from the entries corresponding to the located cache entry.
20. The storage medium of claim 19 wherein the method further comprising determining the number of the cache entries according to the number of the entries.
21. The storage medium of claim 19 wherein the method further comprising calculating the sample information for the respective predetermined number of the entries during playback.
22. The storage medium of claim 19 wherein at least one table is provided, wherein the table is a time to sample box (STTS) listing the entries and the corresponding sample information, the sample information comprises a decoding time of samples in the corresponding entry.
23. The storage medium of claim 22 wherein the target sample information comprises a specific decoding time.
24. The storage medium of claim 23 wherein the specific decoding time is between the accumulated time duration recorded in the cache entries prior to the located cache entry, and the accumulated time duration recorded in the located cache entry.
25. The storage medium of claim 19 wherein at least one table is provided, wherein the table comprises a sample to chunk box (STSC), comprising chunks of the media data stream, and the sample information comprises the number of samples in respective chunks.
26. The storage medium of claim 25 wherein the target sample number is between the accumulated number of samples recorded in the cache entries prior to the located cache entry and the accumulated number of samples recorded in the located cache entry.
27. The storage medium of claim 19 wherein the media data stream is of a MPEG-4 file.
28. The storage medium of claim 19, wherein the media data stream is comprised in an audio file with no metadata.
29. The storage medium of claim 28, wherein the media data stream is comprised in an MP3, AAC, or AMR/AWB file.
30. The storage medium of claim 28, wherein the method further divides the media data stream into segments, and determines the number of the cache entries according to the number of the segments.
31. The storage medium of claim 28, wherein the sample information comprises offset information of an end point of the corresponding segment.
32. The storage medium of claim 31, wherein the method further comprises calculating the offset for the entries during playback.
33. The storage medium of claim 28, wherein the target sample information comprises a specific decoding time.
34. The storage medium of claim 28, wherein the method further locates the target sample by locating one of the cache entries by a binary search, and further locates the target sample within the located segment by a linear search.
35. The storage medium of claim 28, wherein the method further copies the established cache entries.
36. The storage medium of claim 28, wherein the method further rewrites the cache entries when another audio file is to be processed.
37. A data processing system, comprising:
a media data stream comprising a plurality of samples and corresponding sample information recorded in at least one entry;
at least one cache entry storing a calculated result of the sample information for a predetermined number of the entries; and
a processing unit receiving target sample information corresponding to a target sample, locating one of the cache entries by comparing the target sample information with the calculated result of respective cache entries, and after locating the cache entry, locating the target sample from the entries corresponding to the located cache entry.
38. The system of claim 37 wherein the processing unit further determines the number of the cache entries according to the number of the entries.
39. The system of claim 37 wherein the processing unit further calculates the sample information for the respective predetermined number of the entries during playback.
40. The system of claim 37 wherein at least one table is provided, wherein the table is a time to sample box (STTS) listing the entries and the corresponding sample information, the sample information comprises a decoding time of samples in the corresponding entry.
41. The system of claim 40 wherein the target sample information comprises a specific decoding time.
42. The system of claim 41 wherein the specific decoding time is between the accumulated time duration recorded in the cache entries prior to the located cache entry, and the accumulated time duration recorded in the located cache entry.
43. The system of claim 37 wherein at least one table is provided, wherein the table comprises a sample to chunk box (STSC), comprising chunks of the media data stream, and the sample information comprises the number of samples in respective chunks.
44. The system of claim 43 wherein the target sample number is between the accumulated number of samples recorded in the cache entries prior to the located cache entry and the accumulated number of samples recorded in the located cache entry.
45. The system of claim 37 wherein the media data stream is of a MPEG-4 file.
46. The system of claim 37 wherein the data processing system is a MPEG-4 file decoder.
47. The system of claim 37, wherein the media data stream is comprised in an audio file with no metadata.
48. The system of claim 47, wherein the media data stream is comprised in an MP3, AAC, or AMR/AWB file.
49. The system of claim 47, wherein the processing unit further divides the media data stream into segments, and determines the number of the cache entries according to the number of the segments.
50. The system of claim 47, wherein the sample information comprises offset information of an end point of the corresponding segment.
51. The system of claim 50, wherein the processing unit further calculates the offset for the entries during playback.
52. The system of claim 47, wherein the target sample information comprises a specific decoding time.
53. The system of claim 47, wherein the processing unit further locates the target sample by locating one of the cache entries by a binary search, and further locates the target sample within the located segment by a linear search.
54. The system of claim 47, wherein the processing unit further copies the established cache entries for further use.
55. The system of claim 47, wherein the processing unit further rewrites the cache entries when another audio file is to be processed.
US11/465,469 2005-09-20 2006-08-18 Data processing methods and systems Abandoned US20070067570A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US11/465,469 US20070067570A1 (en) 2005-09-20 2006-08-18 Data processing methods and systems

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/230,402 US7370144B2 (en) 2005-09-20 2005-09-20 Method and system for accessing a target sample in a media data stream
US11/465,469 US20070067570A1 (en) 2005-09-20 2006-08-18 Data processing methods and systems

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US11/230,402 Continuation-In-Part US7370144B2 (en) 2005-09-20 2005-09-20 Method and system for accessing a target sample in a media data stream

Publications (1)

Publication Number Publication Date
US20070067570A1 true US20070067570A1 (en) 2007-03-22

Family

ID=37115999

Family Applications (2)

Application Number Title Priority Date Filing Date
US11/230,402 Active 2026-06-24 US7370144B2 (en) 2005-09-20 2005-09-20 Method and system for accessing a target sample in a media data stream
US11/465,469 Abandoned US20070067570A1 (en) 2005-09-20 2006-08-18 Data processing methods and systems

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US11/230,402 Active 2026-06-24 US7370144B2 (en) 2005-09-20 2005-09-20 Method and system for accessing a target sample in a media data stream

Country Status (5)

Country Link
US (2) US7370144B2 (en)
EP (2) EP1765017B1 (en)
CN (2) CN1937768B (en)
BR (1) BRPI0604196A (en)
TW (2) TWI314016B (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090119594A1 (en) * 2007-10-29 2009-05-07 Nokia Corporation Fast and editing-friendly sample association method for multimedia file formats
US20090171674A1 (en) * 2007-12-27 2009-07-02 Roland Corporation Playback device systems and methods
US20090292878A1 (en) * 2008-05-20 2009-11-26 Pantech Co., Ltd. Method and system for providing digital rights management files using caching

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7370144B2 (en) * 2005-09-20 2008-05-06 Mediatek, Inc. Method and system for accessing a target sample in a media data stream
US8214516B2 (en) * 2006-01-06 2012-07-03 Google Inc. Dynamic media serving infrastructure
US10986402B2 (en) 2018-07-11 2021-04-20 Qualcomm Incorporated Time signaling for media streaming

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5604499A (en) * 1993-12-28 1997-02-18 Matsushita Electric Industrial Co., Ltd. Variable-length decoding apparatus
US6008745A (en) * 1998-02-17 1999-12-28 Sun Microsystems, Inc. Variable length decoding using lookup tables
US6157929A (en) * 1997-04-15 2000-12-05 Avid Technology, Inc. System apparatus and method for managing the use and storage of digital information
US20030079222A1 (en) * 2000-10-06 2003-04-24 Boykin Patrick Oscar System and method for distributing perceptually encrypted encoded files of music and movies
US20040205224A1 (en) * 1998-01-15 2004-10-14 Anne Jones Method and apparatus for media data transmission
US7370144B2 (en) * 2005-09-20 2008-05-06 Mediatek, Inc. Method and system for accessing a target sample in a media data stream

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0914636A4 (en) 1997-04-07 2008-07-30 At & T Corp System and method for processing object-based audiovisual information
GB0124882D0 (en) * 2001-10-17 2001-12-05 Koninkl Philips Electronics Nv Improved variable length decoder

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5604499A (en) * 1993-12-28 1997-02-18 Matsushita Electric Industrial Co., Ltd. Variable-length decoding apparatus
US6157929A (en) * 1997-04-15 2000-12-05 Avid Technology, Inc. System apparatus and method for managing the use and storage of digital information
US20040205224A1 (en) * 1998-01-15 2004-10-14 Anne Jones Method and apparatus for media data transmission
US6008745A (en) * 1998-02-17 1999-12-28 Sun Microsystems, Inc. Variable length decoding using lookup tables
US20030079222A1 (en) * 2000-10-06 2003-04-24 Boykin Patrick Oscar System and method for distributing perceptually encrypted encoded files of music and movies
US7370144B2 (en) * 2005-09-20 2008-05-06 Mediatek, Inc. Method and system for accessing a target sample in a media data stream

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090119594A1 (en) * 2007-10-29 2009-05-07 Nokia Corporation Fast and editing-friendly sample association method for multimedia file formats
US20090171674A1 (en) * 2007-12-27 2009-07-02 Roland Corporation Playback device systems and methods
US20090292878A1 (en) * 2008-05-20 2009-11-26 Pantech Co., Ltd. Method and system for providing digital rights management files using caching
US7991958B2 (en) * 2008-05-20 2011-08-02 Pantech Co., Ltd. Method and system for providing digital rights management files using caching
US8200899B2 (en) 2008-05-20 2012-06-12 Pantech Co., Ltd. Method and system for providing digital rights management files using caching

Also Published As

Publication number Publication date
EP1765017B1 (en) 2015-03-11
CN1937768B (en) 2010-04-14
BRPI0604196A (en) 2007-08-21
TWI320885B (en) 2010-02-21
US7370144B2 (en) 2008-05-06
TW200712876A (en) 2007-04-01
CN1936900A (en) 2007-03-28
CN1937768A (en) 2007-03-28
TWI314016B (en) 2009-08-21
US20070067568A1 (en) 2007-03-22
TW200714082A (en) 2007-04-01
EP1764713A1 (en) 2007-03-21
EP1765017A1 (en) 2007-03-21

Similar Documents

Publication Publication Date Title
US8194730B2 (en) Efficient use of storage in encoding and decoding video data streams
US7133881B2 (en) Encoding and transferring media content onto removable storage
US20070067570A1 (en) Data processing methods and systems
CN100585740C (en) Flash memory apparatus and access method to flash memory
WO2017092340A1 (en) Method and device for compressing and playing video
CN1762022A (en) Cpi data for steam buffer channels
WO2018063466A1 (en) Data storage system with multimedia assets
US20170017426A1 (en) Data storage device and data maintenance method thereof
US7581135B2 (en) System and method for storing and restoring a data file using several storage media
US8868429B2 (en) Method and device for storing audio data
US6701391B1 (en) System for stop buffering when a count of stored data blocks from a DVD matches an associated data block number of a requested data block set
EP1576605A1 (en) Recording and reproduction apparatus, recording apparatus, editing apparatus, information recording medium, recording and reproduction method, recording method, and editing method
US9014259B2 (en) Apparatus and method for sequentially parsing bitstreams based on removal of emulation prevention byte
US8565584B2 (en) Editing apparatus and editing method
WO2016186602A1 (en) Deletion prioritization
US20140185690A1 (en) Multimedia data stream format, metadata generator, encoding method, encoding system, decoding method, and decoding system
US8306406B2 (en) Video and audio reproduction apparatus and method thereof
US7631144B1 (en) Write latency efficient storage system
KR100874023B1 (en) Method and apparatus for managing input data buffer of MP3 decoder
JP2005518730A (en) Adaptive storage of media information
CN114374875A (en) MP4 file recording method and device and readable storage medium
CN117235069A (en) Index creation method, data query method, device, equipment and storage medium
CA2345422A1 (en) Method and apparatus for element selection exhausting an entire array
BRPI0600876B1 (en) "DATA PROCESSING METHOD FOR ACCESSING MEDIUM-SAMPLE EXECUTABLE MEDIA STORAGE IN A MACHINE AND DATA PROCESSING SYSTEM".
EP2894578A1 (en) Method and apparatus for handling data in a storage system

Legal Events

Date Code Title Description
AS Assignment

Owner name: MEDIATEK INC., TAIWAN

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SU, CHAN-HUNG;HSIEH, YU-CHENG;YEH, JF;REEL/FRAME:018134/0118

Effective date: 20060712

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO PAY ISSUE FEE