WO2000027106A2 - Providing vcr functionality for data-centered video multicast - Google Patents

Providing vcr functionality for data-centered video multicast Download PDF

Info

Publication number
WO2000027106A2
WO2000027106A2 PCT/US1999/025422 US9925422W WO0027106A2 WO 2000027106 A2 WO2000027106 A2 WO 2000027106A2 US 9925422 W US9925422 W US 9925422W WO 0027106 A2 WO0027106 A2 WO 0027106A2
Authority
WO
WIPO (PCT)
Prior art keywords
point
segment
buffer
segments
video
Prior art date
Application number
PCT/US1999/025422
Other languages
French (fr)
Other versions
WO2000027106A3 (en
Inventor
Ibrahim Mostafa Kamel
Sarit Mukherjee
Zongming Fei
Original Assignee
Matsushita Electric Industrial Co., Ltd.
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 Matsushita Electric Industrial Co., Ltd. filed Critical Matsushita Electric Industrial Co., Ltd.
Priority to AU13306/00A priority Critical patent/AU1330600A/en
Publication of WO2000027106A2 publication Critical patent/WO2000027106A2/en
Priority to US09/578,739 priority patent/US6993787B1/en
Publication of WO2000027106A3 publication Critical patent/WO2000027106A3/en

Links

Classifications

    • 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/47End-user applications
    • H04N21/472End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content
    • H04N21/47208End-user interface for requesting content, additional data or services; End-user interface for interacting with content, e.g. for content reservation or setting reminders, for requesting event notification, for manipulating displayed content for requesting near-video-on-demand content
    • 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/41Structure of client; Structure of client peripherals
    • H04N21/426Internal components of the client ; Characteristics thereof
    • H04N21/42607Internal components of the client ; Characteristics thereof for processing the incoming bitstream
    • H04N21/4263Internal components of the client ; Characteristics thereof for processing the incoming bitstream involving specific tuning arrangements, e.g. two tuners
    • 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
    • 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/4335Housekeeping operations, e.g. prioritizing content for deletion because of storage space restrictions
    • 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/45Management operations performed by the client for facilitating the reception of or the interaction with the content or administrating data related to the end-user or to the client device itself, e.g. learning user preferences for recommending movies, resolving scheduling conflicts
    • H04N21/458Scheduling content for creating a personalised stream, e.g. by combining a locally stored advertisement with an incoming stream; Updating operations, e.g. for OS modules ; time-related management operations
    • 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/83Generation or processing of protective or descriptive data associated with content; Content structuring
    • H04N21/845Structuring of content, e.g. decomposing content into time segments
    • H04N21/8455Structuring of content, e.g. decomposing content into time segments involving pointers to the content, e.g. pointers to the I-frames of the video stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/16Analogue secrecy systems; Analogue subscription systems
    • H04N7/173Analogue secrecy systems; Analogue subscription systems with two-way working, e.g. subscriber sending a programme selection signal
    • H04N7/17309Transmission or handling of upstream communications
    • H04N7/17318Direct or substantially direct transmission and handling of requests

Definitions

  • the present invention relates generally to video on-demand multicasting.
  • the invention relates to a technique for providing VCR functionality (e.g., play, pause, fast forward, rewind, jump) in a data-centered video multicast or broadcast network.
  • VCR functionality e.g., play, pause, fast forward, rewind, jump
  • Video on-demand service promises to create an entire new dimension in home entertainment possibilities. Whereas current pay-per-view broadcasts are confined to specific broadcast times, video on-demand relaxes adherence to strict schedules. Customers are able to request a specific video, selected from a database of choices, and have the video delivered essentially instantaneously or, in the worse case, after only a brief delay. It is recognized that most requests for videos are from a small group of the currently most popular movies. Using multicast to send these movies is an efficient way to satisfy customer demand.
  • the server allocates channels to a movie or to a part of a movie.
  • a given channel broadcasts a movie repeatedly in cycles.
  • Pyramid broadcasting divides a movie into segments of exponentially increasing size and lets each channel broadcast each segment repeatedly. The segment is broadcast in the channel at a faster speed than playback speed.
  • Skyscraper broadcasting modifies the pyramid approach, using a different distribution of segment sizes and broadcasting at the same speed as playback speed.
  • Skyscraper broadcasting places an upper bound on the maximum weight of the segment size. This is done to reduce storage requirements at the client side (user).
  • the number of multicast channels required does not depend on the number of requests from users.
  • the data-centered approach appears to be more scalable than the user-centered approach.
  • the multicast approach to supplying video on-demand from several users at one time sacrifices special requirements of each individual user.
  • the multicast systems usually require the client to wait for a certain period before it can be served. This is referred to as the startup latency for the services.
  • VCR functions such as pause, fast forward, fast rewind and jump to new location are difficult to provide in data-centered multicast systems.
  • the solutions offered to date have not been able to provide scalability while at the same time guaranteeing seamless delivery.
  • the size of the system is scaled up, it becomes increasingly more difficult to provide seamless operation. Thus users experience jumpiness or breaks in delivery that detract from the enjoyment of the system.
  • the present invention proposes a new scheme which can provide VCR functionality in data-centered multicast video on-demand systems.
  • the scheme is scalable and is far more able to guarantee smooth, discontinuity-free delivery.
  • the system employs separate buffers at each client, from which media content may be played back to support VCR functionality.
  • a loader associated with each buffer downloads segments of the video stream from the video data server under control of a pre-fetch manager that intelligently determines what to pre-fetch into the buffer. The pre-fetch manager does this by monitoring the playback position pointer and controls the pre-fetching operation to maintain the playback position pointer within a predetermined range within the buffer.
  • the system also employs a calculation of feasible points based on a set of predefined rules. These feasible points are used in determining which operations are performed in a seamless fashion and also to identify when seamless operation may not be possible. In the latter case, appropriate user- friendly performance is initiated so that the user does not experience undue jerkiness or long delays or gaps in media delivery.
  • FIG. 1 is block diagram of the presently preferred embodiment for providing VCR functionality
  • Figure 2 illustrates a first broadcasting scenario, demonstrating how discontinuity occurs in the case of an unrestricted jump
  • Figure 3 illustrates a similar broadcasting scenario, showing how discontinuity can occur in the case of a fastforward action
  • Figure 4 illustrates Case 1 of the presently preferred set of rules for assessing feasible points
  • Figure 5 illustrates Case 2 of the presently preferred rules for determining feasible points
  • Figure 6 illustrates Case 3 of the presently preferred rules for assessing feasible points
  • Figure 7 is an example showing how the feasible point analysis is performed in accordance with the presently preferred embodiment.
  • FIG. 1 A presently preferred embodiment of the system is illustrated in Figure 1.
  • the system includes a player module 10 that provides an associated user interface 12 by which the user can select among a set of VCR functions. Illustrated in Figure 1 are the following functions: jump backward 14, fast rewind
  • VCR functions are exemplary of the type of functions that may be provided in a consumer product. Of course, other functions may also be provided, if desired. For instance, a jog shuttle mechanism may be provided to allow the user to move forward or backward through successive frames of the video content.
  • a stop function may also be included.
  • the pause function 18 provides nearly the same functionality as a stop function would. This is so because, unlike in a mechanical
  • VCR VCR
  • pause and stop functions may be included, in which case the pause function might provide a freeze-frame function while the stop function would blank the screen, for example.
  • Player 10 accepts VCR commands from the user interface and plays back the video stream through a suitable monitor 30. Player 10 obtains the video stream from one or more buffers 32. In the presently preferred embodiment there is a loader module 34 associated with each buffer. The loader module is responsible for interfacing with the distribution network 36 to download the required video content, as will be more fully described below.
  • the loader modules are controlled by a manager module 38 that is responsible for implementing the selective downloading strategy of the system. As will be more fully described below, the manager is able to access the playback pointer 40 of player 10. This pointer shows the current playback location within the buffer 32 that is currently supplying the video stream to the player for display on the monitor 30.
  • the manager module 38 includes a feasible point calculation module or calculation processor 42 that is responsible for assessing which user-requested functions may result in discontinuous service. The feasible point calculation module thus supplies manager 38 with the information needed to interpret the user's request in a modified fashion if the original request would result in undesirable playback (e.g., jumpy or discontinuous playback or long delay).
  • the manager 38 of the preferred embodiment causes loaders 34 to load information into the buffers in two phases.
  • the first phase is a pyramid phase (unequal segments) during which all loaders are used to download information to guarantee smooth playback in the normal forward direction.
  • manager 38 gradually phases the loaders 34 into the equal segment phase.
  • some of the segments may be fetched to support playback of backward segments (i.e., content that precedes the current playback pointer).
  • the manager selects the channels and segments to be loaded based on the current playback segment, as designated by the playback pointer 40.
  • the manager 38 assigns priority to each segment based on its proximity to the current segment and also based on whether loading is in the initial pyramid phase or in the later equal segment phase.
  • the current segment is k. If k is one of the pyramid phase segments, the first three segments in the forward direction (k, k+1 , k+2) are assigned the highest priority. If k is one of the equal phase segments, the highest priority segments are the current segment k and those that immediately precede and follow it (k, k+1 , k-1 ). The priorities of the remaining segments are determined by their distance from the current segment. The nearer to the current segment the higher its priority. In case of ties, the tie is broken in favor of the segment in the forward direction. If there are more than three loaders and buffers, allocation is based on the priority of the segment.
  • manager 38 allocates or reallocates the loaders into situations: (a) startup and (b) after performing a VCR action.
  • the playback pointer lies at the boundary of the first segment to be played. Note that the boundaries of all segments are also boundaries of the first segment at startup. At this boundary both de-allocation and allocation can occur. If a loader finishes loading a segment, it is returned to the free loader pool (de-allocation). This de-allocation process is voluntary by the loader. Allocation can also occur after de-allocation.
  • the three loaders are allocated to the next unassigned segments in line.
  • the three loaders are assigned to segments k-1 , k, k+1. If the play point is in the latter half of the current segment, the three loaders are assigned to segments k, k+1 , k+2. If the contents of the segment to be played is already in the buffer no loading occurs for that segment. Later downloading segments may overwrite earlier segments already in the buffer. However, if the playpoint is in to-be-overwritten segment in the buffer, the manager 38 prevents it from being overwritten beyond the playpoint. We call this playpoint protection.
  • the manager checks whether the loaders are assigned to k, k+1 , k+2. If this is the case, no actions are taken. Otherwise, the manager will enforce preemptively the assignment.
  • the equal segment phase if the playpoint is inside the buffer, no actions are taken. The relative position of the playpoint is adjusted when the downloading point (channel broadcast point) comes to the boundaries of the equal segments. If the playpoint goes outside the buffer (the current segment assumed to be k), the manager reallocates the loaders to segments k, k+1 and k-1. This may cause an involuntary de-allocation of loaders.
  • the manager 38 of the preferred embodiment controls the loading of buffers 32, based on the playback pointer 40, striving to maintain the playback pointer within a pre-determined range within the buffer.
  • the manager causes information to be fetched and stored in the buffers so that the playback pointer remains at or near the center of the buffer after the initial pyramid phase loading is completed. Doing this allows the system to provide continuous VCR functionality with a very high probability that the user's request can be smoothly carried out.
  • the present system empowers the client to actively pre-fetch nearby frames around the playback point and to locally manufacture the contents required to implement most VCR actions by appropriately accessing the local buffers 32.
  • manager 38 includes a feasible point calculation module 42.
  • the preferred implementation employs a set of rules to decide whether a given destination point is feasible or not, and how to respond accordingly.
  • the system strives to guarantee that the user can jump to a desired destination point p and then resume normal playback to the end of the movie without discontinuity.
  • not all points are feasible points. For example, as illustrated in Figure 2, an unrestricted jump can lead to discontinuities of later playback even if there is no subsequent VCR action.
  • FIG. 2 illustrates, assume that a user issues a VCR action to jump to position c of segment k outside of the client's buffer and that the channel k happens to broadcast at point c. If the jump is allowed, after an elapse of time t, the buffer will only have c k e k and c k+1 d, however the client needs to playback from e k (or b k+1 ) to c k+1 , which is not available and results in discontinuous playback. Even if the video frame contents are in the buffer, some VCR actions can lead to discontinuity after normal play is resumed.
  • Figure 3 illustrates this. In Figure 3 a fastforward action is initiated. Assume that the channel broadcasting point is c, for channel i.
  • channel k The contents of channel k are in the buffer and contents of channel k+1 are not in the buffer.
  • the current playback point is b k . If a fastforward command is issued with length of e k e k , all the contents are in the buffer. Assume that the fastforward of this length takes time t. If the system performs this action to the full length, it will take time t to the playback position of e k . At this point, only b k e k and c k+1 d in the buffer, but b k+1 c k+1 is needed to continue normal play and is not available.
  • the feasible point calculation module determines whether a given point is feasible or not and then determines how to find the nearest point that is feasible.
  • p is feasible: otherwise, if b k+1 c k+1 is in the buffer, the later nearest feasible point is the point q such that qc k are in the buffer with the smallest q value; if b k+1 c k+1 is not in the buffer, the later nearest feasible point is the point q such that qc k+1 are in the buffer with the smallest q value; case 2.2 c k ⁇ c k+1 . This is case in which the broadcasting position of channel k is not the same as channel k + 1 , or they are left aligned.
  • Figure 7 shows an example how to determine the feasible point in this case.
  • the destination point is p, which is later than the broadcasting point c 7 .
  • pc k to represent pe 7 and b 8 c 8 .
  • p is a feasible point in case (a).
  • p is not a feasible point and the nearest feasible point is d because b k+1 c k+1 is in the buffer and d is the smallest value such that dc k is in the buffer.
  • the feasible point calculations allow the user to specify an arbitrary destination within the video-on-demand data stream.
  • the system automatically adjusts the destination to a nearby feasible point, if the point requested by the user is not feasible. Thus, when the destination is not in the buffer, only those destination frames that are being broadcast at each channel are available immediately.
  • the feasible point calculation module assesses what is possible and selects the nearest frame among those available as the adjusted destination if the requested destination cannot be met. If the feasible point calculation module determines that the requested frame is feasible, we call this an allowed destination. If the feasible point calculation module determined that the requested frame cannot be met without discontinuity, it substitutes a different frame that can be met. We call this the adjusted destination.
  • One desirable property of the destination is that once the client resumes normal play from this destination, the client is able to playback to the end of the video without experiencing interruptions, provided there are no further VCR actions.
  • the system designer may wish to specify the number of buffers used at each client. To implement a robust VCR-oriented scheme, two conditions should be preferably met:
  • the segments sized must be equal to the size of the next segment in order to guarantee that the client can playback the next segment when it finishes playing the current segment.
  • Equation 1 presents the function f(n) that will satisfy the above two conditions.
  • the equation assumes that a client can download from m channels simultaneously.
  • m 5: 1 , 2, 4, 8, 16, 16, 32, 64, 128, 256, 256, 512, 1024, 2048, 4096,...
  • m the value of m (simultaneously available channels) places a minimum requirement on the bandwidth needed at each client. Considering the heterogeneity of the client, we like m to be small.
  • clients download both the next segment for forward VCR action and the previous segment for backward VCR action. These segments are fetched in addition to the current segment.
  • the value of m is preferably 3 or greater.
  • m 3 to illustrate both forward and backward VCR functionality.
  • the value selected for m can be greater than 3 while still preserving the benefit of supporting both forward and backward action.
  • ⁇ I,/ (») In operation, when a client downloads video segments from the broadcast channels, we shall assume that at the outset no VCR functions are invoked and the video is to proceed at the beginning of the program. At the beginning, three loaders wait until the boundary of the first segment is detected. This waiting time is the startup latency and the maximum waiting time will be the time required to playback the first segment.
  • the first loader begins to download from the first channel and contents of its buffer are played.
  • the other two loaders are assigned to the second and third channels, respectively. Depending on the relative positions of each channel, the loader may download from the second channel at the beginning or at the end of the first segment. Similarly, the loader may download from the third channel at the beginning or end of the second segment.
  • the foregoing system is thus able to provide smooth, continuous playback while supporting all popular VCR functions.
  • the number of buffers employed at a client location can vary.
  • the number of loaders used to service the buffer population can also vary. While a one-to-one correspondence between buffers and loaders is presently preferred, some implementations may be able to provide adequate throughput with fewer loaders than buffers.

Abstract

The client application provides VCR functionality in a data-centered video multicast network (36) through active prefetching of the fragments from broadcast channels. The player (10) has a user interface (12) that supports a plurality of VCR functions (14-26). Plural buffers (32) and their associated loaders (34) download video data under control of a manager module (38). The manager module accesses the playback pointer (40) and employs feasible point calculation module (42) to cause the loaders to selectively download segments so that VCR functions can be supported while maintaining continuous playback after the VCR function is performed.

Description

PROVIDING VCR FUNCTIONALITY FOR DATA-CENTERED VIDEO MULTICAST
BACKGROUND AND SUMMARY OF THE INVENTION The present invention relates generally to video on-demand multicasting.
More particularly, the invention relates to a technique for providing VCR functionality (e.g., play, pause, fast forward, rewind, jump) in a data-centered video multicast or broadcast network.
Video on-demand service promises to create an entire new dimension in home entertainment possibilities. Whereas current pay-per-view broadcasts are confined to specific broadcast times, video on-demand relaxes adherence to strict schedules. Customers are able to request a specific video, selected from a database of choices, and have the video delivered essentially instantaneously or, in the worse case, after only a brief delay. It is recognized that most requests for videos are from a small group of the currently most popular movies. Using multicast to send these movies is an efficient way to satisfy customer demand. Currently there are two basic approaches to providing multicast video on-demand. In the user-centered approach, the server allocates channels to one user or to a group of users and then sends the movie over the allocated channel or channels. In early unicast systems (a special case of multicast, with one user per group) a single channel was allocated for each user. More recent multicast systems allocate one channel to support several users.
In the data-centered approach, the server allocates channels to a movie or to a part of a movie. Through periodic broadcasts, a given channel broadcasts a movie repeatedly in cycles. Conventionally there are several different schemes for broadcasting in the data-centered paradigm. Pyramid broadcasting divides a movie into segments of exponentially increasing size and lets each channel broadcast each segment repeatedly. The segment is broadcast in the channel at a faster speed than playback speed. Skyscraper broadcasting modifies the pyramid approach, using a different distribution of segment sizes and broadcasting at the same speed as playback speed. Skyscraper broadcasting places an upper bound on the maximum weight of the segment size. This is done to reduce storage requirements at the client side (user). The number of multicast channels required does not depend on the number of requests from users. Thus the data-centered approach appears to be more scalable than the user-centered approach.
The multicast approach to supplying video on-demand from several users at one time, to some extent, sacrifices special requirements of each individual user. The multicast systems usually require the client to wait for a certain period before it can be served. This is referred to as the startup latency for the services. VCR functions such as pause, fast forward, fast rewind and jump to new location are difficult to provide in data-centered multicast systems. Although there have been attempts to provide VCR functionality, the solutions offered to date have not been able to provide scalability while at the same time guaranteeing seamless delivery. Typically, as the size of the system is scaled up, it becomes increasingly more difficult to provide seamless operation. Thus users experience jumpiness or breaks in delivery that detract from the enjoyment of the system.
The present invention proposes a new scheme which can provide VCR functionality in data-centered multicast video on-demand systems. The scheme is scalable and is far more able to guarantee smooth, discontinuity-free delivery. The system employs separate buffers at each client, from which media content may be played back to support VCR functionality. A loader associated with each buffer downloads segments of the video stream from the video data server under control of a pre-fetch manager that intelligently determines what to pre-fetch into the buffer. The pre-fetch manager does this by monitoring the playback position pointer and controls the pre-fetching operation to maintain the playback position pointer within a predetermined range within the buffer.
The system also employs a calculation of feasible points based on a set of predefined rules. These feasible points are used in determining which operations are performed in a seamless fashion and also to identify when seamless operation may not be possible. In the latter case, appropriate user- friendly performance is initiated so that the user does not experience undue jerkiness or long delays or gaps in media delivery. For a more complete understanding of the invention, its objects and advantages, refer to the following specification and to the accompanying drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
Figure 1 is block diagram of the presently preferred embodiment for providing VCR functionality;
Figure 2 illustrates a first broadcasting scenario, demonstrating how discontinuity occurs in the case of an unrestricted jump; Figure 3 illustrates a similar broadcasting scenario, showing how discontinuity can occur in the case of a fastforward action;
Figure 4 illustrates Case 1 of the presently preferred set of rules for assessing feasible points;
Figure 5 illustrates Case 2 of the presently preferred rules for determining feasible points;
Figure 6 illustrates Case 3 of the presently preferred rules for assessing feasible points;
Figure 7 is an example showing how the feasible point analysis is performed in accordance with the presently preferred embodiment.
DESCRIPTION OF THE PREFERRED EMBODIMENT
A presently preferred embodiment of the system is illustrated in Figure 1.
The system includes a player module 10 that provides an associated user interface 12 by which the user can select among a set of VCR functions. Illustrated in Figure 1 are the following functions: jump backward 14, fast rewind
16, pause 18, play 20, slow motion play 22, fast forward 24 and jump forward 26.
These VCR functions are exemplary of the type of functions that may be provided in a consumer product. Of course, other functions may also be provided, if desired. For instance, a jog shuttle mechanism may be provided to allow the user to move forward or backward through successive frames of the video content.
Also note that a stop function may also be included. However, in the presently preferred implementation, the pause function 18 provides nearly the same functionality as a stop function would. This is so because, unlike in a mechanical
VCR, there is no requirement to unload the tape from the tape head or to halt the tape drive motors and capstan. Nevertheless, if desired, both pause and stop functions may be included, in which case the pause function might provide a freeze-frame function while the stop function would blank the screen, for example.
Player 10 accepts VCR commands from the user interface and plays back the video stream through a suitable monitor 30. Player 10 obtains the video stream from one or more buffers 32. In the presently preferred embodiment there is a loader module 34 associated with each buffer. The loader module is responsible for interfacing with the distribution network 36 to download the required video content, as will be more fully described below.
The loader modules are controlled by a manager module 38 that is responsible for implementing the selective downloading strategy of the system. As will be more fully described below, the manager is able to access the playback pointer 40 of player 10. This pointer shows the current playback location within the buffer 32 that is currently supplying the video stream to the player for display on the monitor 30. The manager module 38 includes a feasible point calculation module or calculation processor 42 that is responsible for assessing which user-requested functions may result in discontinuous service. The feasible point calculation module thus supplies manager 38 with the information needed to interpret the user's request in a modified fashion if the original request would result in undesirable playback (e.g., jumpy or discontinuous playback or long delay).
When the client wishes to download video segments from a broadcast channel on network 36, the manager 38 of the preferred embodiment causes loaders 34 to load information into the buffers in two phases. The first phase is a pyramid phase (unequal segments) during which all loaders are used to download information to guarantee smooth playback in the normal forward direction. Once the buffers 32 have been loaded to support the initial forward play mode, manager 38 gradually phases the loaders 34 into the equal segment phase. In the equal segment phase, some of the segments may be fetched to support playback of backward segments (i.e., content that precedes the current playback pointer).
The manager selects the channels and segments to be loaded based on the current playback segment, as designated by the playback pointer 40. The manager 38 assigns priority to each segment based on its proximity to the current segment and also based on whether loading is in the initial pyramid phase or in the later equal segment phase.
To illustrate, assume the current segment is k. If k is one of the pyramid phase segments, the first three segments in the forward direction (k, k+1 , k+2) are assigned the highest priority. If k is one of the equal phase segments, the highest priority segments are the current segment k and those that immediately precede and follow it (k, k+1 , k-1 ). The priorities of the remaining segments are determined by their distance from the current segment. The nearer to the current segment the higher its priority. In case of ties, the tie is broken in favor of the segment in the forward direction. If there are more than three loaders and buffers, allocation is based on the priority of the segment.
We will further consider here the special case where there are only three loaders and buffers. In this case manager 38 allocates or reallocates the loaders into situations: (a) startup and (b) after performing a VCR action.
In the startup situation the playback pointer lies at the boundary of the first segment to be played. Note that the boundaries of all segments are also boundaries of the first segment at startup. At this boundary both de-allocation and allocation can occur. If a loader finishes loading a segment, it is returned to the free loader pool (de-allocation). This de-allocation process is voluntary by the loader. Allocation can also occur after de-allocation.
During the pyramid phase, the three loaders are allocated to the next unassigned segments in line. During the equal segment phase, if the play point is in the earlier half of the current segment (the current segment being designated segment k), the three loaders are assigned to segments k-1 , k, k+1. If the play point is in the latter half of the current segment, the three loaders are assigned to segments k, k+1 , k+2. If the contents of the segment to be played is already in the buffer no loading occurs for that segment. Later downloading segments may overwrite earlier segments already in the buffer. However, if the playpoint is in to-be-overwritten segment in the buffer, the manager 38 prevents it from being overwritten beyond the playpoint. We call this playpoint protection. In the second situation (after every VCR action is performed) a somewhat different sequence proceeds. During the pyramid phase, the manager checks whether the loaders are assigned to k, k+1 , k+2. If this is the case, no actions are taken. Otherwise, the manager will enforce preemptively the assignment. During the equal segment phase, if the playpoint is inside the buffer, no actions are taken. The relative position of the playpoint is adjusted when the downloading point (channel broadcast point) comes to the boundaries of the equal segments. If the playpoint goes outside the buffer (the current segment assumed to be k), the manager reallocates the loaders to segments k, k+1 and k-1. This may cause an involuntary de-allocation of loaders. The manager 38 of the preferred embodiment controls the loading of buffers 32, based on the playback pointer 40, striving to maintain the playback pointer within a pre-determined range within the buffer. In the presently preferred embodiment, the manager causes information to be fetched and stored in the buffers so that the playback pointer remains at or near the center of the buffer after the initial pyramid phase loading is completed. Doing this allows the system to provide continuous VCR functionality with a very high probability that the user's request can be smoothly carried out. In contrast with other schemes, the present system empowers the client to actively pre-fetch nearby frames around the playback point and to locally manufacture the contents required to implement most VCR actions by appropriately accessing the local buffers 32.
To account for situations in which a user's VCR command may not be feasible, manager 38 includes a feasible point calculation module 42. The preferred implementation employs a set of rules to decide whether a given destination point is feasible or not, and how to respond accordingly. To provide high quality VCR functionality and seamless playback, the system strives to guarantee that the user can jump to a desired destination point p and then resume normal playback to the end of the movie without discontinuity. Given the particular channel broadcasting situation and the buffer conditions at the client, not all points are feasible points. For example, as illustrated in Figure 2, an unrestricted jump can lead to discontinuities of later playback even if there is no subsequent VCR action. As Figure 2 illustrates, assume that a user issues a VCR action to jump to position c of segment k outside of the client's buffer and that the channel k happens to broadcast at point c. If the jump is allowed, after an elapse of time t, the buffer will only have ck ek and ck+1 d, however the client needs to playback from ek (or bk+1) to ck+1, which is not available and results in discontinuous playback. Even if the video frame contents are in the buffer, some VCR actions can lead to discontinuity after normal play is resumed. Figure 3 illustrates this. In Figure 3 a fastforward action is initiated. Assume that the channel broadcasting point is c, for channel i. The contents of channel k are in the buffer and contents of channel k+1 are not in the buffer. The current playback point is bk. If a fastforward command is issued with length of ek ek, all the contents are in the buffer. Assume that the fastforward of this length takes time t. If the system performs this action to the full length, it will take time t to the playback position of ek. At this point, only bk ek and ck+1 d in the buffer, but bk+1 ck+1 is needed to continue normal play and is not available. To address the issues illustrated in Figures 2 and 3, the feasible point calculation module determines whether a given point is feasible or not and then determines how to find the nearest point that is feasible. The presently preferred embodiment distinguishes three following cases according to the relative size of the segments involved. Assume that the size of segment i is sr The beginning position and end position of segment i and b, and e„ respectively. We assume that b, = 0 for all 1 <_ i < K. At any time each channel is broadcasting a specific frame in the segment. This point is denoted as c, and we have b^c.≤.e,.
If the destination point p is located at or before the channel point c„ we call the segment containing the desired destination current segment and we assume it is segment k and broadcast in channel k. First we give the rules for this case. After that, we consider the cased in which the destination point p is located after the channel point c,.
• Case 1 (Figure 4): sk = sk+1. This is the case in which the size of the current segment is equal to the size of the next segment. It is abbreviated as (x, x) case.
If pck is in the buffer, then p is feasible; otherwise, the later nearest feasible point is the point q such that qck are in the buffer with the smallest q value.
• Case 2 (Figure 5): sk+1 = 2 * sk and sk+2 = sk+1. This is the case in which the size of the current segment is half of the size of the next segment and the next two segments are of equal size. It is abbreviated as (x, 2x, 2x) case. case 2.1 ck = ck+1. This is case in which the broadcasting position of channel k is the same as channel k + 1 , or they are left aligned.
If pck and bk+1ck+l are in the buffer, then p is feasible: otherwise, if bk+1ck+1 is in the buffer, the later nearest feasible point is the point q such that qck are in the buffer with the smallest q value; if bk+1ck+1 is not in the buffer, the later nearest feasible point is the point q such that qck+1 are in the buffer with the smallest q value; case 2.2 ck ≠ ck+1. This is case in which the broadcasting position of channel k is not the same as channel k + 1 , or they are left aligned.
If pck is in the buffer, then p is feasible; otherwise, the later nearest feasible point is the point q such that qck are in the buffer with the smallest q value.
• Case 3 (Figure 6): sk+1 = 2 * sk+1 and sk+2 = 2 * sk+1. This is the case in which the size of the current segment is half of the next segment and the size of next segment is in turn half of the size of its next segment. It is abbreviated as (x, 2x, 4x) case. case 3.1 ck = ck+1= ck+2. This is case in which the broadcasting position of channels k, k + 1 and k + 2 are the same, or they are left aligned.
If pck, bk+1ck+1 and bk+2ck+2 are in the buffer, then p is feasible; otherwise, if bk+1ck+1 and bk+2ck+2 are in the buffer, the later nearest feasible point is the point q such that qck are in the buffer with the smallest q value; if bk+2ck+2 is in the buffer and bk+1ck+1 is not all in the buffer, the later nearest feasible point is in the point q such that qck+1 is in the buffer with the smallest q value: if bk+1ck+1 is not in the buffer, the later nearest feasible point is the point q such that qck+2 is in the buffer with the smallest q value: case 3.2 ck = ck+1 ≠ ck+2. This is case in which the broadcasting position of channels k, k + 1 are the same, but not the same as that of channel k + 2.
If pck, bk+1ck+1 are in the buffer, then p is feasible; otherwise, if bk+1ck+1 is in the buffer, the later nearest feasible point is the point q such that qck is in the buffer with the smallest q value; if bk+1ck+1 is not all in the buffer, the later nearest feasible point is the point q such that qck+1 is in the buffer with the smallest q value: if bk+1ck+1 is not in the buffer, the later nearest feasible point is the point q such that qck+1 is in the buffer with the smallest q value. - case 3.3 ck ≠ ck+1 ≠ ck+2. This is case in which the broadcasting position of channels k + 1 , k + 2 are the same, but not the same as that of channel k.
If pck, bk+2ck+2 are in the buffer, then p is feasible; otherwise, if bk+2ck+2is in the buffer, the later nearest feasible point is the point q such that qck is in the buffer with the smallest q value; if bk+2ck+2 is not all in the buffer, the later nearest feasible point is the point q such that qck+2 is in the buffer with the smallest q value. case 3.4 ck ≠ ck+1 ≠ ck+2. This is case in which the broadcasting position of channels k, k +1 and k + 2 are all different, or they are all right-aligned. If pck is in the buffer, then p is feasible; otherwise, the later nearest feasible point is the point q such that qck are in the buffer with the smallest q value.
If the destination point p is located after the channel point c„ the next segment to the one that contains the desired destination is called the current segment. We assume it is segment k. In this situation, pck means pe^ and bkck. After this modification, we can use the above rules.
Figure 7 shows an example how to determine the feasible point in this case. Assume the destination point is p, which is later than the broadcasting point c7. So the current segment should be k = 8. Since the segment size of current segment is half next segment and next two segments are of equal size, this is the case 2.1 of the above rule. As stated above, we use pck to represent pe7 and b8c8. According to the rule 2.1 , p is a feasible point in case (a). In case (b), p is not a feasible point and the nearest feasible point is d because bk+1ck+1 is in the buffer and d is the smallest value such that dck is in the buffer.
The feasible point calculations, described above, allow the user to specify an arbitrary destination within the video-on-demand data stream. The system automatically adjusts the destination to a nearby feasible point, if the point requested by the user is not feasible. Thus, when the destination is not in the buffer, only those destination frames that are being broadcast at each channel are available immediately. The feasible point calculation module assesses what is possible and selects the nearest frame among those available as the adjusted destination if the requested destination cannot be met. If the feasible point calculation module determines that the requested frame is feasible, we call this an allowed destination. If the feasible point calculation module determined that the requested frame cannot be met without discontinuity, it substitutes a different frame that can be met. We call this the adjusted destination.
One desirable property of the destination, either allowed or adjusted, is that once the client resumes normal play from this destination, the client is able to playback to the end of the video without experiencing interruptions, provided there are no further VCR actions. In developing an actual embodiment of the invention, the system designer may wish to specify the number of buffers used at each client. To implement a robust VCR-oriented scheme, two conditions should be preferably met:
(1 ) If the destination segment is not in the buffer, and we still require that we can always select the frame being broadcast at this channel as the destination, the segments sized must be equal to the size of the next segment in order to guarantee that the client can playback the next segment when it finishes playing the current segment.
(2) The sizes of all segments beginning from the latter of these two equal segments must satisfy the continuity condition that guarantees smooth playback of the remainder of the video will be possible, assuming the client can download from m channels simultaneously.
Equation 1 below presents the function f(n) that will satisfy the above two conditions. The equation assumes that a client can download from m channels simultaneously.
Equation 1
/(") = 2
As an example, we give below the series generated by f(n) with m = 5: 1 , 2, 4, 8, 16, 16, 32, 64, 128, 256, 256, 512, 1024, 2048, 4096,... In designing a system, the value of m (simultaneously available channels) places a minimum requirement on the bandwidth needed at each client. Considering the heterogeneity of the client, we like m to be small. On the other hand, in order to pre-fetch nearby segments of the current playback segment, clients download both the next segment for forward VCR action and the previous segment for backward VCR action. These segments are fetched in addition to the current segment. Thus in the presently preferred embodiment the value of m is preferably 3 or greater. If fewer than 3 channels are available simultaneously, then the system will have to sacrifice in supporting forward or backward VCR functionality. Thus in the preceding example, we have used m = 3 to illustrate both forward and backward VCR functionality. Of course, in a practical implementation, the value selected for m can be greater than 3 while still preserving the benefit of supporting both forward and backward action.
Given that the series dictated by Equation 1 is monotonically increasing and is bounded by f(u) = f(K), we determine the buffer requirement for a client to be the size of the largest segment minus one size unit. Thus the buffer requirement may be expressed as a function of f(n) as follows:
Equation 2
7, rr f(u)xL
Buffer = - ^- '
ΣI,/(») In operation, when a client downloads video segments from the broadcast channels, we shall assume that at the outset no VCR functions are invoked and the video is to proceed at the beginning of the program. At the beginning, three loaders wait until the boundary of the first segment is detected. This waiting time is the startup latency and the maximum waiting time will be the time required to playback the first segment. The first loader begins to download from the first channel and contents of its buffer are played. The other two loaders are assigned to the second and third channels, respectively. Depending on the relative positions of each channel, the loader may download from the second channel at the beginning or at the end of the first segment. Similarly, the loader may download from the third channel at the beginning or end of the second segment. When the contents of the buffers are played they are immediately discarded. Whenever a loader finishes downloading the assigned channel, it is assigned to the next immediate unassigned channel. It begins downloading from the channel when the length of the contents in its buffer is less than the assigned channel segment size. This guarantees that downloading of a segment is delayed as much as possible to save buffer space, but it also guarantees smooth playback of that segment.
The foregoing system is thus able to provide smooth, continuous playback while supporting all popular VCR functions. While the invention has been described in its presently preferred embodiments, it will be understood that the invention is capable of modification without departing from the spirit of the invention as set forth in the appended claims. For example, the number of buffers employed at a client location can vary. Also, the number of loaders used to service the buffer population can also vary. While a one-to-one correspondence between buffers and loaders is presently preferred, some implementations may be able to provide adequate throughput with fewer loaders than buffers.

Claims

CLAIMSWhat is claimed is:
1. A system for supporting at least one VCR function in a network- based video-on-demand delivery system, comprising: a player having a user interface that provides at least one user- actuable VCR function initiator, said player being adapted for coupling to a display monitor to supply a video stream to said monitor for playback; said player maintaining at least one playback pointer that provides information indicative of the current video playback frame; at least one buffer coupled to said player having an associated loader for downloading video data from said delivery system; a manager coupled to said player and to said loader for selectively causing said loader to download video data from said delivery system in order to maintain said playback pointer within a predetermined location range within said buffer.
2. The system of claim 1 further comprising a plurality of buffers each being selectively loaded with video data under control of said manager such that at least a one of said buffers contains video data that precedes the current video playback frame.
3. The system of claim 2 wherein each of said buffers has an associated loader responsible for supplying that buffer with downloaded video data.
4. The system of claim 1 wherein said manager includes a feasible point calculation module that assesses whether the destination point resulting from a selected user interaction with said VCR function initiator will result in discontinuous playback.
5. The system of claim 4 wherein said manager is responsive to said feasible point calculation module to modify a requested VCR function such that said function will not result in discontinuous playback.
6. The system of claim 1 wherein said user interface provides VCR functions selected from the group consisting of: jump backward, fast rewind, pause, stop, play, slow motion play, fast forward and jump forward.
7. The system of claim 1 further comprising at least three buffers coupled to said player.
8. The system of claim 1 further comprising at least three buffers coupled to said player, each buffer having an associated loader.
9. The system of claim 1 wherein said manager implements at least two different downloading schemes, including a first scheme for loading said buffer upon startup and a second scheme for loading said buffers after startup.
10. The system of claim 1 further comprising at least three buffers coupled to said player and wherein said manager implements at least two different downloading schemes, including:
(a) a first downloading scheme in which a first one of said buffers is loaded with a first segment and the second and third of said buffers are respectively loaded with second and third segments that each follow the first segment;
(b) a second downloading scheme in which a first one of said buffers is loaded with a first segment, a second of said buffers is loaded with a second segment that precedes the first segment, and a third of said buffers is loaded with a third segment that follows said first segment.
11. A Video-on Demand client system to prefetch segments of video data streams through multiple communications channels of data-centered broadcasting network from a video data server for implementing VCR functions including at least playback the segments, said client system comprising: at least one loader to download the segments of the video stream from the video data server; at least one buffer to store the downloaded segments from said loader; a player to playback the segments read from said buffer, said player being responsive to VCR function commands given through user- interface thereof; a playback pointer to issue playback commands to said player for designating a playback starting point of the segment in said buffer; and a prefetch manager to issue prefetch commands to said loader for prefetching the segments from the server based on the current playback point of the segment in said buffer so as to keep the playback point designated by said pointer within predetermined range of said buffer.
12. The client system as in claim 11 , wherein the predetermined range of said buffer is a middle part thereof.
13. The client system as in claim 11, wherein each number of said loaders and said buffers are respectively at least three.
14. The client system as in claim 11 , the VCR function given through the user-interface of said player including normal play which playbacks the segments of the video streams at normal speed, fast forward which playbacks the segments at multiple times speed as normal play in forward direction, fast backward which playbacks the segments at multiple times speed as the normal play in backward direction, slow forward which playbacks the segment slower than the normal play in forward direction, pause which playbacks stationary with keeping the current playback point, jump forward which jumps directory to the destination point of the segment specified in terms of forward distance relative to the current playback point and resumes the normal play from the jumped point, and jump backward which jumps directory to the destination point of the segment specified in terms of backward distance relative to the current playback point and resumes the normal play from the jumped point.
15. The client system as in claim 11 , wherein according to size of the broadcasting segment through the channels of the network from the server to the client, said playback pointer designates the feasible playback starting point for a destination frame point p of the segment designated by VCR function commands.
16. The client system as in claim 15, where
• k is defined as natural number;
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0, (1 <= k <= K);
• condition (a): the destination point p is located at or before broadcasting point c(k) of the segment k broadcasting in channel k; and
• condition (b): the size of the current broadcasting segment k equals to the size of next segment k+1 , wherein when the conditions (a) and (b) are satisfied, if frames between the destination point p and c(k) is in the buffer, then the point p is the feasible point, otherwise the later nearest point q that frames between points of q and c(k) are in the buffer is the feasible point having smallest point value.
17. The client system as in claim 15, where
• k is defined as natural number;
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0 as an offset value, (1 <= k <= K);
• condition (a): the destination point p is located at or before broadcasting point c(k) of the segment k broadcasting in channel k;
• condition (c): the size of the current broadcasting segment k is half of size of the next segment k+1 and the size of the next two segments k+1 and k+2; and
• condition (d): the point value of c(k) equals to the point value of c(k+1 ), wherein when the conditions (a), (c) and (d) are satisfied, if both frames between the destination point p and c(k) and frames between the point b(k+1 ) and c(k+1 ) are in the buffer, then the point p is the feasible point, otherwise: if frames between the points of b(k+1 ) and c(k+1 ) are in the buffer, then the later nearest point q that frames between q and c(k) is in the buffer is the feasible point having smallest point value, if frames between the points of b(k+1 ) and c(k+1 ) are not in the buffer, then the later nearest point q that frames between the points q and c(k+1 ) is in the buffer are the feasible point having smallest point value.
18. The client system as in claim 15, where
• k is defined as natural number;
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0 as an offset value, (1 <= k <= K);
• condition (a): the destination point p is located at or before broadcasting point c(k) of the segment k broadcasting in channel k;
• condition (c): the size of the current broadcasting segment k is half of size of the next segment k+1 and the size of the next two segments k+1 and k+2; and
• condition (e): the point value of c(k) does not equals to the point value of c(k+1 ), wherein when the conditions (a), (c) and (e) are satisfied, if both frames between the destination point p and c(k) are in the buffer, then the point p is the feasible point, otherwise the later nearest point q that frames between points of q and c(k) are in the buffer is the feasible point having smallest point value.
19. The client system as in claim 15, where
• k is defined as natural number,
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0 as an offset value, (1 <= k <= K);
• condition (a): the destination point p is located at or before broadcasting point c(k) of the segment k broadcasting in channel k;
• condition (f): the size of the current broadcasting segment k is half of size of the next segment k+1 and the size of the next segments k+1 is half of size of its next segment k+2; and
• condition (g): the point value of c(k) equals to the both point values of c(k+1 ) and c(k+2), wherein when the conditions (a), (f) and (g) are satisfied, if frames between the destination point p and c(k), frames between the point b(k+1 ) and c(k+1 ), and frames between the point b(k+2) and c(k+2) are in the buffer, then the point p is the feasible point, otherwise: if frames between the point b(k+1 ) and c(k+1), and frames between the point b(k+2) and c(k+2)are in the buffer, then the later nearest point q that frames between q and c(k) is in the buffer is the feasible point having smallest point value, if frames between the points of b(k+1 ) and c(k+1 ) are not all in the buffer, and frames between the point b(k+2) and c(k+2)are in the buffer, then the later nearest point q that frames between q and c(k+1 ) is in the buffer is the feasible point having smallest point value, if frames between the points of b(k+1 ) and c(k+1 ) are not in the buffer, then the later nearest point q that frames between the points q and c(k+2) are in the buffer is the feasible point having smallest point value.
20. The client system as in claim 15, where
• k is defined as natural number;
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0 as an offset value, (1 <= k <= K);
• condition (a): the destination point p is located at or before broadcasting point c(k) of the segment k broadcasting in channel k;
• condition (f): the size of the current broadcasting segment k is half of size of the next segment k+1 and the size of the next segments k+1 is half of size of its next segment k+2; and
• condition (h): the point value of c(k) equals to the both point values of c(k+1 ) and does not equal to c(k+2), wherein when the conditions (a), (f) and (h) are satisfied, if frames between the destination point p and c(k), and frames between the point b(k+1 ) and c(k+1 ) are in the buffer, then the point p is the feasible point, otherwise: if frames between the point b(k+1 ) and c(k+1 ) are in the buffer, then the later nearest point q that frames between q and c(k) is in the buffer is the feasible point having smallest point value, if frames between the points of b(k+1 ) and c(k+1 ) are not all in the buffer, then the later nearest point q that frames between q and c(k+1 ) is in the buffer is the feasible point having smallest point value.
21. The client system as in claim 15, where
• k is defined as natural number;
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0 as an offset value, (1 <= k <= K);
• condition (a): the destination point p is located at or before broadcasting point c(k) of the segment k broadcasting in channel k;
• condition (f): the size of the current broadcasting segment k is half of size of the next segment k+1 and the size of the next segments k+1 is half of size of its next segment k+2; and
• condition (i): the point value of c(k) equals to the point values of c(k+2) and does not equal to c(k+1 ), wherein when the conditions (a), (f) and (i) are satisfied, if frames between the destination point p and c(k), and frames between the point b(k+2) and c(k+2) are in the buffer, then the point p is the feasible point, otherwise: if frames between the point b(k+2) and c(k+2) are in the buffer, then the later nearest point q that frames between q and c(k) is in the buffer is the feasible point having smallest point value, if frames between the points of b(k+2) and c(k+2) are not all in the buffer, then the later nearest point q that frames between q and c(k+2) is in the buffer is the feasible point having smallest point value.
22. The client system as in claim 15, where
• k is defined as natural number;
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0 as an offset value, (1 <= k <= K);
• condition (a): the destination point p is located at or before broadcasting point c(k) of the segment k broadcasting in channel k;
• condition (f): the size of the current broadcasting segment k is half of size of the next segment k+1 and the size of the next segments k+1 is half of size of its next segment k+2; and
• condition (j): the point value of c(k) does not equal to the both point values of c(k+1 ) and c(k+2), wherein when the conditions (a), (f) and (j) are satisfied, if frames between the destination point p and c(k) are in the buffer, then the point p is the feasible point, otherwise the later nearest point q that frames between q and c(k) is in the buffer is the feasible point having smallest point value.
23. The client system as in claim 15, where
• k is defined as natural number;
• b(k) is defined as a beginning frame point of segment No. k;
• e(k) is defined as an end frame point of segment No. k;
• c(k) is defined as a current broadcasting frame point of segment No. k;
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length;
• point value of b(k) equals to 0 as an offset value, (1 <= k <= K);
• condition (k): the destination point p is located after the current broadcasting point c (k) of the segment k broadcasting in channel k, wherein when the conditions (k) is satisfied, frames between the destination point p and c(k) are considered as frames between p and e(k-1 ) and frames between b(k) and c(k) so that the destination point p is considered to be located at or before broadcasting point c(k) of the segment k broadcasting in channel k.
24. A method of demanding segments of video data streams by a Video- on Demand client system through multiple communications channels of data- centered broadcasting network from a video data server for implementing VCR functions including at least playback the segments by a player of the client system, said method comprising the steps of:
(a) downloading the segments of the video stream from the video server to at least one loader;
(b) storing the downloaded segments of the loader at least one buffer for being read to playback by a player therefrom;
(c) issuing at least playback command to the player for designating a playback starting point of the segment in the buffer; and
(d) issuing prefetch commands to the loader for prefetching the segments from the server based on the current playback point of the segment so as to keep the playback point designated by said pointer within predetermined range of a buffer.
25. A method for supplying segments of video data streams to Video-on- Demand clients through multiple communications channels of data-centered broadcasting network from a video data server in a Video-on-Demand system, said method comprising: establishing the communications channel between the client and the server; dividing each video data stream into multiple sequential segments in accordance with equation: SIZE = {f(N)*L}/{sigma function of f(J), J=1~K}; where:
• SIZE is defined as size of segment No. N;
• N is defined as natural number;
• f(N) is defined as 2 to the power {N - (N/M)};
• M is defined as a number of channels being able to download the segments simultaneously;
• L is defined as length of a set of data streams of each video;
• J is defined as natural number; and
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length L, and transmitting the divided segments of each video multiple times to the clients through the multiple channels from the server.
26. The method of claim 25 further comprising the steps of : receiving at the Video-on-Demand client the transmitted segments from the server, playing the segments at the Video-on-Demand client; and concurrently with playing and receiving, storing the transmitted sequential segments at the Video-on-Demand client.
27. A Video-on Demand broadcasting system, said system comprising: a video data server to supply video data streams to multiple communications channels of data-centered broadcasting network;
Video-on-Demand clients through to receive segments of the video data streams through the network wherein after establishing the communications channel between the client and the server, said server having dividing means for dividing each video data stream into multiple sequential segments in accordance with equation:
SIZE = {f(N)*L}/{sigma function of f(J), J=1~K}; where:
• SIZE is defined as size of segment No. N;
• N is defined as natural number;
• f(N) is defined as 2 to the power {N - (N/M)};
• M is defined as a number of channels being able to download the segments simultaneously;
• L is defined as length of a set of data streams of each video;
• J is defined as natural number; and
• K is defined as numbers of channels and divided into segments of a set of video data streams of each video of length L, and transmitting means for transmitting the divided segments of each video multiple times to the clients through the multiple channels.
28. The system of claim 27 wherein the client having receiving means for receiving the transmitted segments from the server and playing means for playing the segments, and concurrently with playing and receiving, storing means for storing the transmitted sequential segments.
29. A video data server of the system as in claim 27.
30. A Video-on-Demand client of the system as in claims 27.
31. A Video-on-Demand client of the system as in claims 28.
PCT/US1999/025422 1998-10-29 1999-10-28 Providing vcr functionality for data-centered video multicast WO2000027106A2 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
AU13306/00A AU1330600A (en) 1998-10-29 1999-10-28 Providing vcr functionality for data-centered video multicast
US09/578,739 US6993787B1 (en) 1998-10-29 2000-05-25 Providing VCR functionality for data-centered video multicast

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10616798P 1998-10-29 1998-10-29
US60/106,167 1998-10-29

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US09/578,739 Continuation US6993787B1 (en) 1998-10-29 2000-05-25 Providing VCR functionality for data-centered video multicast

Publications (2)

Publication Number Publication Date
WO2000027106A2 true WO2000027106A2 (en) 2000-05-11
WO2000027106A3 WO2000027106A3 (en) 2000-09-28

Family

ID=22309872

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1999/025422 WO2000027106A2 (en) 1998-10-29 1999-10-28 Providing vcr functionality for data-centered video multicast

Country Status (2)

Country Link
AU (1) AU1330600A (en)
WO (1) WO2000027106A2 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1225767A2 (en) 2001-01-22 2002-07-24 Sony Computer Entertainment America Method and system for delivering digital content
EP1292143A1 (en) * 2001-02-22 2003-03-12 Sony Corporation Transmitter
EP1542473A1 (en) * 2003-12-04 2005-06-15 Pace Micro Technology PLC Broadcast data system and broadcast data receiver
EP2228989A1 (en) * 2008-01-10 2010-09-15 Sony Corporation Display forming device, display forming method, program, and content download system
CN102625183A (en) * 2012-04-10 2012-08-01 北京邮电大学 User terminal playing method for simulation of video-on-demand system
US9100585B2 (en) 2008-10-28 2015-08-04 Sony Computer Entertainment Inc. Combined broadcast and backchannel delivery of streaming content
CN113612981A (en) * 2021-08-25 2021-11-05 福建天晴数码有限公司 Video-based 3D (three-dimensional) graph real-time rendering method and system

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9483405B2 (en) 2007-09-20 2016-11-01 Sony Interactive Entertainment Inc. Simplified run-time program translation for emulating complex processor pipelines

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5930493A (en) * 1995-06-07 1999-07-27 International Business Machines Corporation Multimedia server system and method for communicating multimedia information
US5959690A (en) * 1996-02-20 1999-09-28 Sas Institute, Inc. Method and apparatus for transitions and other special effects in digital motion video
US5963202A (en) * 1997-04-14 1999-10-05 Instant Video Technologies, Inc. System and method for distributing and managing digital video information in a video distribution network

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5930493A (en) * 1995-06-07 1999-07-27 International Business Machines Corporation Multimedia server system and method for communicating multimedia information
US5959690A (en) * 1996-02-20 1999-09-28 Sas Institute, Inc. Method and apparatus for transitions and other special effects in digital motion video
US5963202A (en) * 1997-04-14 1999-10-05 Instant Video Technologies, Inc. System and method for distributing and managing digital video information in a video distribution network

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8458754B2 (en) 2001-01-22 2013-06-04 Sony Computer Entertainment Inc. Method and system for providing instant start multimedia content
EP1225767A3 (en) * 2001-01-22 2005-12-14 Sony Computer Entertainment Inc. Method and system for delivering digital content
EP1225767A2 (en) 2001-01-22 2002-07-24 Sony Computer Entertainment America Method and system for delivering digital content
EP2280545A1 (en) * 2001-01-22 2011-02-02 Sony Computer Entertainment Inc. Method and system for delivering digital content
EP1292143A1 (en) * 2001-02-22 2003-03-12 Sony Corporation Transmitter
EP1292143A4 (en) * 2001-02-22 2006-10-18 Sony Corp Transmitter
US7664951B2 (en) 2001-02-22 2010-02-16 Sony Corporation Transmitting apparatus for providing information by effective use of bands
EP1542473A1 (en) * 2003-12-04 2005-06-15 Pace Micro Technology PLC Broadcast data system and broadcast data receiver
EP2228989A1 (en) * 2008-01-10 2010-09-15 Sony Corporation Display forming device, display forming method, program, and content download system
EP2228989A4 (en) * 2008-01-10 2011-06-08 Sony Corp Display forming device, display forming method, program, and content download system
US8555175B2 (en) 2008-01-10 2013-10-08 Sony Corporation Display generation device, display generation method, program, and content download system
US9100585B2 (en) 2008-10-28 2015-08-04 Sony Computer Entertainment Inc. Combined broadcast and backchannel delivery of streaming content
US9743140B2 (en) 2008-10-28 2017-08-22 Sony Interactive Entertainment Inc Combined broadcast and backchannel delivery of streaming content
CN102625183A (en) * 2012-04-10 2012-08-01 北京邮电大学 User terminal playing method for simulation of video-on-demand system
CN113612981A (en) * 2021-08-25 2021-11-05 福建天晴数码有限公司 Video-based 3D (three-dimensional) graph real-time rendering method and system

Also Published As

Publication number Publication date
WO2000027106A3 (en) 2000-09-28
AU1330600A (en) 2000-05-22

Similar Documents

Publication Publication Date Title
US6993787B1 (en) Providing VCR functionality for data-centered video multicast
US8010985B2 (en) Method and system for resource management in a video on-demand server
CA2362727C (en) Queuing architecture with multiple queues and method for statistical disk scheduling for video servers
US6543053B1 (en) Interactive video-on-demand system
CA2446617C (en) Channel buffering and display management system for multi-tuner set-top box
US6327421B1 (en) Multiple speed fast forward/rewind compressed video delivery system
US7739715B2 (en) Variable play speed control for media streams
US6018359A (en) System and method for multicast video-on-demand delivery system
US6005599A (en) Video storage and delivery apparatus and system
JP3953512B2 (en) Method and apparatus for providing a trick mode function such as a VCR for observing distributed video data
US7779181B2 (en) Disk driver cluster management of time shift buffer with file allocation table structure
US8468571B2 (en) Enabling trick plays during VBR playback of a CBR transmitted media file
US20020175998A1 (en) Data-on-demand digital broadcast system utilizing prefetch data transmission
WO2000027106A2 (en) Providing vcr functionality for data-centered video multicast
US6643083B2 (en) Method and system for retrieving blocks of data from a storage medium
Fei et al. Providing interactive functions through active client-buffer management in partitioned video multicast VoD systems
EP1026679B1 (en) Recorded information reproducing apparatus
JP2004536491A (en) Data-on-demand digital broadcasting system using prefetch data transmission
Poon et al. Provision of continuous VCR functions in interactive broadcast VoD systems
JP3584787B2 (en) Multimedia data playback / transmission device
To et al. Fast Startup and Interactive Retrievals of Broadcast Videos
EP1761864A2 (en) Method and system for resource management in a video on-demand server
Rahman et al. Buffer efficient fast broadcasting scheme
Sheu et al. Periodic broadcast technique for scalable VCR-like interactivity
KR20030051800A (en) Decreased idle time and constant bandwidth data-on-demand broadcast delivery ma-trices

Legal Events

Date Code Title Description
ENP Entry into the national phase in:

Ref country code: AU

Ref document number: 2000 13306

Kind code of ref document: A

Format of ref document f/p: F

AK Designated states

Kind code of ref document: A2

Designated state(s): AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GE GH GM HR HU ID IL IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

WWE Wipo information: entry into national phase

Ref document number: 09578739

Country of ref document: US

121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: A3

Designated state(s): AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GE GH GM HR HU ID IL IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZW

AL Designated countries for regional patents

Kind code of ref document: A3

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase