AU2013203318B2 - Systems and Methods for Enhanced Trick-Play Functions - Google Patents

Systems and Methods for Enhanced Trick-Play Functions Download PDF

Info

Publication number
AU2013203318B2
AU2013203318B2 AU2013203318A AU2013203318A AU2013203318B2 AU 2013203318 B2 AU2013203318 B2 AU 2013203318B2 AU 2013203318 A AU2013203318 A AU 2013203318A AU 2013203318 A AU2013203318 A AU 2013203318A AU 2013203318 B2 AU2013203318 B2 AU 2013203318B2
Authority
AU
Australia
Prior art keywords
video
user
rewind
server
trick
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
AU2013203318A
Other versions
AU2013203318A1 (en
Inventor
Michael L. Craner
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Adeia Guides Inc
Original Assignee
Rovi Guides Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from AU2012216855A external-priority patent/AU2012216855B2/en
Application filed by Rovi Guides Inc filed Critical Rovi Guides Inc
Priority to AU2013203318A priority Critical patent/AU2013203318B2/en
Publication of AU2013203318A1 publication Critical patent/AU2013203318A1/en
Application granted granted Critical
Publication of AU2013203318B2 publication Critical patent/AU2013203318B2/en
Assigned to ROVI GUIDES, INC. reassignment ROVI GUIDES, INC. Request to Amend Deed and Register Assignors: UNITED VIDEO PROPERTIES, INC.
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Abstract

The present invention is directed to a method for rewinding or fast-forwarding a non-on-demand video. The method comprises the steps of processing viewing criteria; selecting a video for enhanced rewind and fast-forward functionality based on the processed viewing criteria; storing the selected video with a server based on the processed viewing criteria; transmitting the stored video in response to a request for a forward or reverse stream. '/9 o 21 w22i I.W WI

Description

SYSTEMS AND METHODS FOR ENHANCED TRICK-PLAY FUNCTIONS Background of the Invention [0001] This invention is directed to systems and methods 5 for trick-play functions in video or audio entertainment systems. [0002] Mere reference to background art herein should not be construed as an admission that such art constitutes common general knowledge in relation to the invention. 10 [0003] Interactive media guidance applications, such as interactive television program guides, are well known in the art. Some interactive media guidance applications provide video entertainment device users with the ability to perform "trick-play" functions upon video. Such trick-play functions 15 include pause, rewind, and fast-forward. The interactive media guidance applications cache video programs that are transmitted over a network or transmission system (e.g., satellite, cable, or off-the-air) to allow users to trick play through the video programs. To provide trick-play 20 functions, these systems may begin caching video when the user tunes to the program, which may be in progress. As a result, users of such systems can rewind to the point in time when they first tuned to the program, but not to any prior point in time. 25 [0004] Accordingly, it would be desirable to provide systems and methods for trick-play functions by which the user may rewind a video to a time prior to when the user first started viewing the video and fast-forward to a point beyond where the real-time transmission is presently 30 streaming. Summary of the Invention [0005] According to one aspect of the invention, there is provided a method for rewinding or fast-forwarding a non-on 35 demand video, comprising: - 2 processing viewing criteria; selecting a video for enhanced rewind and fast-forward functionality based on the processed viewing criteria; storing the selected video with a server based on the 5 processed viewing criteria; transmitting the stored video in response to a request for a forward or reverse stream. [0006] The viewing criteria may comprise: user viewing history, 10 programs or channels that a user watches, sets reminders for or records, user interests identified in a user profile, or programs that the user watches while another program is recorded. 15 [0007] The viewing criteria may comprise: a plurality of user viewing histories, programs or channels that a plurality of users watch, set reminders for or record, user interests identified in a plurality of user 20 profiles, or programs that a plurality of users watch while another program is recorded. [0008] The method may further comprise storing content scheduled prior to the selected video with the server. 25 [0009] The method may further comprise storing, with the server, all content associated with a channel based on the processed viewing criteria. [0009a] The method may further comprise charging a fee to the media provider of the selected video for enhanced rewind 30 and fast-forward functionality. [0009b] The method may further comprise identifying the selected video for storing, by a phrase or indicator. [0009c] The method may further comprise allocating an amount of memory to a user for storing selected videos for 35 enhanced rewind and fast-forward functionality.
-3 [0009d] The method may further comprise storing the information about users that have access to enhanced rewind and fast-forward functionality of the video. [0009e] The method may further comprise receiving a request 5 from user equipment to store a video for rewind and fast forward functionality. [0009f] According to another aspect of the invention, there is provided a system for rewinding or fast-forwarding a non on-demand video, comprising: 10 means for processing viewing criteria; means for selecting a video for enhanced rewind and fast-forward functionality based on the processed viewing criteria; means for storing the selected video with a server based 15 on processed viewing criteria; means for transmitting the stored video in response to a request for a forward or reverse stream. [0009g] The system may further comprise means for storing content scheduled prior to the selected video with the 20 server. [0009h] The system may further comprise means for storing, with the server, all content associated with a channel based on the processed viewing criteria. [0009i] The system may further comprise means for charging 25 a fee to the media provider of the selected video for enhanced rewind and fast-forward functionality. [0009j] The system may further comprise means for identifying the selected video for storing, by a phrase or indicator. 30 [0009k] The system may further comprise means for allocating an amount of memory to a user for storing selected videos for enhanced rewind and fast-forward functionality. [00091] The system may further comprise means for storing the information about users that have access to enhanced 35 rewind and fast-forward functionality of the video.
- 3a [0009m] The system may further comprise means for receiving a request from user equipment to store a video for rewind and fast-forward functionality. [0009n] Any of the features described herein can be 5 combined in any combination with any one or more of the other features described herein within the scope of the invention. Brief Description of the Drawings [0010] The above and other features of the present 10 invention, its nature and various advantages will be more apparent upon consideration of the following detailed description, taken in conjunction with the accompanying drawings in which: [0011] FIG. 1 is a diagram of an illustrative interactive 15 media system in accordance with one embodiment of the present invention; [0012] FIG. 2 shows an illustrative data structure for buffers in accordance with one embodiment of the present invention; 20 [0013] FIG. 3 shows another illustrative data structure for buffers in accordance with one embodiment of the present invention; [0014] FIG. 4 shows an illustrative display having a transport control bar in accordance with one embodiment of 25 the present invention; [0015] FIG. 5 shows another illustrative display having a transport control bar in accordance with one embodiment of the present invention; [0016] FIG. 6 shows still another illustrative display 30 having transport control bar in accordance with one embodiment of the present invention; -4 [0017] FIG. 7 shows an illustrative display screen .having a program grid in accordance with one embodiment of the present invention; [0018] FIG. 8 shows a flow chart of an illustrative 5 process for rewinding a video in accordance with one embodiment of the present invention; [0019] FIG. 9 shows a flow chart of an illustrative process for fast-forwarding a video in accordance with one embodiment of the present invention; 10 [0020] FIG. 10 shows a flow chart of an illustrative process for providing a video stream to a user's equipment in accordance with one embodiment of the present invention; and [0021] FIG. 11 shows a flow chart of an illustrative 15 process for playing back video from rewind and/or forward buffers in accordance with one embodiment of the present invention. Detailed Description [0022] FIG. 1 shows illustrative interactive media 20 system 100 in accordance with one embodiment of the invention. User equipment 110 receives media in the form of signals from media source 120 over communications path 122. In practice there may be multiple media sources 120 and user equipment 110, but 25 only one of each has been shown in FIG. 1 to avoid over-complicating the drawing. [00231 Media source 120 may be any suitable media source such as, for example, a cable system headend, satellite media distribution facility, media broadcast 30 facility, internet protocol television (IPTV) headend, on-demand server (e.g., VOD server), website, game service provider (e.g., for online gaming), or any -5 other suitable facility or system for originating or distributing media. Media source 120 may be configured to transmit signals over any suitable communications path 122 including, for example, a satellite path, a 5 fiber-optic path, a cable path, an Internet path, or any other suitable wired or wireless path. The signals may carry any suitable media such as, for example, television programs, games, music, news, web services, video, or any other suitable media. In some 10 embodiments, media source 120 may include control circuitry for executing the instructions of a trick play client or an interactive media guidance application such as, for example an online interactive media guidance application. 15 [0024) User equipment 110 may include any equipment suitable for providing an interactive media experience. User equipment 110 may include television equipment such as a television, set-top box, recording device, video player, user input device (e.g., remote control, 20 keyboard, mouse, touch pad, touch screen or voice recognition interface), or any other device suitable for providing an interactive media experience. For example, user equipment 110 may include a DCT 2000, 2500, 5100, 6208 or 6412 set-top box provided by 25 Motorola, Inc. In some embodiments, user equipment 110 may -include computer equipment, such as a personal computer with a television card (PCTV). In some embodiments, user equipment 110 may include a fixed electronic device such as, for example, a gaming system 30 (e.g., X-Box, PlayStation, or GameCube) or a portable electronic device, such as a portable DVD player, a portable gaming device, a cellular telephone, a PDA, a -6 music player (e.g., MP3 player), or any other suitable fixed or portable device. [0025] In the example of FIG. 1, user equipment 110 includes at least control circuitry 116, display device 5 112, user input device 114, and recording device 118 which may be implemented as separate devices or as a single device. A trick-play client may be implemented on user equipment 110 to provide trick-play functions to the user for media displayed on display device 112. 10 In some embodiments, the trick-play client is part of an interactive media guidance application, such as an interactive television program guide. For purposes of clarity, and not by way of limitation, the following embodiments will be described as provided by a trick 15 play client. [0026] Display device 112 may be any suitable device such as, for example, a television monitor, a computer monitor, or a display incorporated in user equipment 110 (e.g., a cellular telephone or portable 20 music player display). Display device.112 displays the media transmitted by media source 120 over path 122, and the displays of the trick-play client. Display device 112 may also be configured to provide for the output of audio. 25 [0027] Recording device 118 may be a personal video recorder (PVR), digital video recorder (DVR), video cassette recorder (VCR), DVD-recorder, or any other suitable video recorder. Recording device 118 may include one or more tuners. The trick-play client 30 directs recording device 118 to cache the rewind and forward streams from server 130. [0028) Control circuitry 116 is adapted to receive user inputs from input device 114 and execute the -7 instructions of the trick-play client. Control circuitry 116 may include one or more tuners (e.g., analog or digital tuners), encoders and decoders (e.g., MPEG decoders), processors (e.g., Motorola 68000 family 5 processors), memory 117 (i.e., RAM and hard disks), communications circuitry (e.g., cable modem circuitry), input/output circuitry (e.g., graphics circuitry), connections to the various devices of user equipment 110, and any other suitable component for 10 providing analog or digital media programming, program recording, and interactive media guidance features. In some embodiments, control circuitry 116 may be included as part of one of the devices of user equipment 110 such as, for example, part of display 112 or any other 15 device (e.g., a set-top box, television and video player). [0029) In some embodiments, the trick-play client may provide features to the user with a client/server approach. There may be one server for each instance of 20 user equipment 110, one for multiple instances of user equipment 110, or a single server may serve as a proxy for each instance of user equipment 110. [00301 Any suitable number of users may have equipment, such as user equipment 110, connected to 25 media source 120 and data sources 124. But for the clarity of the figure, the equipment of only a single user is shown. The equipment of the plurality of users may be connected to media source 120 and data source 124 using a cable television network, a 30 satellite television network, a local area network (LAN), a wireless network, the Internet, or any other suitable means. In some embodiments, the equipment of -8 the plurality of users may be connected to each other using any suitable means. {00313 User equipment 110 may receive interactive media guidance application data from one or more data 5 sources 124. Data sources 124 may provide data for a particular type of media or for a particular application. For example, one data source 124 may provide data for non-on-demand media (e.g., non-pay and pay-per-view programs), and another may provide data 10 for on-demand media (e.g., VOD programs). Or, for example, a single data source may provide both of these types of data. For example, one data source 124 may provide data for an interactive television program guide. Another data source 124 may, for example, 15 provide data for another interactive application (e.g., a home shopping application). In some embodiments, data sources 124 may provide data to the trick-play client using a client/server approach. There may be one server per data source, one for all sources or, in 20 some embodiments, a single server may communicate as a proxy between user equipment 110 and various data sources 124. In some embodiments, data sources 124 may provide data as an online interactive media guidance application. In such embodiments, data source 124 may 25 include control circuitry for executing the instructions of the online media guidance application. (0032) FIG. 1 shows media source 120 and data sources 124 as separate elements. In practice, their functionality may be combined and provided from a 30 single system at a single facility, or multiple systems at multiple facilities. For example, one media source 120 and data source 124 may be combined to provide VOD content and associated VOD data.
-9 [0033] Illustrative interactive television system 100 includes server 130. Server 130 includes control circuitry 132 and memory 134 for executing, for example, operations requested by media source 120 or 5 user equipment 110 (e.g., providing a cached video to the trick-play client). Control circuitry 132 may include one or more tuners, processors, encoders/decoders, communications circuitry, and I/O circuitry connected to the various devices of 10 interactive television system 100, or any other suitable component. Control circuitry 132 may access video or other media provided by media source 120 in any suitable manner, for example by directing a tuner to tune to the channel transmitted by media source 120. 15 As another example, server 130 may access the video directly, for example via an internet protocol connection (e.g., file transfer protocol or DOCSIS QAM stream) to media source 120. [0034] Server 130 may be incorporated in media 20 source 120 (e.g., at the head-end of a cable plant), data source 124, a VOD server (not shown), user equipment 110 (e.g., as a second recording device, or a hard drive on a home computer), an Internet server, or any other suitable device. Alternatively, server 130 25 may be a stand alone device (e.g., a commercial network recording device, or a DVR device in a home or neighborhood network). In some embodiments, all media provided by media source 120 may first be transmitted to server 130, which may subsequently transmit the 30 media to user equipment 110. In such embodiments, the server may record (in systems where user-initiated server-based recording is provided) or cache the media as it is received, and subsequently or simultaneously -10 transmit the media to the user's equipment. In other embodiments, the media source may simultaneously provide media both to the server and to the user's equipment. In such embodiments, the server may only 5 provide rewind and/or forward streams of the media that is has recorded or cached to the user's equipment in response to a request by the trick-play client. In some embodiments, the server may cache or record videos before they are provided to users by media source 120. 10 [0035] Server 130 may receive instructions from user equipment 110 or media source 120 (or any other device of interactive media system 100) to perform suitable operations. Such operations may include, for example, recording or caching some or all of the videos that are 15 transmitted by media source 120. In some embodiments, server 130 may cache every video that is transmitted by media source 120. In some embodiments, server 130 may only cache particular videos (e.g., particular broadcast programs) or particular channels (e.g., user 20 favorite channels). The user's equipment or the media source may identify a particular video in any suitable manner (e.g., from the channel map and the program map table of a QAM stream, or a program identifier), and communicate a request to control circuitry 132 to 25 record or cache the video in memory 134. In some embodiments, users may record videos on server 130. In such embodiments, server 130 may use the recorded video (which may have been recorded for users other than the one using the enhanced rewind functionality) as 30 "cached" video for the rewind and/or forward stream. [0036] The trick-play client, the media source, or the server may select, based on any suitable criteria, the videos that the server records or caches and for -11 which the enhanced rewind and fast-forward functionality of the present invention is available. Such criteria may include, for example, a user's viewing history, the programs or channels that a user 5 typically watches, records, or sets reminders for, user interests as identified by a user profile (e.g., a profile established by asking the user a series of questions). In some embodiments, the criteria may include identifying the programs that the user watches 10 while another program is recorded, the two or more simultaneously transmitted programs among which the user switches, or the programs that the user starts watching after the beginning of the program. If the server has limited memory capabilities, or if the user 15 is allotted a small amount of server memory, the trick play client may be more discriminating in the selection of videos that the server records or caches for the user. [0037] Other criteria for selecting the videos for 20 which the enhanced rewind and fast-forward functionality is available may include the viewing histories or user profiles of some or all of the users of the interactive media system, the popular programs of some or all of the users, or any other criteria 25 derived from more than one user or from a family of users of the interactive media system. As another example, only videos provided by preferred media providers (e.g., providers who pay a fee) may be recorded or cached on the server. Such videos may be 30 identified to users as "provided with enhanced trick play," for example, letting users know that they may rewind, potentially to the beginning of the video even if they joined the video after the video began. In -12 some embodiments, a channel may be identified as "provided with enhanced trick play." The rewind buffer length may be sufficient to allow the user (after some time) to rewind to a point prior to the 5 beginning of the program (e.g., two or three hours, or to yesterday's videos). [0038] Recorded and cached videos are stored by server 130 in memory 134. Memory 134 may be any suitable memory for recording or caching video such as, 10 for example, one or more hard-drive arrays, hard discs, server arrays, RAM, SRAM, DRAM, ROM, flash memory, or any other suitable memory. In some embodiments, memory 134 may store instructions from control circuitry 132, user equipment 110, media source 120, or 15 any other device of interactive media system 100 related to recorded or cached video. Such instructions may include, for example, how long to keep the video in memory, which users have access to the video (e.g., in a tier-based system), or any other suitable 20 instruction. In the example of FIG. 1, memory 134 is shown as a component of server 130, but in other embodiments, memory 134 may be a stand-alone component. (0039] When a user of user equipment 110 accesses a non-on-demand video (such as, for example, by tuning to 25 a channel), the trick-play client may automatically direct recording device 118 of user equipment 110 to cache the video in one or more buffers. In addition, the trick-play client may send a request to server 130 for a rewind stream that includes the portions of the 30 video that were transmitted before the user first started viewing the video. [0040] In some embodiments, the trick-play client may also send a request to server 130 for a forward -13 stream that includes the portions of the video that the trick-play client has not yet cached. The trick-play client may first determine whether the entire video is cached or recorded by server 130 before requesting a 5 forward stream. Alternatively, the trick-play client may systematically request the forward stream and wait for a response from server 130 regarding whether the forward stream portions of the video are available. [0041] The trick-play client may request the rewind 10 and/or forward streams at any suitable time including, for example, as soon as the user starts viewing a video (e.g., tunes to a channel), after a given amount of time (e.g., 1 minute or 5 minutes), in response to a trick-play request from the user (e.g., pause or 15 rewind), or at any other suitable time. [0042] In response to receiving the requests for the rewind and/or forward streams, server 130 may generate and transmit rewind and/or forward streams to user equipment 110, if they are available. For example, if 20 the trick-play client requests both rewind and forward streams for a sporting event that is broadcast live, server 130 may generate and transmit only the rewind stream because the server has not cached or recorded the entire sporting event. The forward stream, if 25 provided to user equipment 110, may include the full feature video (e.g., without skipping any frames) and may be transmitted at a speed that is faster than the real-time video is transmitted (e.g., 2x faster). The forward stream therefore may require more bandwidth 30 than the real-time video. Similarly, the rewind stream may include the full feature video (e.g., without skipping any frames) and may be transmitted at a speed that is faster than real-time.
-14 [0043] Server 130 may provide the rewind and forward streams to user equipment 110 using any suitable transmission scheme (e.g., MPEG-2 QAM stream or DOCSIS QAM stream). For example, the rewind and forward 5 streams may each be added as separate programs in the live QAM stream used to transmit the video (e.g., the rewind stream is placed in a first PID (packet identifier), and the forward stream is placed in a second PID, where the PIDs are in the QAM stream). As 10 another example, the rewind and forward streams may both be added as a single program in the live QAM stream (e.g., a single PMT (program map table) PID may identify both the rewind video and audio, and the forward video and audio as well as the primary real 15 time video and audio). As still another example, the server may generate one or more new QAM streams each containing one of the rewind and forward streams. [0044] The video of the rewind stream may be provided in any suitable manner such as, for example, 20 reverse order bitwise (e.g., as if the user is rewinding from the moment the buffers were created), reverse order by block, reverse order by packet, or by randomly filling in bits of data that are missing (e.g., a bit torrent approach). For approaches other 25 than the reverse order bitwise, the rewind functionality is only available once the video cached by the trick-play client is sufficiently continuous to support playback. [0045] The trick-play client may direct recording 30 device 118 to cache the rewind and/or forward streams provided by server 130 in one or more buffers. FIG. 2 shows an illustrative data structure for the one or more buffers. Data structure 200 includes table 210 -15 and buffers 222 and 224. Table 210 may be stored in recording device 118 (e.g., in memory 220), in memory of control circuitry 116 (e.g., RAM), or in any other memory of user equipment 110. Buffers 222 and 224 may 5 be stored in memory 220 of recording device 118 (e.g., on a hard drive). Table 210 includes a column for streams of the video (e.g., rewind and forward streams) and a column for pointers linking the streams to their respective buffers. In response to receiving the 10 rewind/and or forward streams from server 130, the trick-play client creates rows 212 and 214 for the streams in table 210. [0046] The video provided by the rewind stream is cached in rewind buffer 222. The current frame cached 15 in the rewind buffer, Fi-r, is identified by pointer 232. Rewind buffer 222 begins with frame Fn, the frame that was displayed when the user started viewing the video, and ends with frame FO, which is the first frame of the video. The rewind buffer is filled 20 backwards substantially continuously from frame F, to frame FO (e-.g., in reverse order bitwise) with the video of the rewind stream. Similarly, the video provided by the forward stream is cached in forward buffer 224. The current frame in the forward buffer, Fjrf, is 25 identified by pointer 234. Forward buffer 224 begins with frame F, and ends with frame Fy, which is the last frame of the video. The trick-play client may preferably cache video in forward buffer 224 at a speed that is faster than real time. If the trick-play 30 client does not receive a forward stream, the trick play client may instead cache the real-time stream of the video in forward buffer 224.
-16 [0047] In some embodiments, the trick-play client does not request or receive rewind and/or forward streams until after the user has viewed the video for a given time. If recording device 118 cached the real 5 time stream during the given time (e.g., in a real-time buffer), the trick-play client may request that the rewind stream begin when the user started viewing the video and that the forward stream begin after the given time. Then, as shown in FIG. 3, rewind buffer 322 10 begins with frame Fnr (e.g., the frame at which the user started to view the video), forward buffer 324 begins with frame Fnf (e.g., the frame of the video after the given time), and real-time buffer 326 includes the video between frames Fnr and Fn-. Once 15 recording device 118 begins to cache the forward stream, the trick-play client may direct recording device 118 to stop caching the real-time stream to avoid caching the same video twice. Alternatively, the trick-play client may delete the video cached in the 20 real-time buffer and direct server 130 to provide reverse and forward streams that begin at the same frame, for example any frame between frames Fn--r and Fn.f. (0048] When the user calls a trick-play function, 25 the trick-play client may seamlessly migrate the video from the real-time video stream to the video cached in the rewind buffer and the real-time and/or forward buffer. The user's trick-play functionality is then provided by the buffers stored locally in the recording 30 device, and not remotely, from the server. To play back the video cached in the rewind buffer, the trick play client may direct recording device 118 to provide the video cached in rewind buffer 222 from frame F 0 to -17 frame F,. To play back the video cached in the forward buffer, the trick-play client may direct recording device 118 to provide the video cached in forward buffer 224 from frame Fn to frame Fy. The trick-play 5 client may identify which buffers to play back using table 210 (e.g., connecting the buffers like a linked list). [00491 The trick-play client may display a visual representation of the rewind and forward buffers using 10 an enhanced transport control bar. FIG. 4 shows illustrative screen 400 of the video 402 that the user is viewing, and enhanced transport control bar 410. Enhanced transport control bar 410 includes title 412 of video 402, channel 414 on which the video is 15 transmitted, as well as start time 416 and end time 418 of the video. Enhanced transport control bar 410 includes cursor 420 that indicates the current playback location and time 421 of- video 402 for the user. [0050] Enhanced transport control bar 410 includes 20 mark 430 identifying when the user first started viewing the video. Enhanced transport control bar 410 also includes visual representations of the rewind and forward buffers into which the rewind and forward streams are cached, respectively. In particular, 25 rewind buffer representation 432 begins at mark 430 and moves backwards in time towards the beginning of the video, and forward buffer representation 434 begins at mark 430 and moves forward in time towards the end of the video. For videos that server 130 has not recorded 30 or cached in their entirety, and for which forward streams are not available, forward buffer representation 434 may represent the real-time buffer -18 that is cached with the video from the real-time stream. [00511 FIG. 5 represents the enhanced transport control bar of FIG. 4 after the trick-play client has 5 cached additional portions of the rewind stream and the forward stream in recording device 118 (this can be seen by comparing FIGS. 4 and 5). In enhanced transport control bar 510, cursor 520 has advanced and indicates that the current playback time is 7:36, 16 10 minutes later than the playback time indicated in enhanced transport control bar 410 of FIG. 4. Mark 530 has not moved from FIG. 4, but rewind buffer 532 has advanced all the way to the beginning of the video, and forward buffer 534 has advanced towards the end of the 15 video. [00521 FIG. 6 shows another illustrative display of a visual representation of the rewind and forward buffers in an enhanced transport control bar. Screen 600 includes video 602 that the user is viewing, 20 and enhanced transport control bar 610. Enhanced transport control bar 610 includes start time 612 and end time 614 of the video, cursor 620 that indicates the current playback location for the user, and representations of rewind buffer 632 and forward 25 buffer 634. Enhanced transport control bar 610 also includes rewind cursor 622 and forward cursor 626, which are associated with rewind preview image 624 and forward preview image 628, respectively. In particular, rewind preview image 624 may correspond to 30 the position of rewind cursor 622, and forward preview image 628 may correspond to the position of forward cursor 626. In some embodiments, the user may direct -19 the trick-play client to display multiple rewind and forward cursors and associated preview images. (0053- In some embodiments, the rewind and forward cursors may correspond to the frames of the rewind and 5 forward streams that the trick-play client is currently caching. Alternatively, the rewind and forward cursors may correspond to trick-play requests of the user (e.g., rewinding or fast-forwarding in preview images 624 or 628). The trick-play client may 10 automatically display one or both of preview images 624 and 628, or the user may request the preview images be displayed. When the user has identified a portion of the video in preview image 624 or 628 that the user would like to play back, the user may display the 15 preview image in full screen and play back the video at the playback position of the selected preview image. [0054) The buffers for caching the video may be arbitrarily limited in size, or limited only by the space available on recording device 118. If the 20 buffers are limited in size or recording device 118 has limited space available, the buffer may not be large enough to cache an entire video. To provide enhanced trick-play functions to the user, the trick-play client may cache the rewind and/or forward streams in buffers, 25 and overwrite the rewind and/or forward buffers as necessary to comply with a user trick-play request (e.g., in response to a rewind request that extends to video not cached in the rewind buffer, request a new rewind stream that is cached in place of the forward 30 buffer). The trick-play client may, instead or in addition, identify advertisements in the rewind and forward streams (e.g., from packet identifiers) and not cache the advertisements.
-20 [00553 Once the entire video is cached in buffers, the client may, automatically or in response to a user instruction, save the cached video as a recording for future viewing. In some embodiments, the client may, 5 automatically or in response to a user instruction, save an incomplete video that is cached in the buffers. [0056] In some embodiments, server 130 may not cache or record every video that is provided to user equipment 110. The trick-play client may then, before 10 requesting a rewind and/or forward stream, determine whether server 130 has cached or recorded the video. For example, the trick-play client may receive an indication from server 130 whether the video is available. In response to determining that the video 15 is in fact available, the trick-play client may request the rewind and/or forward streams from server 130. (0057] The trick-play client may determine whether server 130 has cached or recorded a partially or in its entirety video at any suitable time. For example, 20 server 130 may identify for the trick-play client the videos that the server has or will cache or record for a given time period (e.g., the next day or week) at regular intervals. Server 130 may further specify to the trick-play client the time at which the videos will 25 be cached or recorded in their entirety. The trick play client may in turn identify the videos for the user. For example, the trick-play client may display an icon, shade the listing, change a color, or provide any other suitable indication on the transport control 30 bar or in a program grid. [0058] FIG. 7 shows illustrative program grid screen 700 that includes grid 702 of program listings. The programs listed in grid 702 that have been cached -21 or recorded by server 130 are identified by icons 710 and 712. Rewind icon 710 indicates that server 130 has at least partially cached or recorded the program associated with the icon, and that a rewind stream is 5 available (e.g., "Friends" and "The Sopranos"). Forward icon 712 indicates that server 130 has cached or recorded the program associated with the icon in its entirety, and that a forward stream is available (e.g., "The Bourne Identity"). The trick-play client may 10 display both rewind icon 710 and forward icon 712 to indicate that both rewind and forward streams are available. Alternatively, the trick-play client may display only forward icon 712 to indicate that rewind and forward streams are available (e.g., because if an 15 entire video is cached or recorded, the server may provide a rewind stream). Though FIG. 7 shows icons, the program grid may include any other suitable indication. The trick-play client may use one or more indicators to identify videos for which a user may 20 request rewind or fast-forward streams. [00591 The following flow charts serve to illustrate processes involved in some embodiments of this invention. FIG. 8 is a flow chart of an illustrative process for rewinding a video to a point prior to when 25 the user first started viewing the video. Process 800 begins at step 802. At step 810, the user selects a non-on-demand video after the video has already started (e.g., starts viewing a broadcast program after the broadcast has started). For example, the user may 30 direct a tuner in control circuitry 116 to tune to a real-time stream provided by media source 120 by entering a channel number or by selecting a program -22 from a suitable trick-play client display (e.g., a program guide grid). [0060] At step 820, the trick-play client determines whether the user has a sufficient interest in the video 5 to warrant requesting a rewind stream. For example, the trick-play client may determine whether the user has viewed the video for a given amount of time, or whether the user has called a trick-play function (e.g., "rewind"). In some embodiments, prior to 10 step 820, the trick-play client may determine whether server 130 has cached or recorded the selected video. In the process shown in FIG. 8, however, this step has been omitted. If the trick-play client determines that the user does not have a sufficient interest in the 15 video to warrant requesting a rewind stream, process 800 moves to step 852 and ends. (0061] If instead, at step 820, the trick-play client determines that the user has a sufficient interest in the video to warrant requesting a rewind 20 stream, process 800 moves to step 830. At step 830, the trick-play client requests a rewind stream from server 130. The rewind stream includes the video that was transmitted by media source 120 prior to the time when the user first selected the video. The video of 25 the rewind stream may begin at the time when the user first selected the video, and stream backwards in time to the beginning of the video. The rewind stream may provide the video content in any suitable manner such as, for example, reverse-order bitwise. 30 10062] At step 840, the trick-play client receives the rewind stream from server 130 over communications path 122 and directs recording device 118 to cache the rewind stream in one or more rewind buffers. At -23 step 850, the trick-play client rewinds the video to a point prior to when the user first selected the video by rewinding the video through the one or more rewind buffers. The trick-play client may then play back the 5 video from the one or more rewind buffers. Process 800 ends at step 852. [0063) FIG. 9 is a flow chart of an illustrative process for fast-forwarding a video to a point that has not yet been reached by the real-time stream of the 10 video. Process 900 begins at step 902, At step 910, the user selects a non-on-demand video transmitted in a real-time stream (e.g., a broadcast program). For example, the user may direct a tuner in control circuitry 116 to tune to a real-time stream provided by 15 media source 120 by entering a channel number or selecting a program from a suitable trick-play client display (e.g., a program guide grid). [0064) At step 920, the-trick-play client determines whether server 130 has recorded or cached the entire 20 video. For example, the trick-play client may request an indication from server 130 of the videos that have been recorded or cached in their entirety. As another example, the trick-play client may determine that server 130 recorded or cached a video if the video is a 25 re-run or a repeated program (e.g., a repeat episode of a popular series). If the trick-play client determines that server 130 has not recorded or cached the video, process 900 moves to step 962 and ends. [0065] If instead, at step 920, the trick-play 30 client determines that server 130 has recorded or cached the video, process 900 moves to step 930. At step 930, the trick-play client determines whether the user has a sufficient interest in the video to warrant -24 requesting a forward stream. For example, the trick play client may determine whether the user has viewed the video for a given amount of time, or whether the user has called a trick-play function (e.g., "fast 5 forward"). If the trick-play client determines that the user does not have a sufficient interest in the video to warrant requesting a forward stream, process 900 moves to step 962 and ends. [00661 If instead, at step 930, the trick-play 10 client determines that the user has a sufficient interest in the video to warrant requesting a forward stream, process 900 moves to step 940. At step 940, the trick-play client requests a forward stream from server 130. The forward stream includes the entire 15 video (e.g., without skipping any video frames) that was transmitted by media source 120 at least after the time when the user first selected the video (e.g., after the time at which the user requested the forward stream). In some embodiments, server 130 provides the 20 forward stream to user equipment 110 at a speed that is greater than the speed of the real-time stream (e.g., at a speed greater than lx). [0067] At step 950, the trick-play client receives the forward stream from server 130 over communications 25 path 122 and directs recording device 118 to cache the forward stream in one or more forward buffers. At step 960, the trick-play client fast-forwards the video through the forward buffer. The trick-play client may then play back the video from the one or more cached 30 forward buffers. Process 900 ends at step 962. [0068] FIG. 10 is an illustrative flow chart for transmitting rewind and forward streams to user equipment 110. Process 1000 begins at step 1002. At -25 step 1010, server 130 receives videos from media source 120, for example in a real-time stream that is also provided to the instances of user equipment 110 of interactive media system 100. At step 1020, server 130 5 determines whether to record or cache some or all of the videos received at step 1010. Server 130 may determine whether to record or cache a particular video using any suitable criteria (e.g., popular videos or preferred video providers). In some embodiments, media 10 source 120, user equipment 110 or another device of interactive media system 100 may specify for server 130 which videos to cache or record. [0069] If, at step 1020, the server determines that no videos are to be recorded or cached, process 1000 15 moves to step 1062 and ends. If instead, at step 1020, the server determines that at least one_ particular video is to be recorded or cached, process 1000 caches the at least one particular video and moves to step 1030. In some embodiments, process 1000 may skip 20 step 1020 and simply record or cache every video. [0070] At step 1030, server 130 receives a request from the trick-play client implemented on user equipment 110 for a video. The trick-play client may request a rewind stream of video that was transmitted 25 before the user of the trick-play client started viewing the video. The trick-play client may also or instead request a forward stream of video that has not yet been transmitted by the real-time stream provided by the media source. 30 [0071] At step 1040, server 130 determines whether server 130 has recorded or cached the video required for the requested streams. For example, when a user requests a forward stream, the server may determine -26 whether it has already recorded or cached the requested video in its entirety. If server 130 determines that it has not recorded or cached the video required for all of the requested streams, process 1000 moves to 5 step 1062 and ends. [0072] If instead, at step 1040, server 130 determines that it has recorded or cached at least some of the video required for the requested streams, process 1000 moves to step 1050. For example, 10 server 130 may determine that it has cached the video needed for a rewind stream, but not the video required for a forward stream. At step 1050, server 130 generates at least one requested stream (e.g., a forward stream or a rewind stream) with the video 15 required for the stream. At step 1060, server 130 transmits the at least one requested stream generated at step 1050 over communications path 122 to the trick play client implemented on user equipment 110. Process 1000 ends at step 1062. 20 [0073] FIG. 11 is an illustrative flow chart for playing back a video that has been cached in a rewind buffer and in a forward buffer with user equipment 110. Process 1100 begins at step 1102. At step 1110, the trick-play client receives a user request to play back 25 at least a portion of a video cached in a rewind buffer and a forward buffer from the buffers. For example, the trick-play client may receive a user request to play back a video from the beginning. [0074] At step 1120, the trick-play client 30 identifies the video frame from which the user would like to start playing back the video. For example, if the user, while rewinding the video from the rewind buffer, selects a "play" key, the trick-play client may -27 identify the video frame displayed at the time the user selected the "play" key. [0075] At step 1130, the trick-play client determines whether the video frame identified at S step 1120 is in the rewind buffer. If the trick-play client determines that the video frame is in the rewind buffer, process 1100 moves to step 1140. At step 1140, the trick-play client displays the identified frame on display device 112, and subsequently moves towards the 10 beginning of the rewind buffer and displays the next frames cached in the rewind buffer. For example, if the rewind buffer begins at frame F., ends at frame FO (i.e., the beginning of the program), and the trick play client identified frame Fi, the trick-play client 15 displays frame Fi, then frame Fi+,, frame Fi+2, all the way to frame F.. In other words, the trick-play client moves through the buffer with a first-in, last-out scheme. [0076] At step 1150, the trick play client displays 20 the last frame of the rewind buffer and migrates to the forward buffer. In some embodiments, the trick-play client may instead migrate to a real-time buffer (e.g., if there is no forward buffer, or if there is a real time buffer between the rewind buffer and the forward 25 buffer). [0077] At step 1160, the trick play client displays the first frame of the forward buffer on display device 112, and subsequently moves towards the end of the forward buffer and displays the next frames cached 30 in the forward buffer. For example, if the forward buffer begins at frame F,, ends at frame Fy (i.e., the end of the program), the trick-play client displays frame F,, then frame Fn+1, frame Fn+ 2 , all the way to -28 frame Fy. In other words, the trick-play client moves through the buffer with a first-in, first-out scheme. [0078] Process 1100 may also access step 1160 if, at step 1130, the trick-play client determines that the video frame is not in the 5 rewind buffer (e.g., the identified frame is in the forward buffer). In that case, instead of the trick-play client first displaying the first frame of the forward buffer, the trick-play client first displays the frame identified at step 1120. Process 1100 then ends at step 1162. 10 [0079] The above described embodiments of the present invention are presented for purposes of illustration and not of limitation, and the present invention is limited only by the claims which follow. [0080] Throughout this specification, including the claims, where the context permits, the term "comprise" and variants thereof 15 such as "comprises" or "comprising" are to be interpreted as including the stated integer or integers without necessarily excluding any other integers.

Claims (20)

1. A method for rewinding or fast-forwarding a non-on-demand video, comprising: processing viewing criteria; selecting a video for enhanced rewind and fast-forward functionality based on the processed viewing criteria; storing the selected video with a server based on the processed viewing criteria; transmitting the stored video in response to a request for a forward or reverse stream.
2. The method of claim 1, wherein the viewing criteria comprises: user viewing history, programs or channels that a user watches, sets reminders for or records, user interests identified in a user profile, or programs that the user watches while another program is recorded.
3. The method of claim 2, wherein the viewing criteria comprises: a plurality of user viewing histories, programs or channels that a plurality of users watch, set reminders for or record, user interests identified in a plurality of user profiles, or programs that a plurality of users watch while another program is recorded.
4. The method of claim 1 further comprising: storing content scheduled prior to the selected video with the server. - 30
5. The method of claim 1 further comprising: storing, with the server, all content associated with a channel based on the processed viewing criteria.
6. The method of claim 1 further comprising: charging a fee to the media provider of the selected video for enhanced rewind and fast-forward functionality.
7. The method of claim 1 further comprising: identifying the selected video for storing, by a phrase or indicator.
8. The method of claim 1 further comprising: allocating an amount of memory to a user for storing selected videos for enhanced rewind and fast-forward functionality.
9. The method of claim 1 further comprising: storing the information about users that have access to enhanced rewind and fast-forward functionality of the video.
10. The method of claim 1 further comprising: receiving a request from user equipment to store a video for rewind and fast-forward functionality.
11. A system for rewinding or fast-forwarding a non-on-demand video, comprising: means for processing viewing criteria; means for selecting a video for enhanced rewind and fast forward functionality based on the processed viewing criteria; means for storing the selected video with a server based on processed viewing criteria; - 31 means for transmitting the stored video in response to a request for a forward or reverse stream.
12. The system of claim 11, wherein the viewing criteria comprises: user viewing history, programs or channels that a user watches, set reminders for or records, user interests identified in a user profile, or programs that the user watches while another program is recorded.
13. The system of claim 11, wherein the viewing criteria comprises: a plurality of user viewing histories, programs or channels that a plurality of users watch, set reminders for or record, user interests identified in a plurality of user profiles, or programs that a plurality of users watch while another program is recorded.
14. The system of claim 11 further comprising: means for storing content scheduled prior to the selected video with the server.
15. The system of claim 11 further comprising: means for storing, with the server, all content associated with a channel based on the processed viewing criteria.
16. The system of claim 11 further comprising: - 32 means for charging a fee to the media provider of the selected video for enhanced rewind and fast-forward functionality.
17. The system of claim 11 further comprising: means for identifying the selected video for storing, by a phrase or indicator.
18. The system of claim 11 further comprising: means for allocating an amount of memory to a user for storing selected videos for enhanced rewind and fast-forward functionality.
19. The system of claim 11 further comprising: means for storing the information about users that have access to enhanced rewind and fast-forward functionality of the video.
20. The system of claim 11 further comprising: means for receiving a request from user equipment to store a video for rewind and fast-forward functionality.
AU2013203318A 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions Active AU2013203318B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU2013203318A AU2013203318B2 (en) 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US11/365,787 2006-02-28
AU2012216855A AU2012216855B2 (en) 2006-02-28 2012-09-14 Systems and Methods for Enhanced Trick-Play Functions
AU2013203318A AU2013203318B2 (en) 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
AU2012216855A Division AU2012216855B2 (en) 2006-02-28 2012-09-14 Systems and Methods for Enhanced Trick-Play Functions

Publications (2)

Publication Number Publication Date
AU2013203318A1 AU2013203318A1 (en) 2013-05-02
AU2013203318B2 true AU2013203318B2 (en) 2014-07-17

Family

ID=48444741

Family Applications (3)

Application Number Title Priority Date Filing Date
AU2013203314A Active AU2013203314B2 (en) 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions
AU2013203320A Active AU2013203320B2 (en) 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions
AU2013203318A Active AU2013203318B2 (en) 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions

Family Applications Before (2)

Application Number Title Priority Date Filing Date
AU2013203314A Active AU2013203314B2 (en) 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions
AU2013203320A Active AU2013203320B2 (en) 2006-02-28 2013-04-10 Systems and Methods for Enhanced Trick-Play Functions

Country Status (1)

Country Link
AU (3) AU2013203314B2 (en)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030046702A1 (en) * 2001-09-03 2003-03-06 Gen Sasaki Program server and a receiver
US20050262529A1 (en) * 2004-05-20 2005-11-24 Raja Neogi Method, apparatus and system for remote real-time access of multimedia content

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7401351B2 (en) * 2000-12-14 2008-07-15 Fuji Xerox Co., Ltd. System and method for video navigation and client side indexing
EP1251515A1 (en) * 2001-04-19 2002-10-23 Koninklijke Philips Electronics N.V. Method and system for selecting a position in an image sequence
US20050166230A1 (en) * 2003-03-18 2005-07-28 Gaydou Danny R. Systems and methods for providing transport control
KR100564452B1 (en) * 2003-04-03 2006-03-29 엘지전자 주식회사 Video recording/playback apparatus and method
JP4203741B2 (en) * 2003-09-25 2009-01-07 日本電気株式会社 Data reproducing apparatus and data reproducing method

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030046702A1 (en) * 2001-09-03 2003-03-06 Gen Sasaki Program server and a receiver
US20050262529A1 (en) * 2004-05-20 2005-11-24 Raja Neogi Method, apparatus and system for remote real-time access of multimedia content

Also Published As

Publication number Publication date
AU2013203320A1 (en) 2013-05-02
AU2013203318A1 (en) 2013-05-02
AU2013203314B2 (en) 2013-06-06
AU2013203320B2 (en) 2015-06-04
AU2013203314A1 (en) 2013-05-02

Similar Documents

Publication Publication Date Title
US11956514B2 (en) Systems and methods for enhanced trick-play functions
AU2013203318B2 (en) Systems and Methods for Enhanced Trick-Play Functions
AU2012216855B2 (en) Systems and Methods for Enhanced Trick-Play Functions
AU2006339439B2 (en) Systems and methods for enhanced trick-play functions

Legal Events

Date Code Title Description
FGA Letters patent sealed or granted (standard patent)