The present invention relates broadly to the remote control of signal recording equipment. Specifically, the present invention relates to the control of remotely located recording equipment via a computer network.
Most consumer video/audio recording equipment today such as the video cassette recorder (VCR) is equipped with scheduling features. Scheduling features allow users to schedule recording of television programs based on user-specified time and channels. Most equipment can be controlled by remote control. However, for average users the process of scheduling television program recordings can be cumbersome. The user must be present at the location of recording equipment where a remote control unit is situated within an effective operating distance of the recording device. In the case where the remote control unit transmits commands in the form of infrared signals, the remote control unit must also establish line of sight to the recording equipment. Before operating a timer mechanism in conjunction with the recording equipment, the internal clock of video/audio recording equipment must be set to conform to local time. A user reviews schedule information of television programs to be recorded, such as program date, time and channel. A user typically selects a desired program to be recorded and enters schedule information using the remote control unit into the recording equipment. This step may consist of several key entries on the remote control units, since for every intended consecutive scheduled recording, the user specifies the time to begin recording as well as the time to terminate recording.
U.S. Pat. Nos. 5,692,214 and 5,988,078 to Levine teach implementations of an electronic schedule stored in memory to allow cursor based programming on a conventional video recorder through use of an associated personal computer. The computer communicates with the video recorder via infrared signals of the type used for remote control of the video recorder. Programming schedule information may be provided to the personal computer from a remote database by telephonic communication, broadcast, or use of disposable memories. A remote transmitter connected to the personal computer is used at the time of the recording to send signals to the video recorder to initiate recording of a preselected program, allowing unattended programming memory of the video recorder to initiate recording of a specific channel at a proper time. The method taught by Levine includes the steps of providing at the viewing location a computerized unit having an operator input and a modem; establishing a connection to a wide area network through the modem; transmitting information to a service provider regarding the geographical location of the particular viewing location; and receiving from the service provider information specific to the type of programming available to the particular viewing location. However, neither of the Levine patents address the problem of trying to operate a video recorder from a remote location.
The present invention addresses the problems identified above and provides an apparatus, method and service model which simplify conventional methods for schedule recordings of television programs and enable users to control recording equipment from any location via the Internet. Entities connected to computer networks such as the Internet and web-browser software can schedule recordings of television programs and/or operate the recording equipment. In an example scenario, a user who maintains recording equipment at home may utilize the present invention from his or her workplace or vacation place, accesses a service provider website using her/his user name and password, views the a schedule of television programs provided by a broadcaster or other distributor of programming and selects the television programs to be recorded. The application service provider in turn transmits the selected television program information to a computer connected to a later described remote control unit to execute and operate the recording of selected programs. In this manner, the present invention enables anyone with internet access to remotely operate recording equipment to record television programs.
Another attendant advantage of the present invention is an inexpensive solution to provide global connectivity of the Internet to existing recording equipment. The present invention can be utilized to operate recording equipment such as video cassette recorders, that typically have infrared sensors to receive control commands. Other recording equipment such as DVD recorders, hard drive based video recorders, etc. can also be controlled using the present invention.
In another aspect of the present invention, a method of providing a program recording to a user includes: accessing an application service provider that includes a program database via a first connection over a network with a user processor; selecting, with the user processor, a program recording to be received at the location of the user processor; providing the program recording selected with the user processor, at the location of the application service provider or a third location different from the location of the application service provider and the location of the user processor; and delivering the selected program recording to the location of the user processor.
In at least one embodiment, the delivering comprises transmitting the selected program recording over a network interconnecting the user processor with at least one of the application service provider and a processor at the third location.
In at least one embodiment, the delivering comprises delivering the selected program recorded on an optical or magnetic storage medium.
In at least one embodiment, providing the program recording comprises recording the program recording to be received on a recording device.
In at least one embodiment, the recording device is provided at the third location.
In at least one embodiment, the method includes providing additional locations different from the user processor location, location of the application service provider and the third location, wherein each of the additional locations are configured for selection to providing the selected program recording.
In at least one embodiment, the selected program is an audio program.
In at least one embodiment, the selected program comprises a video program.
In at least one embodiment, the video program includes audio programming
In another aspect of the present invention, a method of providing a program recording to a user is provided, including: accessing an application service provider that includes a program database via a first connection over a network with a user processor; selecting, with the user processor, a program recording to be received at the location of the user processor; providing the program recording selected with the user processor, at a third location selected from a plurality of locations different from the location of the application service provider and the location of the user processor; and delivering the selected program recording to the location of the user processor.
In at least one embodiment, the delivering comprises transmitting the selected program recording over a network interconnecting the user processor with a processor at the third location.
In at least one embodiment, the delivering comprises delivering the selected program recorded on an optical or magnetic storage medium from the third location to the location of the user processor.
In another aspect of the present invention, a method of remotely programming a remotely located recording device to receive program content from a program provider includes: accessing an application service provider separate from the program provider, that includes a program database via a first connection over a network with a user processor; selecting scheduling information provided by the program database of the application service provider via the first connection, wherein the scheduling information is associated with at least one program selected by a user; establishing or verifying a second connection over the network between the application service provider and a control processor; transmitting the scheduling information associated with the at least one program to the control processor via the second connection; and generating control signals based upon the scheduling information associated with the at least one program to control the recording device to receive the at least one program associated with the scheduling information.
In at least one embodiment, program content of the at least one program is received from the program provider and the application service provider transmits the scheduling information separately from the program provider.
In at least one embodiment, the recording device comprises a video recorder.
In at least one embodiment, the recording device comprises an audio recorder.
In at least one embodiment, the recording equipment comprises a television.
The forgoing aspects and many of the attendant advantages of the present invention will become more readily apparent in the following detailed description and accompanying drawings, wherein:
Although a desktop type of computer is illustrated, it is to be understood that other forms of computers, such as workstations, laptops, palm tops, dumb terminals, or any computer capable of communicating with other computers may be used in connection with embodiments of the present invention.
Computers 10, 60 may communicate over the computer network 50 via modem and telephone line. An operating system and browser program may also be included in computers 10, 60 so that a user may access the laboratory. However, other media may also be used, such as a direct connection or high speed data line. The computer network 50, as described above, may be a large and complex system, incorporating a vast number of nodes and components.
Computer 60 is located at a laboratory where physical processes are to be conducted. For illustrative purposes, the operation of a laser and optical equipment is described herein, but it is to be understood that other types of physical processes may be used in connection with the present invention. An interface 62 is connected to the processor in computer 60 that allows a user to control laser 64. The beam from laser 64 may be directed through various optical equipment 66, which may be adjusted on table 68 by interface 62. In an embodiment of the present invention, interface 62 may use a PCI-GPIB board to control and monitor laser 64. To acquire images of the laser beam that have been processed by optical equipment 66, a CCD detector that transmits digitized images to a IMAQ PCI-1424 board may be used. The optical equipment 66 may be mechanically adjusted and aligned by motorized stages on which the equipment is mounted. To display live pictures of the processes and equipment, an IMAQ PCI-1408 board may be used to digitize the analog video signal from camera 70. Motion of camera 70 may be controlled by a motion control system available through a software application such as LabView, which may be stored and executed on computer 60. Camera 70 is provided with frame grabber 72 to provide video feedback of the physical process, and are controlled by the video server 72, which may be executed on the processor of computer 60. System software on computer 60 may also include IMAQ Vision for G that provides image processing libraries such as a Fast Fourier Transform (FFT) routine to speed up development of live data analysis software.
Directing attention to
Data from the physical processes 110 are collected by the lab server 112 for purposes of storing into the database via the database server 120 and/or distributing to the clients 118 via the connection server 114. Prior to sending data, the lab server 112 can also perform analysis and transformation of the data such as statistics and FFT computation. The lab server 112 also receives data from the clients 118 such as control commands through the connection server 114. After analyzing these commands, the lab server 112 then passes the commands to the electronic devices or equipment (i.e. laser, motors, detectors, etc.). As shown in
The connection server 114 serves as the distributor of data that accepts, verifies and routes information from data sources to appropriate destinations. The connection server 114 supports full duplex point-to-point and point-to-multipoints data transmissions between the clients 118, lab server 112, and database server 120. Several transmission modes will be discussed below. Additionally, the connection server 114 also monitors the status of network connections throughout the entire process.
The clients' processes 118 provide user interfaces (UI) for users' input and output functions. The clients' processes 118 are implemented as software programs that can be run on clients' computing devices such as desktop computers. The client also establishes two-way communications with the connection server 114. Data from the connection server 114 are decoded and displayed according to associated formats such as the video, graph, LED displays, etc.
In a preferred embodiment, communications between the processes above are carried out using a common language, such as Data Network Protocol (DNP). Besides transporting various data types, DNP also carries network and communications related messages between different processes. DNP packet format is also discussed in the later sections.
The lab server 112 may reside at the location of the physical process 110 to have direct local control of the physical process. The lab server 112 is the process that broadcasts data from the physical process 110 and well as control the physical process 110 based on requests from clients 118. The lab server 112 can be implemented as a multi-threaded software that implements communication functions across computer networks such as the internet 116. To provide universal and reliable communications, all data can be transported using standard connection based network protocols such as Transmission Control Protocol/Internet Protocol (TCP/IP). Each connection (in this case between the lab server process 112, connection server process 114, and clients 118) is commonly called socket that consists of a network or IP address and a port number. However, the data itself and other communication messages are encoded in a format called Data Network Protocol (DNP). In the OSI network model, DNP can be considered as an application layer protocol like HTTP and FTP. The unique design of DNP provides a common language between different processes that enables collaborative environments between multiple users across the internet.
DNP is designed to carry various types of digital data such as float, integer, Boolean, video and arrays of data. Data is encoded using DNP into one information entity called a packet that has two main sections: the overhead section 205 and instruction section 225. Directing attention to
Packet size 210: the length of the entire packet normally in byte words (8 bits unit).
Destination ID 212: may contain client ID, lab server ID, connection server ID, all-clients-group ID, all-clients-and-lab-server-group ID, or connection server group ID where the packet is sent.
Source ID 214: may contain client ID, lab server ID or connection server ID where the packet is originated.
Instruction number 216: contains the number of instructions following the overhead section 205. For example in
The instruction section 225 may contain a number of instructions. Each instruction can be a specific command or request that contains the following fields.
Component ID 230: identification number of specific device/equipment for user interface component.
Command ID 232: identification number of specific command/request to be performed.
Command Value 234: parameter values used to perform the commands or requests. Based on the associated command/request, the data type of common values can vary (i.e. float data, integer data, video data, array of data). Consequently this field has variable size. Both sender and receiver of the request may have a look-up list of data types associated with the component ID's and command ID's. Hence, the data type information need not be carried in the packet itself. The instruction section may be extended to include component ID's, command ID's and command values 252-262.
Two main functions may be performed by the lab server: broadcast data from the physical processes 110; and perform clients' requests and general associated responses. To keep clients 118 up to date with the current states of the physical processes 110, the lab server 112 can broadcast information that is directly collected from the physical processes 110. Data from the physical processes 110 that are encoded in the DNP packet are transmitted to connections server 114 for distribution. The connections server can then look at the overhead section of the transmitted DNP packet and forward the packet to appropriate destinations. Details on the routing algorithm in the connections server are discussed below.
Sensors, detectors and other measurement instruments detect and/or measure various physical phenomena (i.e. electric fields, electromagnetic radiation, temperature, pressure, etc.), and send this information to the lab server 112. The lab server 112 that has established network connection to the connections server 114 can then put the received information or its computed analysis into the instruction section of the DNP packet. This process can be repeated if more than one instruction is needed to be sent. Once all the instructions have been written in the instruction section of the DNP packet, the corresponding overhead sections can also be constructed. Once the DNP packet is complete, it can then be sent to the connections server 114.
Directing attention to
Another function of the lab server 112 is to process clients' requests and generate associated responses. The lab server 112 can receive a DNP packet from the connections server 114 that contains the clients' requests for instructions. It is the responsibility of the lab server 112 to interpret these instructions, execute the commands and generate responses. This process is described in
Execution of a client's requests may involve calling particular software drivers that send the commands to instruments via the associated computer interface such as GPIB, RS-232, USB, ethernet, etc. The request may also contain instructions for information management such as recording the client's request, storing collected values from instruments, and querying previously collected information. In the case of information management, the lab server 112 can interact directly with local or remote database servers through standard database drivers such as ODBC or JDCB.
Unlike the broadcasting functions that may continuously send DNP packets to clients, this function of the lab server 112 only generates responses when client requests are received. When the lab server 112 is implemented in a software program, this function may be run in a separate thread for parallel processing with other functions.
The connections server 114 can be run in the same computer where the lab server 112 resides. For additional reliability, in the preferred embodiment the connections server 114 may be executed in a separate computer. The connections server 114 may be implemented using object oriented, network-enable and multi-threaded software development environments such as JAVA or C++. Two of the main functions performed by the connections server 114 include: monitoring and maintaining reliable network connections with all active clients and lab servers; and routing DNP packets to appropriate destinations.
The connections server 114 maintains network connections with all the processes, namely: lab server 112, database server 120, and clients 118. A connection handler, which may be a class or object in object-oriented programming terminology, can perform readings from and writing to each of the connections. Each connection handler should be run in a separate thread for parallel processing. Once the connections server 114 accepts or establishes a connection, it can then pass the connection information (i.e. the socket information that contains remote post address and remote port number) to the connection handler for further processing. The connections server 114 maintains an array or table of connection handlers, namely the connection table, to perform and monitor network related processes. A connection monitor is another important process included in the connections server 114 that runs on a periodic basis. The connection monitor may be implemented as a subclass of the connections server 114 and may be executed in a separate thread. A function of the connection monitor is to monitor and control the network communications of the processes (i.e. clients 118 and lab server 112) connected to the connections server.
The connections server serves as the distributor of data that accepts, verifies and routs DNP packets to appropriate destinations. The connections server supports full duplex point-to-point and point-to-multipoints data transmissions based on the destination ID field of the DNP packet. As a result, both clients 118 and lab server 112 processes may synchronously receive events that are generated by any processes.
As discussed above, the connection handler is part of the connections server and may perform reading from and writing to each connection. The connections server 114 listens to any connection request, and passes the network information to the connection handler once a valid connection is established.
Client processes provide a graphical user interface for the end users of the physical process 110. The clients may be implemented in any object-oriented and network-enabled software development environment such as C++ or JAVA. The client should contain graphical components that may be used for getting user inputs and/or display information. Some of the components may include dials, graphs, switches, LED displays, buttons, etc.
The client process 118 may be executed from any computer that is connected to a TCP/IP network such as the internet. When the client process is run, it will first attempt to establish network connections to the connections server 114. User requests/commands that are received from the UI components are encoded into DNP packets to be sent to the connections server 114. The client 118 may also process DNP packets from other remote clients and lab servers 112 that are received via the connections server 114. This operation may also be executed in a separate thread for parallel processing.
The database server 120 manages a database containing information that is essential to the operation of other processes. The remote operation of the database server 120 can be facilitated using database application programming interface standards such as ODDC or JDDC. The database server 120 manages the following list of information: user information, user physical process data, scheduling information, and event data.
The database server 120 manages user profiles. A user profile contains user accessed information such as log-in name and password that enables the connections server 114 to verify connection requests from the clients 118. In addition, the user profile also includes the client's progress information by tracking the status of accomplished actions/requests. Data from the physical processes 118 (i.e. sensor readings, states of equipment, etc.) may also be recorded on behalf of a client's request. This data be time stamped and may be made available to the user via an interactive “laboratory notebook” user interface. Using a common gateway interface (CGI) or JAVA servlet program that may interact with the database server 120, clients may search and retrieve previously recorded physical process data. The search may be based on chronological order, keyword, or other characteristics of the recorded data. Scheduling information ensures that only the appropriate clients are given access to the physical processes 110 in a certain time period. Every event received by the lab server may also be automatically recorded. This data may be used to analyze clients' behavior and usage patterns in controlling the physical process 110. The interactive laboratory notebook may also contain lab parameters, “to do” lists, and personal notes.
The interactive laboratory notebook is part of a user interface that may be constructed using Interface Builder or similar software application, and may be accessed by users during the course of an experiment. The interactive laboratory notebook may be implemented to include a database stored on a hard disk or other nonvolatile memory of computer 60, as well as a user interface to access the database. Where the present invention is utilized for distance learning, the interactive laboratory notebook provides a central repository for information and is an essential tool for instructors to evaluate the progress and performance of students using the online laboratory.
The user interface may include animated switches, dials, buttons, and LED displays rather than traditional browser forms. Online graphing of the real time data along with other customized user interface components allows users to experience a hands-on look and feel. The user interface may closely resemble the front panels of the actual instruments in functionality, layout, and appearance. The live video stream may also be included in the user interface.
Real Time Video Observation
Observing physical processes in real time via the internet is a key feature of the present invention. Returning to
To perform temporal compression, the server 74 subtracts the ideal DCT data from the DCT data that the client currently holds. This difference in DCT data is the information that the client must receive in order to allow its video to be updated to the desired image. This compression uses a single new frame to calculate data to be sent. This sacrifices compression efficiency (i.e. that obtained using the MPEG4 standard) in order to minimize latency. An approximation to this difference is calculated which meets the requirements of the specified fixed packet size (specified in bits). By basing compression on a specified packet size, compressed video matches transmission limitations of the client 110. The data rate (PACKET_SIZE* PACKETS_PER_SECOND) that is used for a particular client is dynamically determined and updated as video is sent. This allows the quality of video that is sent to a client to vary according to the abilities of each client's internet connection. This also allows the data rate to vary in response to changes in a client's allowable data rate. By having the client intermittently inform the server of the times that it received transmitted packets, the latency and allowable data rate of the client may be calculated.
The instructions described above as well as the user interface and interactive laboratory notebook may be implemented in software and stored in the computer 60 and executed in accordance with the preferred embodiment of the present invention.
While the description above explains the operation of a laser and optical equipment, it is to be understood that a wide variety of physical processes may be performed using the present invention, and other forms of data may be recorded such as time, temperature, voltage, current, magnetic field, electromagnetic radiation, and the like. Additional applications of the present invention may extend to entertainment, for example the remote control of toys in an interactive setting, where multiple users may access computer 60 via the computer network 50 and play games involving multiple users. The real time video taught by the present invention is an integral part of such an application.
In other applications of the present invention, computer 60 and camera 70 may be utilized as a sales or development tool to demonstrate equipment or processes to prospective clients, customers, or developers by providing a demonstration of the equipment or processes in real time and eliminating the expenditure of resources required to travel to a location where the equipment or processes are located.
In embodiments of the present invention where video recording is to be performed in accordance with the present invention, two types of equipment are needed to record audio and video signals transmitted from a programming source: a tuning device capable of tuning/separating television channels among designated frequency bands, and a recording device capable of storing analog video/audio signals on recording media such as magnetic tape, magnetic disks or optical disks. Many recording devices such as VCRs are equipped with built-in television tuners. In this case, the process of recording television programs can be accomplished by manipulating a single piece of equipment. For recording devices that do not have built-in television tuners, broadcast television signals must be processed by tuning a particular television channel and converting such channel into video and audio signals prior to recording. Referring to
TV receiver 1010, recording device 1012 and set-top box 1014 are often equipped with infrared sensors that allow remote control from infrared transmitting devices operated within effective distance. Most remote control units emit infrared signal with a certain modulation method and carrier frequency to transmit digital commands for operating such devices. The methods used to demodulate such infrared signals vary by manufacturer. Many equipment manufacturers use conventional digital modulation methods such as on-off shift keying, pulse length modulation, etc. with carrier frequencies ranging from 20-60 kHz. By using a diode detector, such signals can be learned and stored in a conventional memory. Video/audio recording equipment is controlled by transmitting a sequence of stored commands using infrared emitting diode 1016 in the remote control unit 1018.
In an alternative embodiment of the remote control unit 1018, the clock 1030 and/or memory 1026 can be excluded. In this case, the transmission of infrared signal from remote control unit 1018 is controlled using microprocessor, memory and clock of computer 1020. In this alternative embodiment the remote control unit 1018 and computer 1020 stay connected during the process of recording television programs.
In another alternative embodiment of the present invention, means for controlling the recording device 1012 and accessing an online-based application service provider 1032 can be built internal to the recording device 1012. In this case, recording device 1012 incorporates microprocessor 1024, memory 1026, clock 1030, modem 1034 and client software 1038 can be controlled through electronics means without any external device such as the remote control unit and computer.
Computer 1020 can include an application program such as Client Software 1038 executed by computer 1020 to receive user-selected TV scheduling information from the Application Service Provider 1032 and transmit such information to remote control unit 1018. As shown in
In the case where there is no line of sight between the remote control unit and the recording equipment, such as the case where computer 1020 and remote control device 1018 are located in different rooms, communication between remote control unit 1018 and computer 1020 can be performed using radio frequency (RF) transmitter 1021 and receiver 1023, as shown in
Commands in the form of digital information can be encoded and modulated using RF frequency, which in turn is received an decoded by an RF receiver to be passed to remote control unit 1018 for controlling the audio/video recording equipment. A physical connection between the controlling computer (Computer 2) to either remote control unit 1018 (
Internet-Based Service Model
The goals of the service model of the present system are to simplify the process of recording TV programs using existing audio/video recording equipment through an Internet-based user interface. Using standard web browser programs such as Netscape Navigator® or Microsoft Internet Explorer®, users can browse, search and select television programs to be recorded. In turn, the system will automatically obtain information about the selected television programs (such as start times, end times and channel numbers), and send such information to remote control unit 1018 that operates the audio/video recording equipment.
Another goal of the service model of the present invention is to provide global access to audio/video equipment. Users can operate audio/video equipment from virtually anywhere through the Internet.
Yet another goal of the service model is to guide users in selecting TV programs by providing suggestions based on analysis of user preferences and viewing history.
In the preferred embodiment of the invention as shown in
Database 1044 is connected to Information Server 1050, facilitated by workstation or Local Area Network at the Application Service Provider 1032 site. Database 1044 may serve as a data center to manage information regarding user accounts, television schedule information, and operation of the system. New users are required to register with Application Service Provider 1032. Using HTML forms, a user from Computer 1036 can submit registration data to be processed by Information Server 1050. Information provided by the user for proper operation of recording equipment includes the authentication information, equipment and connectivity identification, and programming source. Other information about the user such as email, telephone and/or fax may also be stored in the user account, hence the user may receive information such as selected television programs, reminders and other information regarding television program recordings via email, telephone and/or fax.
Upon receiving the above registration information from a user, Information Server 1050 stores the registration information in database 1044 on behalf of the user in her/his individual user account. Once the registration process is complete, the user then selects television programs to be recorded. Information Server 1050 serves HTML pages containing textual and graphical information regarding TV programming schedules stored in database 1044. To serve the HTML-pages, Information Server 1050 executes computer programs in the forms of Java Servlet or Common Gateway Interface (CGI) to search database 1044 and display television programming schedules. A user can view and select television programming schedules that are displayed based on her/his preferences such as: viewing dates, topics, actors, shown genres, review, etc. Information Server 1050 formats the retrieved television information into HTML pages that allow users to select TV programs to be recorded. The television schedule information may be displayed in spreadsheet forms having the axes time versus channels. For devices that only have a single television tuner, a spreadsheet user interface may be used in the following applications.
Whenever a user selects a valid or non-conflicting television program, the interface disables the selection options for all conflicting television programs that are broadcast during the same time period. This method forces the user to deselect the current selection in order to select another program in the same scheduled time period. Whenever a user select a television program, the interface deselects all selected television programs that have conflicting viewing schedules.
Once the user submits his/her television program selections to Information Sever 1050, the information is stored in her/his account in database 1044. Also stored in his/her account is information regarding the status of network connection between Client Software 1038 and Control Server 1042. Whenever a Client Software 1038 establishes or terminates network connection with Control Server 1042, the events are noted in the user account to track the status of the network connection. Upon receiving the user selections, Information Sever 1050 accesses the user-account to check whether a valid network connection has been established between Client Software 1038 and Control Server 1042. If a valid connection is found, Information Server 1050 notifies the appropriate Control Server 1042 via Local Area Network that new user selections have been received and stored in database 1044 on behalf of the user. Upon receiving the notification from Information Server 1050, Control Server 1042 may also access database 1044 via Local Area Network to retrieve user-selected television information that has not been transmitted to Client Software 1038. Control Server 1042 then formats the retrieved information and transmits it to Client Software 1038. Upon receiving the user selections, Client Software 1038 sends them to remote control unit 1018 and updates the television recording schedule information in memory 1026. Once the user selections are stored in memory 1026 of remote control unit 1018, microprocessor 1024 can then compare the selected television programs with clock 1030 to start and stop the recording process.
In the preferred embodiment, Control Server 1042 is an application program executed in a conventional computer that is capable of establishing network communications with other computers using standard network protocol such as the Internet Protocol (IP). Client Software 1038 executed in Computer 1020 as shown in
Initiation may be based on notification from the Information Server 1050. When Information Server 1050 obtains user-specified television scheduling information to be recorded, it notifies the Control Server 1042. In turn, if network communication has been established between the Control Server 1042 and Client Software 1038, the Control Server 1042 retrieves the user selections and sends them to the Client Software 1038.
Alternatively, initiation may be based on notification from Client Software 1038. The Client Software 1038 notifies the Control Server 1042 to transmit user selections for recording. This notification would normally be sent when the Client Software 1038 initially establishes network connection with the Control Server 1042. The Control Server 1042 then retrieves user selections and sends them to Client Software 1038.
Information indicating user selections is stored in the database 1044. Such information can convey user preferences, useful in providing targeted advertising, rating of television programs, providing television program guides, suggestions, etc.
Directing attention to
While an apparatus, method, and service model for the remote control of recording devices via a computer network have been described in preferred embodiments, those of ordinary skill in the art will understand that many modifications maybe made thereto without changing the scope of the claims that follow. Accordingly, it is not intended that the scope of the invention in any way be limited by the above description, but instead be determined by reference to the claims that follow.
This application is a continuation of application Ser. No. 13/711,798, filed Dec. 12, 2012, which is a continuation of application Ser. No. 10/795,071, filed Mar. 5, 2004 , now U.S. Pat. No. 8,352,567, issued on Jan. 8, 2013, which is a division of application Ser. No. 09/608,685 09, filed Jun. 29, 2000, now U.S. Pat. No. 6,732,158, issued on May 4, 2004 , which is a continuation in part of application Ser. No. 09/454,178, filed Dec. 2, 1999, now U.S. Pat. No. 6,499,054, issued on Dec. 24, 2002 . application Ser. Nos. 09/608,605, 09/454,178, 10/795,071, and 13/711,798 and U.S. Pat. Nos. 8,352,567, 6,499,054, and 6,732,158 are incorporated hereby herein, in their entireties, by reference thereto, and to which applications we claim priority under 35 USC § 120.
Number | Name | Date | Kind |
---|---|---|---|
5499046 | Schiller | Mar 1996 | A |
5526037 | Cortjens et al. | Jun 1996 | A |
5537141 | Harper et al. | Jul 1996 | A |
5570415 | Stretton et al. | Oct 1996 | A |
5600834 | Howard | Feb 1997 | A |
5623601 | Vu | Apr 1997 | A |
5634052 | Morris | May 1997 | A |
5644714 | Kikinis | Jul 1997 | A |
5692214 | Levine | Nov 1997 | A |
5710970 | Walters et al. | Jan 1998 | A |
5745906 | Squibb | Apr 1998 | A |
5751883 | Ottesen et al. | May 1998 | A |
5793952 | Limsico | Aug 1998 | A |
5793964 | Rogers et al. | Aug 1998 | A |
5805442 | Crater et al. | Sep 1998 | A |
5835911 | Nakagawa et al. | Nov 1998 | A |
5841976 | Tai et al. | Nov 1998 | A |
5845282 | Alley et al. | Dec 1998 | A |
5850449 | McManis | Dec 1998 | A |
5867155 | Williams | Feb 1999 | A |
5878213 | Bittinger et al. | Mar 1999 | A |
5886707 | Berg | Mar 1999 | A |
5893119 | Squibb | Apr 1999 | A |
5907322 | Kelly et al. | May 1999 | A |
5930473 | Teng et al. | Jul 1999 | A |
5935212 | Kalajan et al. | Aug 1999 | A |
5946697 | Shen | Aug 1999 | A |
5956487 | Venkatraman et al. | Sep 1999 | A |
5960177 | Tanno | Sep 1999 | A |
5968131 | Mendez et al. | Oct 1999 | A |
5974446 | Sonnenreich et al. | Oct 1999 | A |
5982362 | Crater et al. | Nov 1999 | A |
5983350 | Minear et al. | Nov 1999 | A |
5988078 | Levine | Nov 1999 | A |
5990884 | Douma et al. | Nov 1999 | A |
6002768 | Albanese et al. | Dec 1999 | A |
6012086 | Lowell | Jan 2000 | A |
6014451 | Berry et al. | Jan 2000 | A |
6014706 | Cannon et al. | Jan 2000 | A |
6021118 | Houck et al. | Feb 2000 | A |
6025868 | Russo | Feb 2000 | A |
6052145 | Macrae | Apr 2000 | A |
6052750 | Lea | Apr 2000 | A |
6065062 | Periasamy et al. | May 2000 | A |
6078961 | Mourad et al. | Jun 2000 | A |
6081508 | West et al. | Jun 2000 | A |
6081693 | Wicks et al. | Jun 2000 | A |
6084638 | Hare | Jul 2000 | A |
6085192 | Mendez et al. | Jul 2000 | A |
6085227 | Edlund et al. | Jul 2000 | A |
6098106 | Philyaw et al. | Aug 2000 | A |
6101265 | Bacus et al. | Aug 2000 | A |
6104716 | Crichton et al. | Aug 2000 | A |
6105067 | Batra | Aug 2000 | A |
6133909 | Schein et al. | Oct 2000 | A |
6173112 | Gruse et al. | Jan 2001 | B1 |
6182094 | Humpleman et al. | Jan 2001 | B1 |
6182139 | Brendel | Jan 2001 | B1 |
6182226 | Reid et al. | Jan 2001 | B1 |
6184863 | Sibert et al. | Feb 2001 | B1 |
6198905 | Remschel | Mar 2001 | B1 |
6212327 | Berstis et al. | Apr 2001 | B1 |
6212558 | Antur et al. | Apr 2001 | B1 |
6219669 | Haff et al. | Apr 2001 | B1 |
6223289 | Wall et al. | Apr 2001 | B1 |
6230203 | Koperda et al. | May 2001 | B1 |
6233589 | Baicha et al. | May 2001 | B1 |
6255961 | Van Ryzin et al. | Jul 2001 | B1 |
6261103 | Stephens et al. | Jul 2001 | B1 |
6263371 | Geagan, III et al. | Jul 2001 | B1 |
6263507 | Ahmad | Jul 2001 | B1 |
6275942 | Bernhard et al. | Aug 2001 | B1 |
6288753 | DeNicola et al. | Sep 2001 | B1 |
6304895 | Schneider et al. | Oct 2001 | B1 |
6366930 | Parker et al. | Apr 2002 | B1 |
6377573 | Shaffer et al. | Apr 2002 | B1 |
6401239 | Miron | Jun 2002 | B1 |
6408435 | Sato et al. | Jun 2002 | B1 |
6427161 | LiVecchi | Jul 2002 | B1 |
6437803 | Panasyuk et al. | Aug 2002 | B1 |
6445872 | Sato et al. | Sep 2002 | B1 |
6463459 | Orr et al. | Oct 2002 | B1 |
6496205 | White et al. | Dec 2002 | B1 |
6499054 | Hesselink et al. | Dec 2002 | B1 |
6513068 | Jones et al. | Jan 2003 | B1 |
6553422 | Nelson | Apr 2003 | B1 |
6564380 | Murphy | May 2003 | B1 |
6571245 | Huang et al. | May 2003 | B2 |
6581092 | Motoyama et al. | Jun 2003 | B1 |
6588012 | Tanaka | Jul 2003 | B2 |
6588013 | Lumley et al. | Jul 2003 | B1 |
6611654 | Shteyn | Aug 2003 | B1 |
6615088 | Myer et al. | Sep 2003 | B1 |
6625623 | Midgley et al. | Sep 2003 | B1 |
6633235 | Hsu | Oct 2003 | B1 |
6640241 | Ozzie et al. | Oct 2003 | B1 |
6654746 | Wong et al. | Nov 2003 | B1 |
6668288 | Midwinter et al. | Dec 2003 | B1 |
6675386 | Hendricks | Jan 2004 | B1 |
6714968 | Prust | Mar 2004 | B1 |
6714982 | McDonough et al. | Mar 2004 | B1 |
6732158 | Hesselink et al. | May 2004 | B1 |
6732269 | Baskey et al. | May 2004 | B1 |
6754678 | Norris et al. | Jun 2004 | B2 |
6754707 | Richards et al. | Jun 2004 | B2 |
6785716 | Nobakht | Aug 2004 | B1 |
6799248 | Scherr | Sep 2004 | B2 |
6804718 | Pang et al. | Oct 2004 | B1 |
6892225 | Tu et al. | May 2005 | B1 |
6898636 | Adams et al. | May 2005 | B1 |
6901209 | Cooper et al. | May 2005 | B1 |
6938042 | Aboulhosn et al. | Aug 2005 | B2 |
6973482 | Mohammed et al. | Dec 2005 | B2 |
6981050 | Tobias et al. | Dec 2005 | B1 |
7020778 | Miettinen et al. | Mar 2006 | B1 |
7043644 | DeBruine | May 2006 | B2 |
7055166 | Logan | May 2006 | B1 |
7058696 | Phillips et al. | Jun 2006 | B1 |
7069310 | Bartholomew | Jun 2006 | B1 |
7107605 | Janik | Sep 2006 | B2 |
7114080 | Rahman et al. | Sep 2006 | B2 |
7117440 | Gordon | Oct 2006 | B2 |
7120692 | Hesselink et al. | Oct 2006 | B2 |
7124372 | Brin | Oct 2006 | B2 |
7127745 | Herse et al. | Oct 2006 | B1 |
7143430 | Fingerman | Nov 2006 | B1 |
7237114 | Rosenberg | Jun 2007 | B1 |
7240108 | Smith, Jr. et al. | Jul 2007 | B2 |
7254786 | Henriquez | Aug 2007 | B2 |
7257158 | Figueredo | Aug 2007 | B1 |
7383564 | White | Jun 2008 | B2 |
7404207 | Perry | Jul 2008 | B2 |
7424543 | Rice, III | Sep 2008 | B2 |
7437429 | Pardikar et al. | Oct 2008 | B2 |
7454443 | Ram et al. | Nov 2008 | B2 |
7467187 | Hesselink et al. | Dec 2008 | B2 |
7546353 | Hesselink et al. | Jun 2009 | B2 |
7587467 | Hesselink et al. | Sep 2009 | B2 |
7600036 | Hesselink et al. | Oct 2009 | B2 |
7634787 | Gebhardt | Dec 2009 | B1 |
7788404 | Hesselink et al. | Aug 2010 | B2 |
7895334 | Tu et al. | Feb 2011 | B1 |
7917628 | Hesselink et al. | Mar 2011 | B2 |
7934251 | Hesselink et al. | Apr 2011 | B2 |
7949564 | Hughes et al. | May 2011 | B1 |
8004791 | Szeremeta et al. | Aug 2011 | B2 |
8255661 | Karr et al. | Aug 2012 | B2 |
8285965 | Karr et al. | Oct 2012 | B2 |
8341117 | Ram et al. | Dec 2012 | B2 |
8341275 | Hesselink et al. | Dec 2012 | B1 |
8352567 | Hesselink et al. | Jan 2013 | B2 |
8386465 | Ansari et al. | Feb 2013 | B2 |
8526798 | Hesselink | Sep 2013 | B2 |
8631284 | Stevens | Jan 2014 | B2 |
8646054 | Karr et al. | Feb 2014 | B1 |
8661507 | Hesselink et al. | Feb 2014 | B1 |
8688797 | Hesselink et al. | Apr 2014 | B2 |
8713265 | Rutledge | Apr 2014 | B1 |
8719090 | Lewis | May 2014 | B2 |
8762682 | Stevens | Jun 2014 | B1 |
8780004 | Chin | Jul 2014 | B1 |
8793374 | Hesselink et al. | Jul 2014 | B2 |
8819443 | Lin | Aug 2014 | B2 |
9021538 | Ellis | Apr 2015 | B2 |
20010009014 | Savage et al. | Jul 2001 | A1 |
20010013127 | Tomita et al. | Aug 2001 | A1 |
20010018701 | Livecchi | Aug 2001 | A1 |
20010023451 | Hericourt | Sep 2001 | A1 |
20010046366 | Susskind | Nov 2001 | A1 |
20010053274 | Roelofs et al. | Dec 2001 | A1 |
20020023143 | Stephenson et al. | Feb 2002 | A1 |
20020042830 | Bose | Apr 2002 | A1 |
20020057893 | Wood et al. | May 2002 | A1 |
20020178441 | Hashimoto | Nov 2002 | A1 |
20030018972 | Arora | Jan 2003 | A1 |
20030084104 | Salem et al. | May 2003 | A1 |
20030191911 | Kleinschnitz et al. | Oct 2003 | A1 |
20040075619 | Hansen | Apr 2004 | A1 |
20040172449 | Hesselink et al. | Sep 2004 | A1 |
20050028208 | Ellis et al. | Feb 2005 | A1 |
20050144195 | Hesselink et al. | Jun 2005 | A1 |
20050144200 | Hesselink et al. | Jun 2005 | A1 |
20050188002 | Yang | Aug 2005 | A1 |
20070083908 | McCarthy et al. | Apr 2007 | A1 |
20080141307 | Whitehead | Jun 2008 | A1 |
20090131152 | Busse | May 2009 | A1 |
20110317986 | Hirata | Dec 2011 | A1 |
20120036041 | Hesselink | Feb 2012 | A1 |
20130212401 | Lin | Aug 2013 | A1 |
20130266137 | Blankenbeckler et al. | Oct 2013 | A1 |
20130268749 | Blankenbeckler et al. | Oct 2013 | A1 |
20130268759 | Blankenbeckler et al. | Oct 2013 | A1 |
20130268771 | Blankenbeckler et al. | Oct 2013 | A1 |
20140095439 | Ram | Apr 2014 | A1 |
20140169921 | Carey | Jun 2014 | A1 |
20140173215 | Lin et al. | Jun 2014 | A1 |
20150156553 | Blake | Jun 2015 | A1 |
Number | Date | Country |
---|---|---|
2136150 | May 1996 | CA |
2462448 | Apr 2010 | CA |
02823077.9 | Jun 2008 | CN |
19740079 | Mar 1999 | DE |
0805594 | Nov 1997 | EP |
0917052 | May 1999 | EP |
0986225 | Mar 2000 | EP |
214359 | Feb 2008 | IN |
08-314835 | Nov 1996 | JP |
H10-155131 | Jun 1998 | JP |
4667747 | Jan 2011 | JP |
10-0994666 | Nov 2010 | KR |
WO 1997013368 | Apr 1997 | WO |
WO 1997018636 | May 1997 | WO |
WO 1998017064 | Apr 1998 | WO |
WO 1999021118 | Apr 1999 | WO |
WO 1999050994 | Oct 1999 | WO |
WO 2000005903 | Feb 2000 | WO |
WO 2000011832 | Mar 2000 | WO |
WO 0135599 | May 2001 | WO |
WO 2001031875 | May 2001 | WO |
WO 2001035599 | May 2001 | WO |
WO 2001040961 | Jun 2001 | WO |
WO 2001075836 | Oct 2001 | WO |
WO 2001078349 | Oct 2001 | WO |
WO 2002037380 | May 2002 | WO |
WO 03044676 | May 2003 | WO |
WO 2003044676 | May 2003 | WO |
WO 2004046852 | Jun 2004 | WO |
Entry |
---|
“The Next Step in Server Load Balancing—White Paper”, XP-002974311, Alleen Web Systems, Inc., Nov. 1999, 16 pages. |
Arpaia et al., A measurement laboratory on Geographic Network for Remote Test Experiments. May 18-21, 1998, pp. 206-209A. |
Bird, VPN Information on the World Wide Web. Http://vpn.shmoo.com/vpn/vpn-general.html, pp. 1-2, Apr. 28, 2003. |
Canadian Office Action in related Western Digital case 2,725,655 dated Mar. 1, 2011. |
European Office Action dated Feb. 11, 2015 related to European Patent Application No. 03781759.0, 9 pages. |
European Office Action dated Mar. 25, 2010 related to European Patent Application No. 03781759.0, 6 pages. |
Goldberg et al., Beyond the Web: manipulating the real world. 1995, pp. 209-219. |
Hesselink, et al., U.S. Appl. No. 10/988,280, filed Nov. 13, 2004, 99 pages. |
International Search Report and Written Opinion dated Jan. 17, 2008, from PCT/US04/37608, filed Nov. 13, 2004, 14 pages. |
Jim Henry, Controls Laboratory Teaching via the World Wide Web, ASEE, Jun. 1996, 4 pages. |
Jim Henry, Laboratory Teaching via the World Wide Web, ASEE, Southeastern Section Paper, Apr. 1998, 11 pages. |
LabVIEW from National Instruments, http://www.ni.com/labview/; Jan. 18, 2000, 1 page. |
National Instruments Manual entitled LabVIEW—Instrumentation and Analysis Software; pp. 61, 63, 75 and 76; Jan. 2000. |
Nishimura et al., Real-Time Camera Control for Videoconferencing Over the Internet, 5th International Conference on Real-time Computing Systems and Applications, pp. 121-124, Oct. 1998. |
Office Action dated Feb. 23, 2010, issued in connection with KR application 10-2005-7008962. |
Office Action dated Feb. 8, 2010, issued in connection with JP application 2001-541955. |
Office Action dated Sep. 3, 2010, issued in connection with E02782342.6. |
Ramesh Jain, The convergence of PCs and TV, IEEE Multimedia, vol. 6, Issue 4, Oct. 1999, p. 1. |
Richardson et al., Virtual Network Computing. Http://computer.org/internet, pp. 33-38, Jan. & Feb. 1998. |
Ronald M. Toi et al., TV Anytime: Store It on My TV, Conference on Consumer Electronic 2000 Digest of Technical Papers, ICCE 2000, IEEE, pp. 30-31. |
Scharf, R. et al., Using Mosaic for Remote Test System Control Supports Distributed Engineering, NCSA Mosaic and the Web Conference, Oct. 1994, 9 pages. |
Shen et al., Conducting Laboratory Experiments over the Internet. vol. 42, Aug. 1999, pp. 180-185. |
www.GoToMyPC.com, 2 pages. |
www.GoToMyPC.com, 2 pages, published by Expertcity, Inc., Santa Barbara, CA 93111, 2002. |
www.GoToMyPC.com, XP-002611880, Expertcity, Inc., date of publication prior to Dec. 12, 2012, 2 pages. |
Zhe Wang et al., Persistent Connection Behavior of popular Browsers, retrieved from http://pages.cs.wisc.edu/-cao/ papers/persistent-connection.html, Dec. 1998, 4 pages. |
Office Action dated Jan. 12, 2017 in European Patent Application No. 03 781 759.0. |
Number | Date | Country | |
---|---|---|---|
20180034895 A1 | Feb 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09608685 | Jun 2000 | US |
Child | 10795071 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13711798 | Dec 2012 | US |
Child | 15782723 | US | |
Parent | 10795071 | Mar 2004 | US |
Child | 13711798 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09454178 | Dec 1999 | US |
Child | 09608685 | US |