Senior Fitness - Exercise and Nutrition for Aging Men and Women
FREE Article Feed for your website.
Home Ownership Magazine
Party Planning Information
Article Marketing Resources
Bio-Medical Research Article Database
Informative Articles on Life, Love and Happiness
Tutorials on Business to Writing
Famous Quotes from Famous People
Song Lyric Information
New US Patent Information
Comprehensive List of Content by Category
Online Auctions and Shopping Related Articles
Article Search
Most Recent Articles
 

How To Determine Which Cell Service Is Best For You
Category:
Business  

A Short History of the Wristwatch
Category:
Business  

Growing Your Own Herbs
Category:
Home And Family  

Herbal Acne Home Cures
Category:
Health / Fitness  

Creating Fresh Content for Search Engines
Category:
Marketing  

That Talking Thing will either make or break a relationship
Category:
Home And Family  

Avoid the Most Common Mistakes in Affiliate Marketing
Category:
Business  

Know the Signs of Childhood Asthma
Category:
Health / Fitness  

The Easiest Weight Loss Program Ever
Category:
Health / Fitness  

How to Expand your Business by Leaps and Bounds
Category:
Business  

Personal Accident Claim The Successful Route
Category:
Business  

Free Advertising
Category:
Marketing  

Free Advertising
Category:
Marketing  

Chicken and the Egg
Category:
Business  

Herbs for hair growth
Category:
Health / Fitness  

Organic Gardening
Category:
Home And Family  

Does Your Cleaning Business Have a Mission Statement
Category:
Business  

Internet Banking Are you online
Category:
Finance / Investment  

3 Things All Affiliate Marketers Need To Survive Online
Category:
Marketing  

How to use your subject to grab the attention of your optin news...
Category:
Marketing  

Choosing the Right Network Marketing Company 4 surprising steps
Category:
Marketing  

Diabetic diet plan guide
Category:
Health / Fitness  

6 POWERFUL VRE Business Models You Can Start Building In 2006 Us...
Category:
Business  

Free Cell Phone Ring Tones Jingling Vibes For Any Occasion
Category:
Entertainment / Television  

Free Ringtone Downloads Dazzling Tunes For Your Pleasure
Category:
Entertainment / Television  

Why choose MLM Leads
Category:
Business  

Vending Machines provide an excellent income
Category:
Business  

Discovers The Secret To The Most Popular Way Of Making Money
Category:
Business  

Internet Marketing Information Overload
Category:
Marketing  

Your New Cat Why Are the First 24 Hours So Important Part 3
Category:
Home And Family  

SearchInform 3 0 Consolidating information from various sources
Category:
Computers  

Health Insurance How to Find An Affordable Quote
Category:
Home And Family  

Brand You The Top Five Ways To Build Your Brand Online
Category:
Marketing  

Acne Treatment
Category:
Health / Fitness  

Home Business Entrepreneurs Banking On Increased Income
Category:
Business  

Hypnotherapy in Bedfordshire
Category:
Health / Fitness  

An Alaska Cruise Offers Unlimited Fun
Category:
Travel  

Guide To Ceiling Fan Blades
Category:
Home And Family  

Personal Injury Specialist No Win No Fee
Category:
Finance / Investment  

reduce tension
Category:
Business  

How to Use Free Articles to Create Massive Traffic Within Minute...
Category:
Marketing  

LASIK a Cure for Blurry Vision
Category:
Health / Fitness  

The Truth About Debt Consolidation
Category:
Business  

Don t Wait for a Mate Feather Your Nest Now Part 2
Category:
Home And Family  

Hawaii Vacation Accommodation and Holiday Homes in Oahu Maui Kau...
Category:
Travel  

Mortgage Lenders Making The Right Choice
Category:
Business  

Hawaii Vacation Accommodation and Holiday Homes in Oahu Maui Kau...
Category:
Travel  

Changing Face Of Holidays In The UK
Category:
Travel  

Make Your Business Memorable with Business Cards
Category:
Marketing  

Network Marketing The Organic Way
Category:
Marketing  

8 Ways to Grow Your Business During a Summer Lull
Category:
Marketing  

You Don t Need to be a Computer Scientist to Profit Online
Category:
Marketing  

Information Retrieval Systems IRS and Search Engines SEO
Category:
Marketing  

Plasma TVs are Hot
Category:
Computers  

The Top Providers on the Web
Category:
Health / Fitness  

Winning the Skin War Best Acne Skin Care
Category:
Health / Fitness  

Boost Your Income and Hits Today
Category:
Business  

Bad Credit Loans Made Easier by Pre Approval
Category:
Business  

Vitamin supplements by Nguang Nguek Fluek
Category:
Health / Fitness  

How you Can Save Money if you Book Hotels in Central Rome
Category:
Travel  

Universal Life Insurance guide 101
Category:
Finance / Investment  

FINE or VICE Cash Loans
Category:
Finance / Investment  

Why Blogs are so popular
Category:
Marketing  

Office Supplies and Client Relation
Category:
Business  

Buying a Hidden Spy Camera
Category:
Business  

Understanding Flower Bulbs
Category:
Home And Family  

Parenting 101 Get Into a Parenting Class
Category:
Home And Family  

Lanzarote Tourist
Category:
Travel  

A Visitors Guide to Paris France
Category:
Travel  

Personal Accounts Choosing Your Bank
Category:
Business  

Protect Yourself Against Viruses
Category:
Computers  

Acne A Clean Face First Step In A 12 Step Program
Category:
Health / Fitness  

Inspiring Chicago Musical
Category:
Entertainment / Television  

VOIP security guide
Category:
Computers  

Three Reasons For Becoming A Foster Parent
Category:
Home And Family

Method and apparatus for storing and accessing multiple constant bit rate data Number:6,999,476 from the United States Patent and Trademark Office (PTO) owispatent

Home    Author Login    Submit Article    Article Search    Add Your Link    Edit Your Link    Contact Us    Advertising    Disclaimer

   

 
Web LinkGrinder.com

Top Breaking News
     Greek, Cypriot Leaders Resume Unification Talks in Nicosia by Nathan Morley
     Indonesia Tobacco Sales Grow, Raising Health Fears
     South Korea Allows Top Defector to Travel Overseas by VOA News

Title: Method and apparatus for storing and accessing multiple constant bit rate data

Abstract: A method of defining extent for storing a plurality data streams having different bit rates. The method calculates the size of the extent for a given data stream then periodically inserts at least one null packet into the extents to enable any bit rate to be able to be stored using a fixed extent size for the stream.

Patent Number: 6,999,476 Issued on 02/14/2006 to Lerman,   et al.


Inventors: Lerman; Jesse S. (Kendall Park, NJ); Chin; Danny (Princeton Junction, NJ)
Assignee: Sedna Patent Services, LLC (Philadelphia, PA)
Appl. No.: 925215
Filed: August 8, 2001

Current U.S. Class: 370/470
Current Intern'l Class: H04J 3/16     (20060101)
Field of Search: 370/232,470,234,230,231,233,428,465,389 348/384.1,387.1,404.1,410.1,441


References Cited [Referenced By]

U.S. Patent Documents
5400329Mar., 1995Tokura et al.
5493568Feb., 1996Sampat et al.
5506832Apr., 1996Arshi et al.
5913026Jun., 1999Bleidt et al.
6282207Aug., 2001Lerman et al.

Primary Examiner: Ton; Dang
Attorney, Agent or Firm: Patterson & Sheridan, LLP

Parent Case Text



CROSS-REFERENCE TO RELATED APPLICATION

This application is a continuation of U.S. patent application Ser. No. 09/458,337, filed on Dec. 10, 1999 (now U.S. Pat. No. 6,282,207 B1, issued on Aug. 28. 2001), which claims benefit of U.S. Provisional Patent Application Ser. No. 60/126,836 filed Mar. 30, 1999.
Claims



What is claimed is:

1. A method for storing and accessing a plurality of programs in memory, said programs having various constant bit rates, comprising the steps of:

associating each program with a constant bit rate;

computing an extent size for each program from the respective constant bit rate associated with each program;

determining a quantity of packets associated with the extent size;

rounding the computed extent size up to a next whole packet of data;

identifying extents that require a null packet to be added to the extent;

inserting the null packet into the identified extents; and

storing the packets associated with each extent in said memory.

2. The method of claim 1 wherein said memory is a disk drive army comprising a plurality of disk drives.

3. The method of claim 2 wherein said storing step further comprises the step of striping the extents across said disk drive array.

4. The method of claim 1 wherein the plurality of programs comprises a plurality of packetized data streams where each data stream has a different bit rate.

5. The method of claim 4 wherein the packetized data stream comprise packets of encoded video information.

6. The method of claim 1 wherein said step of computing the extent size further comprises the step of multiplying the constant bit rate associated with each program times a respective service interval.

7. A computer-readable medium having stored thereon a plurality of instructions, the plurality of instructions including instructions that, when executed by a processor, cause the processor to perform the steps comprising:

associating each program with a constant bit rate;

computing an extent size for each program from the respective constant bit rate associated with each program;

determining a quantity of packets associated with the extent size;

rounding the computed extent size up to a next whole packet of data;

identifying extents that require a null packet to be added to the extent;

inserting the null packet into the identified extents; and

storing the packets associated with each extent in said memory.

8. The computer-readable medium of claim 7 wherein said memory is a disk drive array comprising a plurality of disk drives.

9. The computer-readable medium of claim 8 wherein said storing step further comprises the step of striping the extents across said disk drive array.

10. The computer-readable medium of claim 7 wherein the plurality of programs comprises a plurality of packetized data streams where each data stream has a different bit rate.

11. The computer-readable medium of claim 10 wherein the packetized data stream comprise packets of encoded video information.

12. The computer-readable medium of claim 7 wherein said step of computing the extent size further comprises the step of multiplying the constant bit rate associated with each program times a respective service interval.

13. Apparatus for storing and accessing a plurality of programs in memory, said programs having various constant bit rates, comprising:

means for associating each program with a constant bit rate and computing an extent size for each program from the respective constant bit rate associated with each program;

means for determining a quantity of packets associated with the extent size and rounding the computed extent size up to a next whole packet of data;

means for identifying extents that require a null packet to be added to the extent and inserting the null packet into the identified extents; and

means for storing the packets associated with each extent in said memory.

14. The apparatus of claim 13 wherein said storing means further comprises striping the extents across a disk drive array.

15. The apparatus of claim 13 wherein the plurality of programs comprises a plurality of packetized data streams where each data stream has a different bit rate.

16. The apparatus of claim 15 wherein the packetized data stream comprise packets of encoded video information.

17. The apparatus of claim 13 wherein said means for computing the extent size further comprises multiplying the constant bit rate associated with each program multiplied by a respective service interval.
Description



BACKGROUND OF THE INVENTION

1. Field of the Invention

The invention relates to electronic data storage and access. More particularly, the invention relates to a method and apparatus for storing and retrieving multiple electronic data streams having different bit rates.

2. Description of the Background Art

Multimedia systems store and retrieve video, audio and other content from mass storage devices, e.g., disk drive arrays. One such system provides video-on-demand (VOD) to an end user. Such a VOD system stores video content in memory and retrieves the content upon demand. The VOD system then serves the video content to the end user requesting the video content.

The VOD system uses a VOD server for storing and accessing video content or a plurality of video files. The VOD server processes the video content as data packets and stores the video content into extents or logical memory blocks within a memory. The data packets generally comply with one or more of the Moving Pictures Experts Group (MPEG) standards. To store these data packets in a redundant manner, the VOD server may stripe the video content over an array of disks within the memory. Each video file may occupy several physical disk blocks or disk tracks within the disk drives.

Multimedia programs are encoded using various resolutions of encoding depending upon the content of the program, i.e., sporting events are encoded with higher resolution than situation comedies. The bit rate of high-resolution encoded program is greater than a bit rate of a low-resolution encoded program. As such, for a given unit of program time, a high resolution encoded program generates more packets than are generated when forming a low resolution encoded program. Consequently, a video server must be able to store a plurality of programs having constant bit rates. To facilitate storage of multiple constant bit rate programs, current servers require the bit rates of various programs to be integer multiple of one another such that the extents of any given program are of equal size and the extents across programs are integer multiples of each other. Such a restrictive storage system is not flexible in providing storage of any form of programming, i.e., programs having non-integer bit rates. Consequently, current video servers do not store programming in an optimal manner.

Therefore, there is a need in the art for an improved method and apparatus for storing an accessing multiple constant bit rate video programs wherein the bit rate of programming can be arbitrary.

SUMMARY OF THE INVENTION

The invention overcomes the disadvantages associated with the prior art by a method and apparatus for defining constant time length (CTL) extents to store packetized video streams having multiple constant bit rates (MCBR), i.e., each stream has a constant bit rate within the stream, but different as compared to other streams. Specifically, the method analyses the bit rate of a given stream and determines an appropriate length for a CTL extent within which to store data packets that comprise the stream. The extent is a number of bits that can be read from memory during a data read period for a given bit rate, rounded up to the next full packet. The method then stores the extents and pads some extents with a null packet, as needed, to compensate for accumulated partial packets of data. The null packets are referred to as dither null packets to differentiate them from the null packets that appear in a standard encoded video bitstream. Consequently, any bit rate stream can be stored in this manner with a minimum utilization of dither null packets. The extents are stored by striping them onto a disk array, i.e., one extent per disk drive, then wrapping from the last drive in the array to the first. The method repeats for each data stream such that a plurality of constant bit rate streams are stored.

To read the data from the array, the extents are recalled one at a time and temporarily stored in a buffer memory. A data pointer is used to access the packets from the buffer. The dither null packets are skipped such that the output stream of packets does not contain dither null packets. The packets are coupled to a multiplexer. The multiplexer combines the packets into a transport stream to deliver the packets of video data to a downstream user.

BRIEF DESCRIPTION OF THE DRAWINGS

The teachings of the present invention can be readily understood by considering the following detailed description in conjunction with the accompanying drawings, in which:

FIG. 1 shows a high level block diagram of a system for storing and retrieving data;

FIG. 2 shows process for storing MCBR data streams;

FIG. 3 shows a flow diagram of a routine for storing multiple constant bit rate (MCBR) data streams into memory.

To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures.

DETAILED DESCRIPTION

FIG. 1 depicts a high level block diagram of a video server system 100 for storing and retrieving data. The system 100 of FIG. 1 finds great utility in, e.g., a video of demand (VOD) system, as described in U.S. Pat. No. 6,253,375, issued Jun. 26, 2001, and incorporated herein by reference. The system 100 comprises a sewer 102 and an array of storage disks 1041, 1042 . . . 104n, where n is an integer equal to the number of storage disks in an array used to store and retrieve data. The server 102 comprises an access controller 108, a data buffer 110, and a multiplexer (MUX) 112. Other components and features of the system 100 not essential to the invention are not discussed herein.

In operation of the system 100, the server 102 receives a data stream or video file from a video source 106 via signal path S1. The data stream is typically video content, such as a movie or live broadcast, in the form of an encoded and/or compressed bitstream using, illustratively, the MPEG-2 standard. The data stream is generally a sequence of data packets. The packets may be standard MPEG packets or they may be special transport packets such as those described in U.S. patent application Ser. No. 09/458,339, filed Dec. 10, 1999, and is incorporated herein by reference.

The packets are organized into groups to facilitate storage. The groups of packets are known as extents. The video source 106 generally provides a plurality of constant bit rate video programs, i.e., MPEG bitstreams, having arbitrary bit rates. Each program may have a different bit rate as compared to other programs such that programs of various video resolution are made available to a viewer. Thus, for a given length of programming time, more or less packets represent each program depending upon the encoding parameters used to produce the encoded program.

The server 102 stores the data stream in a memory comprising an array of disks 1041, 1042 . . . 104n or some storage medium. The array of disks 1041, 1042 . . . 104n may be arranged in a Redundant Array of Independent Disks (RAID) configuration as discussed in The RAIDbook: A Source Book for Disk Array Technology, Fourth Edition (1995). Each disk 1041, 1042 . . . 104n in the array stores data as extents.

The server 102 stripes the data into array of disks 1041, 1042 . . . 104n illustratively in the manner shown in U.S. U.S. Pat. No. 5,920,702, issued Jul. 6, 1999 and incorporated herein by reference. The size of the extent is a constant time length (CTL) extent, where the extent represents a fixed period of programming time, i.e., a fixed number of encoded video frames. Each extent may store a plurality of data packets that represent video content and a null packet, as needed. The use of null packets shall be described below.

When a user requests to view a particular video or data stream, the video session manager (not shown) of the system 100 sends a control or enable signal to the server 102. In response to this signal, the access controller 108 of the server 102 retrieves the extents for the requested program from the array of disks 1041, 1042 . . . 104n. The server 102 then buffers the retrieved program in buffer 110 and, using MUX 112, combines the packets of the retrieved program with those of other programs to form a transport stream on signal path S2. The transport stream is coupled to a network and sent downstream to a user set top terminal for viewing.

FIG. 2 diagrammatically depicts the process used to store multimedia programming on the disk array 104 of FIG. 1. For simplicity two encoded movies 200 and 202 are shown having bit rates b1 and b2, where b2 is greater than b1 and both bit rates are arbitrary.

The process first computes an extent size for each movie. The extent size in equal to the bit rate of the movie times the service interval over which the extent will be read from the disk drive. For example, if the bit rate for movie 1 (M1) is 5 Mbps and the service period is 1.8 seconds, then the extent size will be 5984.04 packets (assuming 188 byte MPEG packets are used to carry the data). Since partial packets can not be stored, i.e., cannot be divided over two extents, the process rounds up to the next full packet. Additionally, rounding up ensures that a data underflow condition will not occur at the decoder, i.e., more data is being supplied per service interval than is necessary. As such, in this example, the extent size is 5985 packets.

As movie 1 is stored in these 5985 packet long extents, a fractional packet accumulation occurs that, if not compensated for, would add substantial amount of buffer memory needed to process a movie within a decoder. In the example and as shown at reference number 208, a 0.96 fraction of a packet is accumulated with each extent such that after 2 extents more than full packet of accumulation occurs, i.e., 1.92 packets. To minimize the size of the buffer memory in the server, the invention compensates for the accumulation by making the 5986th packet a null packet after a full packet of accumulation occurs. Without such null packet utilization, the buffer memory would accumulate a substantial number of packets, since the access controller would be providing more packets than are sent to users. In this example, after 2 extents have been stored, the 3rd extent (E3) contains a null packet (Pnull). The null packet used for accumulation compensation is referred to as a dither null packet to differentiate the packet from a standard null packet that may appear in an MPEG stream.

The access controller maintains a sum of the fractional packet accumulation. As such, a fractional packet accumulation value is computed and, when a null packet is used, one packet is subtracted from the accumulation value and the remainder is used as the accumulation value to which additional fractional packet values are added. In the example above, the first extent fractional value is 0.96 and the accumulated value after the second extent is 1.92 (i.e., 0.96 plus 0.96). Then, one dither null packet is used and the accumulation value falls to 0.92, but the third packet adds a 0.96 fractional packet to the accumulation value causing the accumulation value to rise to 1.88. As such, the fourth extent will contain a dither null packet. This process is repeated until the entire movie is stored in memory.

The present invention typically stores packets that have a header in which a special code is used to identify a dither null packet. This code is used to ensure that the dither null packets are removed from the data before the data is sent to a user. Sending such null packets would use bandwidth in the transmission channel for no reason. The removal of dither null packets is described below.

These extents are striped onto the disk array as shown in striping map 206, where movie 1, extent 1 (M1E1) is stored on disk drive 1 (D1), then M1E2 is stored on D2 and so on.

If, for example and as shown at 202, the bit rate for movie 2 (M2) is 6 Mbps and the service period is 1.8 seconds, then the extent size will be 7180.85 packets (assuming 188 byte MPEG packets are used to carry the data). The process rounds up to the next full packet, to an extent size is 7181 packets. As movie 2 is stored in these 7181 packet long extents, the fractional packet accumulation is a 0.15 fraction of a packet for each extent such that after 6 extents a full packet of accumulation occurs. The invention, as shown at 204, compensates for the fractional packet accumulation by using a dither null packet after a full packet of accumulation occurs. In this example, after 6 extents have been stored, the 7th extent (E7) uses a dither null packet (Pnull). The extents for movie 2 are stored on the disk drive array as shown in the striping map 206.

Using null packets in this manner, any arbitrary bit rate packet stream can be easily stored and the server uses a minimal sized buffer.

Returning to FIG. 1, upon a request for delivery of programming to a user, the program extents are recalled from the disk drives by the access controller 108. The extents are buffered in buffer 110. Since the server 102 is simultaneously processing and fulfilling requests from many users, the access controller 108 interleaves the extent accesses of the various requested movies. Although the extents for a requested movie are generally accessed sequentially, they are not accessed contiguously. As such, a given movie's extents are placed in the buffer 110 interspersed with other movie's extents. In fact, to minimize buffer size, an extent for a given movie is not added to the buffer 110 until the previous extent has been read out of the buffer 110 and sent to the user.

As the extents are stored in the buffer 110, the access controller monitors the packet headers within the extents to detect dither null packets. Once identified, the pointer that is used to access the packets for transfer to the multiplexer 112 is instructed to skip the dither null packets. As such, the dither null packets are not transferred to the multiplexer 112.

The multiplexer 112 is provided the buffered packets as needed to maintain a steady video signal at a user's television. The individual packets from the buffer 110 are positioned into a transport stream along with packets of many other programs. The transport stream is transmitted along with as many as 270 other streams through a 1 G bps fiber optic channel to the user. The user's equipment extracts from the transport stream the packets associated with the requested program, decodes the packets, and displays the program.

FIG. 3 shows a flow diagram of a routine 300 for storing multiple constant bit rate (MCBR) data streams into a memory. The routine 300 begins with a start signal at step 302. The routine 300 then proceeds to step 304 to determine the extent size to use for the MCBR stream. As discussed above, the extent size (E) is the bit rate (BR) of the stream times the service interval (Ts) (i.e., the time required to read an extent from a disk drive to fulfill a user request).

The routine 300 then proceeds to step 308 to determine which of the extents will receive a dither null packet. The process maintains an accumulation value, as described above. This accumulation value is the sum of the fractional packet value that is contained in each extent. When the accumulation value reaches a value that is greater than or equal to one, a dither null packet is used. This reduces the accumulation value by one and the remainder is then used as the accumulation value to which the following extent's fractional value is added. Thus, step 308 uses the accumulation value to determine which of the extents will contain a dither null packet. used

At step 310, the server 102 stores the data stream into the extents as defined in step 306 and inserts dither null packets in the extents as determined in step 308. The extents are striped across the array as discussed with respect to FIG. 2.

After storing the extents, the routine 300 proceeds to step 312 to determine whether there are any more data streams to be stored. If there is additional data to receive, then the routine 300 returns to step 304 to receive and store an additional data stream. If there is no additional data to receive, then the routine 300 proceeds to step 314 to stop the storage of MCBR data streams.

The numerical values used herein in FIGS. 1 to 3 are illustrative and are not intended as limiting the invention. As such, other values and standards may be used without affecting the scope of the invention.

Although various embodiments which incorporate the teachings of the present invention have been shown and described in detail herein, those skilled in the art can readily devise many other varied embodiments that still incorporate these teachings.

*


Free Web Sudoku Puzzles.
Solve with your browser.
        5 7 4   1
6   1 3          
        2       5
7 4 6 8          
                 
          5 3 4 6
1       4        
          8 1   7
8   2 1 9        
What is it?



Add Your Site · Terms Of Service · Privacy Policy


DISCLAIMER
Linkgrinder is a free service that searches the Internet and indexes all files found so that you may search quickly and easily for shared files. These files are created and made available individually by users whose identity we are not aware of and who we have no control over. In essence we function like a search engine tool; these files ARE NOT STORED OR SERVED BY OUR NETWORK. We are not responsible for any materials obtained by using our service. We do not monitor any of the contents of these files. These files may contain viruses, illegal materials, materials inappropriate for minors, offensive files and the like. BY USING OUR SERVICE, YOU ASSUME FULL RESPONSIBILITY FOR DOWNLOADING THESE MATERIALS AND WILL INDEMNIFY US FOR ANY DAMAGES THAT MAY BE INCURRED.

For More Specific Information VIEW OUR TERMS OF SERVICE.

Thank you and Enjoy!