US7624128B2 - Method and apparatus for synchronizing EPG information between server and client - Google Patents
Method and apparatus for synchronizing EPG information between server and client Download PDFInfo
- Publication number
- US7624128B2 US7624128B2 US11/515,015 US51501506A US7624128B2 US 7624128 B2 US7624128 B2 US 7624128B2 US 51501506 A US51501506 A US 51501506A US 7624128 B2 US7624128 B2 US 7624128B2
- Authority
- US
- United States
- Prior art keywords
- synchronization
- file
- information
- files
- server
- 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.)
- Expired - Fee Related, expires
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/25—Management operations performed by the server for facilitating the content distribution or administrating data related to end-users or client devices, e.g. end-user or client device authentication, learning user preferences for recommending movies
- H04N21/262—Content or additional data distribution scheduling, e.g. sending additional data at off-peak times, updating software modules, calculating the carousel transmission frequency, delaying a video stream transmission, generating play-lists
- H04N21/26283—Content or additional data distribution scheduling, e.g. sending additional data at off-peak times, updating software modules, calculating the carousel transmission frequency, delaying a video stream transmission, generating play-lists for associating distribution time parameters to content, e.g. to generate electronic program guide data
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/47—End-user applications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/10—File systems; File servers
- G06F16/18—File system types
- G06F16/182—Distributed file systems
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/242—Synchronization processes, e.g. processing of PCR [Program Clock References]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/43—Processing 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/433—Content storage operation, e.g. storage operation in response to a pause request, caching operations
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/80—Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
- H04N21/83—Generation or processing of protective or descriptive data associated with content; Content structuring
- H04N21/84—Generation or processing of descriptive data, e.g. content descriptors
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/16—Analogue secrecy systems; Analogue subscription systems
- H04N7/173—Analogue secrecy systems; Analogue subscription systems with two-way working, e.g. subscriber sending a programme selection signal
- H04N7/17309—Transmission or handling of upstream communications
- H04N7/17318—Direct or substantially direct transmission and handling of requests
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10S—TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10S707/00—Data processing: database and file management or data structures
- Y10S707/99931—Database or file accessing
- Y10S707/99938—Concurrency, e.g. lock management in shared database
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10S—TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10S707/00—Data processing: database and file management or data structures
- Y10S707/99951—File or database maintenance
- Y10S707/99952—Coherency, e.g. same view to multiple users
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10—TECHNICAL SUBJECTS COVERED BY FORMER USPC
- Y10S—TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y10S707/00—Data processing: database and file management or data structures
- Y10S707/99951—File or database maintenance
- Y10S707/99952—Coherency, e.g. same view to multiple users
- Y10S707/99953—Recoverability
Definitions
- Apparatuses and methods consistent with the present invention relate to data synchronization between a server and a client, and more particularly, to synchronizing EPG information between a server and a client in a digital broadcasting network.
- TV cable television
- satellite cable TV service providers have entered into the market.
- the service providers use tens to hundreds of channels.
- Information on the channels has to be provided to create a TV time table and to notify that the channels exist.
- a service provider allocates a specific channel as an electronic program guide (EPG) channel to provide the channel information.
- EPG electronic program guide
- TV viewers passively observe the channel information scrolling on a TV screen.
- a method has been needed in which information on TV program is transferred through a network, and the information is stored in a client system so that the information can be immediately obtained at the request of a user.
- the information is provided along with program and system information protocol (PSIP) data to be analyzed in the client system.
- PSIP program and system information protocol
- the amount of information obtained in this way is small. For this reason, the information has to be provided through a network to provide larger and better information.
- EPG personal video recorder
- FIG. 1 illustrates a structure of a related art digital broadcasting system for synchronizing EPG information.
- the system of FIG. 1 is disclosed in the Korean Patent No. 10-0385328.
- a server administrator adds, deletes, or updates the EPG information
- the server cyclically creates a synchronization file whenever the EPG information is modified.
- clients each of which has different synchronization times with each other, separately receive relevant synchronization files to synchronize the EPG information. This will be now described in detail with reference to FIG. 1 .
- an update date tracing unit 101 writes a modification time into a server database 107 along with information on which actions (insert/delete/update) have been carried out.
- FIG. 2 illustrates a modification history table stored in the server database 107 and a file to be transferred.
- an update data creating unit 105 extracts records corresponding to a predetermined time period from the server database 107 to be stored in a file storing unit 109 . For example, if an update file is created twice a day at 10:00 and 22:00, each synchronization file is configured according to the EPG information modified between 22:01 to 09:59 and 10:01 to 21:59.
- a PVR scheduler 115 When it is time to update the EPG information, a PVR scheduler 115 generates an event therefore and requests data from the server via a downloader unit 113 .
- the synchronization file is transmitted through a data providing unit 111 , and a client system requests a retransmission of required synchronization files included in a synchronization file list.
- the synchronization files are stored in the file storing unit 109 .
- a data update unit 119 reads the synchronization files and updates a PVR database 121 according to the content of the synchronization files.
- the synchronization files created at the server-side include all content modified during the time period.
- unnecessary content is also included in the synchronization files. This causes file size to increase, thereby deteriorating file transfer efficiency.
- the server administrator deletes an item three times and inserts the item four times. This is the same as in the case when no modification occurs ever since the item is inserted at 07:10. Every modification history is stored in the server database in the order of a time sequence. Also, a synchronization file to be transmitted to the client system includes all the modification history.
- every synchronization file created before current data is configured is received and its database is updated according to the modified history recorded in the synchronization file. Consequently, the same process performed at the server-side has to be repeated at the client-side, thereby performing unnecessary operations.
- the present invention provides a method and apparatus for effectively synchronizing EPG information between a server and a client, in which a new modification history is applied to all existing synchronization files whenever the EPG information is updated, and data relating to unnecessary EPG information is deleted from a server database after a synchronization file is created.
- a method of providing synchronization files to clients so as to synchronize server-side EPG information with EPG information pieces of the clients comprising: (a) updating synchronization files, that are created respectively according to the updates of the server-side EPG information, according to information which is modified after a last synchronization file is created; (b) creating a synchronization file according to information which is modified after the last synchronization file is created; and (c) transferring a synchronization file to one of the clients, where the synchronization file is created first after the EPG information of the client is updated among from the synchronization files updated in the operation (a) and the synchronization file created in the operation (b).
- the method may further comprise: writing action type information into an action type field of an item modified in an EPG table whenever EPG information is updated; and initializing the action type field after the synchronization file is created in the operation (b), wherein, in the operation (a), the modified information is recognized with reference to the action type field.
- the present invention also provides a computer-readable medium having embodied thereon a computer program for executing any one of the method of providing synchronizing files to clients, where the synchronization files are provided by a server to synchronize server-side EPG information with each of client-side EPG information pieces.
- a server apparatus for providing synchronization files to clients so as to synchronize server-side EPG information with EPG information pieces of the clients, the apparatus comprising: a file storing unit which stores synchronization files created respectively according to the updates of the server-side EPG information; a scheduler which generates an event to create a synchronization file according to items that are modified in an EPG table after the last synchronization file among the previous synchronization files are created; an update information synchronizer which updates all previous synchronization files stored in the file storing unit according to the modified items when the event is generated, creates a synchronization file based on the modified items, and stores the synchronization file to the file storing unit; and a file transfer unit which transfers a synchronization file to one of the clients, where the synchronization file is created first after the EPG information of the client is updated among from the synchronization file stored in the file storing unit.
- a method of synchronizing client-side EPG information with server-side EPG information in a digital broadcasting network comprising: receiving a list of synchronization files created according to the update of the server-side EPG information; selecting a synchronization file in the list of the synchronization files, which is created first after a latest update time of the client-side EPG information, and receiving the synchronization file; and updating the EPG information by using the received synchronization file.
- all of the synchronization files in the list may include a modification history of the server-side EPG information from the time of file creation up to the present.
- the present invention also provides a computer-readable medium having embodied thereon a computer program for executing any one of the method of synchronizing client-side EPG information with server-side EPG information in a digital broadcasting network.
- a client apparatus for synchronizing client-side EPG information with server-side EPG information in a digital broadcasting network
- the apparatus comprising: a file determining unit which determines a file to be received which is included in a synchronization file list, where the file is a synchronization file created first after client-side EPG information is updated to the latest version; a file requesting unit which requests a synchronization file selected in the file determining unit to a sever; and an update unit which updates the client-side EPG information by using a synchronization file received in response to the file request.
- the synchronization files in the list may reflect the recent EPG information of the server-side.
- synchronization files in the list may be created such that each file name thereof includes information on a file creation date and time.
- FIG. 1 illustrates a structure of a conventional digital broadcasting system for synchronizing EPG information
- FIG. 2 illustrates the content of a synchronization file for synchronizing EPG information according to the prior art
- FIG. 3 is a flowchart illustrating a process of creating a server-side synchronization file according to an exemplary embodiment of the present invention
- FIGS. 4A to 4B illustrate EPG tables according to an exemplary embodiment of the present invention
- FIGS. 5A and 5B illustrate source codes of synchronization files written in the xml format according to an exemplary embodiment of the present invention
- FIG. 6 illustrates a structure of a digital broadcasting system according to an exemplary embodiment of the present invention
- FIG. 7 illustrates a structure of an update information synchronizer according to an exemplary embodiment of the present invention
- FIG. 8 is a flowchart of a process of a first synchronizer according to an exemplary embodiment of the present invention.
- FIG. 9 is a flowchart of a process of a second synchronizer according to an exemplary embodiment of the present invention.
- FIGS. 10A to 10B are flowcharts of a process of creating a synchronization file in a server according to an exemplary embodiment of the present invention
- FIG. 11 illustrates a process of creating a synchronization file according to an exemplary embodiment of the present invention
- FIG. 12 illustrates a process of creating a synchronization file according to another exemplary embodiment of the present invention
- FIG. 13 is a flowchart of a process of a synchronization file manager according to an exemplary embodiment of the present invention.
- FIG. 14 illustrates a structure of a client according to an exemplary embodiment of the present invention.
- FIG. 15 is a flowchart of a process of a synchronization file manager according to another exemplary embodiment of the present invention.
- FIG. 3 is a flowchart illustrating a process of creating a server-side synchronization file according to an exemplary embodiment of the present invention.
- the synchronization file stores modification history of server-side EPG in order to update client-side EPG information.
- the synchronization file is cyclically created and includes the latest update history.
- the content of the synchronization file may be written in extensible markup language (XML) format as shown in FIG. 5 .
- XML extensible markup language
- programs may be written using ⁇ Ins>, ⁇ Upd>, and ⁇ Del> tags.
- FIGS. 5A and 5B will be described in detail later.
- a server When a server administrator updates EPG information (operation 310 ), a server writes action type information (i.e., insert, delete, update, etc.) to an EPG table (operation 320 ).
- action type information i.e., insert, delete, update, etc.
- EPG table When a sever scheduler generates an event to generate a synchronization file, information is extracted on items which have been actually modified thereafter.
- a previously created synchronization file exists in a file storing unit for storing the synchronization file. If it does not exist, an initial synchronization file is created so that it includes all items contained in a current EPG table, and the initial synchronization file is then stored in the file storing unit (operation 350 ). If it exists, previous synchronization files are updated according to the modified items (operation 360 ). Thereafter, a last synchronization file is created so that it includes only the modified items (operation 370 ). Thereafter, items deleted by the server administrator, that is, items of which action type is DEL, are deleted from a database.
- all clients can obtain the latest EPG information by downloading only the next subsequent version of a current synchronization file regardless of the latest EPG update time of the clients, and the server no longer has to store data relating to deleted items.
- FIGS. 4A to 4B illustrate EPG tables according to an exemplary embodiment of the present invention.
- item 5 is inserted in the case when programs corresponding to items 1 to 4 already exist.
- a user inserts, deletes, or updates data, it is written in the action type field.
- the action field unmodified items stay in an initial state of NULL.
- the action file is reinitialized to NULL.
- the action type field is not NULL, it shows that modification has occurred at least once.
- the synchronization file is created according to a modification history, and then all of the action type fields are initialized to NULL.
- the action type field is initialized after the synchronization file is created according to the modification history, when items are updated at a later time, it is possible to determine which items have been updated.
- FIGS. 5A and B illustrate source codes of synchronization files written in the xml format according to an exemplary embodiment of the present invention.
- items 1 , 4 , 6 , 9 , and 10 are inserted.
- items 6 , 9 , and 10 are inserted, item 1 is updated, and items 2 and 4 are deleted.
- the synchronization files include only an ID of an item in this exemplary embodiment, but all information on the item may be included in the synchronization file in practice.
- the synchronization file of FIG. 5A is the initial synchronization file which is the oldest synchronization file.
- the oldest synchronization file is transferred to a client along with other synchronization files. Further, the oldest synchronization file may be used to create reference information which is needed to apply the modification history to other synchronization files.
- Later version synchronization files are created according to only the items which have been updated with respect to the initial synchronization file.
- the initial synchronization file is first updated according to the current EPG information.
- the later version synchronization files are updated according to only the modification history applied to the initial synchronization file, so that all synchronization files can include the current EPG information.
- the latest EPG information can be obtained by just downloading the initial synchronization file. Referring to FIG. 5A , the initial synchronization file has only ⁇ Ins> tags.
- FIG. 6 illustrates a structure of a digital broadcasting system according to an exemplary embodiment of the present invention.
- a server 607 includes a server scheduler 601 , an update information synchronizer 602 , an update history setting unit 603 , a server database 606 , a file transfer unit 605 , a synchronization file manager 604 and a file storing unit 620 .
- a client 614 includes a client scheduler 609 , a file requesting unit 610 , a file determining unit 611 , an update unit 613 , and a client database 612 .
- the server scheduler 601 generates an event to notify the need to create a synchronization file for items in the EPG table, the items which have been modified since the latest synchronization file was created.
- the update information synchronizer 602 extracts items which have been modified during a predetermined time period from the EPG table, updates all previous synchronization files stored in a file storing unit 620 , creates the latest synchronization file updated according to only the modified items, and stores the latest synchronization file into the file storing unit 620 .
- the update history setting unit 603 When the server administrator updates server-side EPG information, the update history setting unit 603 writes action type information of each item into the EPG table to be stored in the server database 606 . Further, the update history setting unit 603 initializes action type fields of the EPG table to NULL when the update information synchronizer 602 creates the latest synchronization file. Action type fields show which items have been updated after a new time period starts, and the update information synchronizer 602 recognizes modified items according to the action type field values.
- the file transfer unit 605 transfers a synchronization file list or a synchronization file, and the server database 606 stores the EPG information.
- the synchronization file manager 604 deletes old synchronization files from the server database 606 . However, since the initial synchronization file has to exist all the time, the content of the initial synchronization file has to be copied to a second oldest file stored in the file storing unit 620 prior to the deletion the initial synchronization file. This will be described in detail later.
- the client scheduler 609 When it is time for the client 614 to update the EPG information, the client scheduler 609 generates an event. Then, the file requesting unit 610 requests the synchronization file list from the server 607 by sending a request to the server 607 .
- the file determining unit 611 determines the synchronization file to be received which is included in the synchronization file list, where the synchronization file is a synchronization file created first after the client-side EPG information has been updated to the latest version. Then, the file requesting unit 610 requests the server 607 to transfer the synchronization file determined by the file determining unit 611 .
- the update unit 613 updates the client-side EPG information according to the received synchronization file.
- the client database 612 stores the updated EPG information.
- the client scheduler 609 generates an event to download the synchronization file for synchronizing the EPG information.
- the client 614 can synchronize its EPG information with the EPG information of the server 607 by downloading a next subsequent version of a current synchronization file.
- the client 614 has to know not only the version of the synchronization file currently stored in the client 614 but also the version of the synchronization file stored in the server 607 .
- the server 607 has to know the version of the synchronization file stored in the server 607 . For this reason, when the server 607 generates the synchronization file, the data and time of file creation may be included in a file name.
- FIG. 7 illustrates a structure of an update information synchronizer according to an exemplary embodiment of the present invention.
- an update information synchronizer 710 includes a first synchronizer 711 , an extractor 712 , and a second synchronizer 713 .
- the extractor 712 extracts modified items from a server database 706 according to the action type field value as described above.
- the first synchronizer 711 updates an initial synchronization file by using the extracted items. Not all of the items extracted by the extractor 712 are used in updating the initial synchronization file, in practice. This will be described in detail later with reference to FIGS. 8 and 12 .
- the second synchronizer 713 updates the rest of the synchronized files according to items which are used in updating the initial synchronization file, in practice.
- FIG. 8 is a flowchart of a process of the first synchronizer 711 according to an exemplary embodiment of the present invention.
- the first synchronizer 711 refers to the action type fields of each item (operation 801 ) and determines whether a field value thereof is UPD (operation 802 ). If it is UPD, whether an ID exists within the ⁇ Ins> or ⁇ Upd> tags in the initial synchronization file (operation 805 ) is checked. If it exists, the content of the file is updated (operation 807 ). If it does not exist, the action type fields of the extracted items are modified to INS (operation 808 ) to be inserted within the ⁇ Ins> tag in the initial synchronization file (operation 811 ).
- the action type field of the item extracted by the extractor 712 indicates UPD.
- the initial synchronization file created according to only its previous version synchronization file does not even recognize that the item has been inserted.
- the initial synchronization file recognizes this as INS instead of UPD.
- operation 803 If the action type field indicates DEL (operation 803 ), whether the ID exists in the ⁇ Ins> or ⁇ Upd> tags of the initial synchronization file (operation 806 ) is checked. If it exists, the ID is deleted (operation 810 ). If it does not exist, the content of the item is deleted from the extracted items (operation 809 ).
- the action type field indicates INS (operation 804 )
- the content of the ID is inserted within the ⁇ Ins> tag of the initial synchronization file (operation 811 ).
- the extracted items are modified at the same time the initial synchronization file is updated.
- the reference information will be referred to as update reference information.
- the initial synchronization file does not exist when the aforementioned operations are performed, the content of the initial synchronization file may be referred to. Alternatively, every operation for modifying the initial synchronization file may be treated as an error or be cancelled.
- FIG. 9 is a flowchart of a process of the second synchronizer 713 according to an exemplary embodiment of the present invention.
- the second synchronizer 713 updates the rest of the synchronization files instead of the initial synchronization file.
- the action type field of the update reference information is referred to (operation 901 ). Thereafter, if the action type field value is UPD (operation 902 ), whether an ID exists within the ⁇ Ins> or ⁇ Upd> tags in a file to be transferred (operation 905 ) is checked. If the ID exists, the content of the ID is updated (operation 907 ). If the ID does not exist, the ID is inserted within the ⁇ Upd> tag of the synchronization file (operation 908 ).
- action type field value is DEL (operation 903 )
- whether the ID exists in the ⁇ Ins> or ⁇ Upd> tags of the synchronization file is checked. If the ID exists, the ID is deleted (operation 910 ). If the ID does not exist, the ID is inserted within the ⁇ Del> tag of the file to be transferred (operation 909 ).
- FIGS. 10A to B are flowcharts of a process of creating the synchronization file in the server according to an exemplary embodiment of the present invention.
- the current action type is written on the action type field of the EPG table to be stored in the database.
- the update information synchronizer updates the synchronization files according to the modification history of the EPG table. For this, the action type field of the EPG table is first referred to from the database to extract items which are not NULL (operation 1004 ). Next, it is determined whether the synchronization file exists (operation 1005 ). If it exists, the update reference information is created at the same time the initial synchronization file is updated as described above (operation 1007 ). If it does not exist, the initial synchronization file is created so that all items of the current EPG table are inserted into the initial synchronization file (operation 1013 ).
- the rest of the synchronization files are all updated (operations 1008 to 1012 ). If the last modification history is applied to all of the synchronization files, and the synchronization file configured according to only the last modification history is created (operation 1013 ), the items of which the action field value in the EPG table is DEL are completely deleted from the database, and all of the action type field values of the EPG table are initialized to NULL.
- FIG. 11 illustrates a process of creating a synchronization file according to an exemplary embodiment of the present invention.
- the server administrator inputs data to update EPG information (operation S 10 ). Then, according to the input data, the update history setting unit writes action type information of each item to action type fields of an EPG table.
- FIG. 11 shows an EPG table 1130 with fields for ID, Action, Channel Number (“ChNum”), Start Time (“S TIME”), End Time (“E TIME”) and TITLE. There are no inserted items in the first EPG table 1130 . At a later time, four items are inserted in an EPG table 1140 to reflect the four items in the EPG 1145 . In this case, four items are modified, and the action type thereof is INS.
- the update information synchronizer extracts the modified items according to the action type field of the EPG table (operation S 50 ). In order to create the update reference information, the update information synchronizer loads the initial synchronization file to a memory (operation S 60 ). Since the initial synchronization file does not exist in this time, an initial synchronization file 1100 is created in which four items are inserted (operation S 70 ). Up to now, update reference information 1110 is the same to the items extracted in operation S 50 . When the synchronization file is created, the update information synchronizer initializes all of the action type fields of an EPG table 1150 to NULL (operations S 90 ).
- FIG. 12 illustrates a process of creating a synchronization file according to another exemplary embodiment of the present invention.
- An EPG table 1240 contains five items to reflect the five items on the EPG 1245 .
- an initial synchronization file 1220 and a synchronization file 1260 exist.
- items of ID 2 and ID 3 are all replaced by ID 6
- ID 5 is replaced by ID 7
- ID 1 is updated
- ID 8 is inserted and then deleted.
- ID 2 which was listed to run between 10:00 and 11:00
- ID 3 which was listed to run between 11:00 and 12:00
- ID 6 which is listed to run between 10:00 and 12:00
- the programming referred to as ID 5 which is listed to run between 13:00 and 14:00, is replaced by ID 7 which runs between 13:00 and 15:00, as shown in the EPG 1245 .
- each item of an EPG table 1250 is modified.
- Update reference information 1210 is extracted to be applied to the initial synchronization file 1220 , thereby creating an updated initial synchronization file 1230 .
- Newly inserted ID 6 and ID 7 are inserted within the ⁇ Ins> tag of the initial synchronization file 1220 . Since ID 1 already exists within the ⁇ Ins> tag, the updated content is overwritten.
- ID 2 , 3 , and 5 are deleted since they exist within the ⁇ Ins> tag, but ID 8 is not deleted since it does not exist within any tags. Therefore, the content of ID 8 is deleted from the extracted items to generate update reference information 1203 .
- the previous synchronization files are updated according to the created update reference information 1203 .
- a synchronization file 1270 is updated by using the previous synchronization file 1260 . That is, ID 5 is deleted from the ⁇ Ins> tag, and the rest of items are inserted within relevant tags.
- a last synchronization file 1290 is created which contains only the update reference information.
- each synchronization file may include a file creation date and time so as to know the order of file creation.
- FIG. 13 is a flowchart of a process of the synchronization file manager 604 according to an exemplary embodiment of the present invention.
- old synchronization files need to be deleted starting from the oldest synchronization file, since the content of the old files become the same with each other over time. For example, if a valid time period of EPG information is set to one week, synchronization files which have been created more than one week ago are deleted. In this case, as describe above, the initial synchronization file has to exist all the time due to the characteristics of the synchronization system of the present invention. Thus, a later version synchronization file needs to be configured to be the new initial synchronization file prior the deletion of the initial synchronization file.
- the later version synchronization file is the second oldest file, following the first synchronized file.
- the later version synchronization file will be referred to as a preliminary synchronization file.
- the scheduler When the scheduler generates an event to delete the initial synchronization file after a predetermined time elapses (operation 1310 ), the initial synchronization file and the preliminary synchronization file are loaded in a memory (operation 1320 ). Next, the content written within the ⁇ Upd> and ⁇ Del> tags in the preliminary synchronization file is all deleted (operation 1330 ). Thereafter, the content of the ⁇ Ins> tag of the initial synchronization file and the preliminary synchronization file are compared with each other, and IDs which exist only in the initial synchronization file are inserted within the ⁇ Ins> tag of the preliminary synchronization file (operation 1340 ).
- the preliminary synchronization file has content indicating that all of the items included in the current EPG information have to be inserted. Thereafter, the initial synchronization file is deleted, and the file name of the modified preliminary synchronization file is determined to be the same as the initial synchronization file (operation 1350 ).
- FIG. 14 illustrates a structure of a client 1414 according to an exemplary embodiment of the present invention.
- the client 1414 includes a client scheduler 1409 , a file requesting unit 1410 , a file determining unit 1411 , a database (DB) 1412 , and an update unit 1413 .
- DB database
- the client scheduler 1409 generates an event to update the EPG information after a predetermined time elapses.
- the file determining unit 1411 determines a synchronization file to be received which is included in the list of synchronization files received from the server 607 through the file requesting unit 1410 . For this, a system update time has to be stored in the client 1414 whenever the EPS information is updated in the DB 1412 .
- the system update time is referred to so that the synchronization file to be received can be determined to be a file created right after the system update time among from the server-side synchronization files. This is because the file contains all content updated from when the client 1414 updates the EPG information up to the present.
- the synchronization file name includes the file creation date and time.
- the synchronization file name may be “Update.20050531.10.epg”, which indicates that the synchronization file was created at 2005, May, 31, 10:00 am.
- the file determining unit 1411 can select a required synchronization file according to the file name.
- the file requesting unit 1410 requests the server 607 to transfer the synchronization file selected by the file determining unit 1411 .
- the update unit 1413 updates the EPG information stored in the DB 1412 by using the received synchronization file.
- FIG. 15 is a flowchart of a process of the synchronization file manager 604 according to another exemplary embodiment of the present invention.
- the client scheduler 1409 generates an event to update the EPG (operation 1510 ). Then, the synchronization file list is requested from and received from the server 607 (operation 1520 ). To determine the synchronization file to be received in the synchronization file list, a last update time stored in the DB 1412 is referred to (operation 1530 ). The synchronization file created first after the last EPG update time has elapsed, is selected (operation 1540 ). When the synchronization file is selected, the file creation date and time included in the file name are referred to.
- a storage space can be saved since unnecessary data is not stored after EPG information is updated.
- network resources required to transfer a synchronization file can be saved since the file size is reduced according to only a last update state of the EPG information without having to include all update history when the synchronization file is created in a server.
- client-side EPG information can be easily synchronized with sever-side EPG information by downloading only one synchronization file created first after the currently stored last synchronization file was created regardless of when the latest EPG information was updated.
- the exemplary embodiments of the present invention can be written as computer programs and can be implemented in general-use digital computers that execute the programs using a computer readable recording medium.
- Examples of the computer readable recording medium include magnetic storage media (e.g., ROM, floppy disks, hard disks, etc.) and optical recording media (e.g., CD-ROMs, or DVDs).
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Information Transfer Between Computers (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
Abstract
Description
Claims (21)
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR10-2005-0081999 | 2005-09-03 | ||
KR1020050081999A KR100739729B1 (en) | 2005-09-03 | 2005-09-03 | Method and device for synchronizing EPG information between a server and a client in a digital broadcast network |
Publications (2)
Publication Number | Publication Date |
---|---|
US20070055709A1 US20070055709A1 (en) | 2007-03-08 |
US7624128B2 true US7624128B2 (en) | 2009-11-24 |
Family
ID=37817960
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/515,015 Expired - Fee Related US7624128B2 (en) | 2005-09-03 | 2006-09-05 | Method and apparatus for synchronizing EPG information between server and client |
Country Status (4)
Country | Link |
---|---|
US (1) | US7624128B2 (en) |
JP (1) | JP2007074724A (en) |
KR (1) | KR100739729B1 (en) |
CN (1) | CN1925495B (en) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150112926A1 (en) * | 2013-10-23 | 2015-04-23 | Linkedin Corporation | Synchronizing channels lists |
EP4075815A4 (en) * | 2019-12-12 | 2023-04-05 | ZTE Corporation | Epg data management method, server, and readable storage medium |
Families Citing this family (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8245257B1 (en) * | 2002-09-30 | 2012-08-14 | Arris Group, Inc. | System and method for dynamic electronic program guide (EPG) data downloads |
CN101355676B (en) * | 2007-07-24 | 2010-07-07 | 华为技术有限公司 | Method for providing network television service information and network television service system |
CN101127915B (en) * | 2007-09-20 | 2011-04-20 | 中兴通讯股份有限公司 | Electronic program navigation data synchronization method and system based on incremental mode |
KR101223642B1 (en) * | 2007-10-19 | 2013-01-17 | 삼성전자주식회사 | Method and apparatus for transmitting additional data related broadcasting service and mathod and apparatus for receiving additional data related broadcasting service |
KR100890628B1 (en) * | 2007-12-11 | 2009-03-27 | 한국전자통신연구원 | Real-time si monitoring system and method for ip tv |
US8700750B2 (en) * | 2009-01-16 | 2014-04-15 | Microsoft Corporation | Web deployment functions and interfaces |
JP5061166B2 (en) | 2009-09-04 | 2012-10-31 | Kii株式会社 | Data synchronization system and data synchronization method |
CN101902613B (en) * | 2010-07-21 | 2014-06-04 | 中兴通讯股份有限公司 | Information synchronization method and system, set top box and server in IPTV (Internet Protocol Television) system |
WO2014017882A1 (en) * | 2012-07-27 | 2014-01-30 | 삼성전자 주식회사 | Terminal and server performing data synchronization |
US20140250069A1 (en) * | 2013-03-01 | 2014-09-04 | Appsense Limited | Systems and methods for selectively synchronizing files |
CN103220579B (en) * | 2013-05-07 | 2014-07-23 | 江苏省广电有线信息网络股份有限公司南京分公司 | Automatic processing method of time shift programme |
JP5766262B2 (en) * | 2013-12-12 | 2015-08-19 | シャープ株式会社 | Server device |
CN104301789A (en) * | 2014-09-28 | 2015-01-21 | 北京正奇联讯科技有限公司 | EPG system and real-time updating method for EPG information |
US10187678B2 (en) * | 2016-11-17 | 2019-01-22 | Rovi Guides, Inc. | Systems and methods for displaying segments of media guidance data |
US20180152740A1 (en) * | 2016-11-29 | 2018-05-31 | The Directv Group, Inc. | Centralized metadata retrieval |
FR3068561A1 (en) * | 2018-01-29 | 2019-01-04 | Sagemcom Broadband Sas | METHOD FOR PROVIDING AN ELECTRONIC PROGRAM GUIDE |
CN111291011B (en) * | 2020-02-19 | 2023-10-20 | 北京百度网讯科技有限公司 | File synchronization method and device, electronic equipment and readable storage medium |
Citations (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5475834A (en) * | 1992-10-26 | 1995-12-12 | International Business Machines Corporation | Integration of migration level two and backup tape processing using multiple inventory entries |
US5917481A (en) | 1995-03-31 | 1999-06-29 | Matsushita Electric Corporation Of America | Electronic television program guide with selective updating |
JP2000307968A (en) | 1999-04-20 | 2000-11-02 | Sony Corp | Method for transmitting and receiving electronic program information, electronic program information reception equipment and electronic program information transmission system |
KR20010058364A (en) | 1999-12-27 | 2001-07-05 | 구자홍 | method for processing data electronic program guide |
JP2003046979A (en) | 2001-08-02 | 2003-02-14 | Sony Corp | Device and method for processing information, recording medium, and program |
KR100385328B1 (en) | 2002-09-30 | 2003-05-23 | Digital & Digital Inc | System and method for providing electronic program guide information, subscriber terminal and method for updating electronic program guide information |
US20040078370A1 (en) * | 2002-10-17 | 2004-04-22 | International Business Machines Corporation | Method and apparatus for real time creation and modification of a change log for multi-server synchronization |
US20040103141A1 (en) * | 2002-11-19 | 2004-05-27 | Miller Quentin S. | Atomic message division |
US20040107199A1 (en) * | 2002-08-22 | 2004-06-03 | Mdt Inc. | Computer application backup method and system |
US20040117507A1 (en) * | 2002-11-13 | 2004-06-17 | (Nokia Corporation) | Arranging synchronization session |
US6763522B1 (en) * | 1998-06-30 | 2004-07-13 | Sony Corporation | System and method for a digital television electronic program guide |
US20040172423A1 (en) * | 2003-02-28 | 2004-09-02 | Microsoft Corporation | Method and system for synchronizing data shared among peer computing devices |
US20050091316A1 (en) * | 2003-10-03 | 2005-04-28 | Oscar Ponce | System and method for creating and selectively sharing data elements in a peer-to-peer network |
US6895586B1 (en) * | 2000-08-30 | 2005-05-17 | Bmc Software | Enterprise management system and method which includes a common enterprise-wide namespace and prototype-based hierarchical inheritance |
US20050125621A1 (en) * | 2003-08-21 | 2005-06-09 | Ashish Shah | Systems and methods for the implementation of a synchronization schemas for units of information manageable by a hardware/software interface system |
US20050144538A1 (en) * | 2001-11-01 | 2005-06-30 | Microsoft Corporation | System and method for replicating data in a distributed system |
US7383463B2 (en) * | 2004-02-04 | 2008-06-03 | Emc Corporation | Internet protocol based disaster recovery of a server |
Family Cites Families (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6769127B1 (en) * | 2000-06-16 | 2004-07-27 | Minerva Networks, Inc. | Method and system for delivering media services and application over networks |
JP2002369094A (en) * | 2001-06-12 | 2002-12-20 | Matsushita Electric Ind Co Ltd | System and method for acquiring program information |
JP2003124898A (en) * | 2001-10-15 | 2003-04-25 | Nippon Hoso Kyokai <Nhk> | Digital broadcast receiver and transmitter, and program arrangement information storage method and program arrangement information update method |
US20030196202A1 (en) * | 2002-04-10 | 2003-10-16 | Barrett Peter T. | Progressive update of information |
KR100468972B1 (en) * | 2002-10-23 | 2005-01-29 | 엘지전자 주식회사 | Update method for electronic program guide data |
CN1262121C (en) * | 2002-10-25 | 2006-06-28 | 休斯电子公司 | Program quide system |
JP4427994B2 (en) | 2003-08-13 | 2010-03-10 | ソニー株式会社 | Information processing apparatus and method, and program |
JP2005142753A (en) | 2003-11-05 | 2005-06-02 | Toshiba Corp | Apparatus and method for broadcast receiving, and apparatus and method for program recording |
JP2005222442A (en) * | 2004-02-09 | 2005-08-18 | Fujitsu Ltd | Generation information reference system of network operation system |
JP2004297828A (en) | 2004-05-28 | 2004-10-21 | Matsushita Electric Ind Co Ltd | Broadcast receiver |
-
2005
- 2005-09-03 KR KR1020050081999A patent/KR100739729B1/en active IP Right Grant
-
2006
- 2006-09-04 CN CN2006101289419A patent/CN1925495B/en not_active Expired - Fee Related
- 2006-09-04 JP JP2006239047A patent/JP2007074724A/en active Pending
- 2006-09-05 US US11/515,015 patent/US7624128B2/en not_active Expired - Fee Related
Patent Citations (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5475834A (en) * | 1992-10-26 | 1995-12-12 | International Business Machines Corporation | Integration of migration level two and backup tape processing using multiple inventory entries |
US5917481A (en) | 1995-03-31 | 1999-06-29 | Matsushita Electric Corporation Of America | Electronic television program guide with selective updating |
US6763522B1 (en) * | 1998-06-30 | 2004-07-13 | Sony Corporation | System and method for a digital television electronic program guide |
JP2000307968A (en) | 1999-04-20 | 2000-11-02 | Sony Corp | Method for transmitting and receiving electronic program information, electronic program information reception equipment and electronic program information transmission system |
KR20010058364A (en) | 1999-12-27 | 2001-07-05 | 구자홍 | method for processing data electronic program guide |
US6895586B1 (en) * | 2000-08-30 | 2005-05-17 | Bmc Software | Enterprise management system and method which includes a common enterprise-wide namespace and prototype-based hierarchical inheritance |
JP2003046979A (en) | 2001-08-02 | 2003-02-14 | Sony Corp | Device and method for processing information, recording medium, and program |
US20050144538A1 (en) * | 2001-11-01 | 2005-06-30 | Microsoft Corporation | System and method for replicating data in a distributed system |
US20040107199A1 (en) * | 2002-08-22 | 2004-06-03 | Mdt Inc. | Computer application backup method and system |
KR100385328B1 (en) | 2002-09-30 | 2003-05-23 | Digital & Digital Inc | System and method for providing electronic program guide information, subscriber terminal and method for updating electronic program guide information |
US20040078370A1 (en) * | 2002-10-17 | 2004-04-22 | International Business Machines Corporation | Method and apparatus for real time creation and modification of a change log for multi-server synchronization |
US20040117507A1 (en) * | 2002-11-13 | 2004-06-17 | (Nokia Corporation) | Arranging synchronization session |
US20040103141A1 (en) * | 2002-11-19 | 2004-05-27 | Miller Quentin S. | Atomic message division |
US20040172423A1 (en) * | 2003-02-28 | 2004-09-02 | Microsoft Corporation | Method and system for synchronizing data shared among peer computing devices |
US20050125621A1 (en) * | 2003-08-21 | 2005-06-09 | Ashish Shah | Systems and methods for the implementation of a synchronization schemas for units of information manageable by a hardware/software interface system |
US20050091316A1 (en) * | 2003-10-03 | 2005-04-28 | Oscar Ponce | System and method for creating and selectively sharing data elements in a peer-to-peer network |
US7383463B2 (en) * | 2004-02-04 | 2008-06-03 | Emc Corporation | Internet protocol based disaster recovery of a server |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150112926A1 (en) * | 2013-10-23 | 2015-04-23 | Linkedin Corporation | Synchronizing channels lists |
US9218357B2 (en) * | 2013-10-23 | 2015-12-22 | Linkedin Corporation | Synchronizing channels lists |
EP4075815A4 (en) * | 2019-12-12 | 2023-04-05 | ZTE Corporation | Epg data management method, server, and readable storage medium |
Also Published As
Publication number | Publication date |
---|---|
US20070055709A1 (en) | 2007-03-08 |
JP2007074724A (en) | 2007-03-22 |
CN1925495A (en) | 2007-03-07 |
KR20070025631A (en) | 2007-03-08 |
CN1925495B (en) | 2011-05-18 |
KR100739729B1 (en) | 2007-07-13 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7624128B2 (en) | Method and apparatus for synchronizing EPG information between server and client | |
US10206000B2 (en) | Receiving apparatus, receiving method, and program | |
US10412451B2 (en) | Storing same channel overlapping recordings | |
JP6387036B2 (en) | Reception device and reception method, and transmission device and transmission method | |
US20180376100A1 (en) | Receiving device, receiving method, transmitting device, and transmitting method | |
JP6408762B2 (en) | Receiving apparatus, receiving method, and program | |
KR102057107B1 (en) | Receiving device, receiving method, program, and information processing system | |
US8781303B2 (en) | Program accumulation apparatus, program accumulation reservation method, and program | |
CN104079983A (en) | System and method for HLS program recording and service | |
US20190007717A1 (en) | Method of controlling a synchronization server, and equipment for performing the method | |
JP4603367B2 (en) | Device for the execution of services received via a communication network | |
EP3648465B1 (en) | A method for generating a unique event identifier for an epg event | |
WO2006109359A1 (en) | Broadcast content update method and update program | |
US20140282781A1 (en) | Methods for processing and for end user management of interactive content and devices thereof | |
JP2011216932A (en) | Receiver and server |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: SAMSUNG ELECTRONICS CO., LTD., KOREA, REPUBLIC OF Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:JUNG, TAE-UNG;KIM, YONG-SUNG;REEL/FRAME:018261/0320 Effective date: 20060824 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Free format text: PAYER NUMBER DE-ASSIGNED (ORIGINAL EVENT CODE: RMPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20211124 |