Not applicable.
Embodiments of the present invention relates generally to the field of content delivery. More specifically, embodiments of the present invention provide a mediation service to select a device well suited to present the content, such that a user's experience of the content is maximized.
Currently, when a new computer having a unique configuration is introduced to a network of computers, often the new computer can not communicate with other computers on the network without a lengthy and tedious configuration process, where a developer creates specialized scripts that enable the new computer to communicate with the other computers on the network. Additionally, after the new computer is configured to communicate with other computers, a device configuration in the new computer is usually static. For example, when the new computer is configured, using wires, to send an audio signal to a pair of speakers connected to a speaker output jack of the new computer, the connection will remain constant until the device configuration is changed by a user. If an external speaker that is not connected to the new computer is better suited to process the audio signal, the new computer will not send the audio signal to the external speaker because the device configuration does not enable the new computer to communicate with the external speaker. Accordingly, a user has to manually change the device configuration to utilize the external speaker.
Therefore, a need arises to provide a service that allows computers to dynamically communicate with devices without requiring a developer to create specialized scripts or to manually configure the devices. Moreover, it would be advantageous for the service to allow computers having different formats to freely exchange content to maximize a user's experience in a network environment by efficiently utilizing devices that enhance the user's experience.
These and other problems, in the art, are solved by a mediator that provides a mediation service to maximize a user's experience in a network environment by determining a best-fit match between content and a plurality of devices in the network environment.
The mediator includes at least a ranking component, a listening component, and a control component. The ranking component assigns values, indicating importance, to the content and the plurality of devices. The listening component collects information about device offerings, from the plurality of devices; collects information about content preferences, from either content metadata or a device storing the content; and collects information about changes in the network environment. The control component specifies the level of user involvement, which is default to no user involvement. The mediator utilizes the information provided by the control, listening and ranking components to automatically select a group of suitable devices from the plurality of devices to reproduce the content.
Also, the mediator may provide an arbitration component to resolve device conflicts. The arbitration component includes a set of rules that evaluates the device offerings provided by the plurality of devices or the values assigned to the plurality of devices when resolving device conflicts.
The network environment includes a plurality of devices capable of communicating wirelessly. A first communication device of the plurality of devices receives streaming content from a content source and reproduces the content. A second communication device of the plurality of devices receives content different from the content of the first communication device and reproduces the different content. When the first communication device comes into proximity with the second communication device a mediator is initiated to determine whether the content being reproduced by the first communication device should take precedence over the different content being reproduced on the second communication device.
The mediator determines a best-fit match between content and a plurality of devices in the network environment by mining for relationships between content and the plurality of devices. The method for mining relationships includes receiving content information, receiving device information, and correlating the content information and the device information. The relationships discovered include content-content, relationships between different content, content-device, relationships between a device and content, and device-device relationships, relationships between different devices, are stored by the mediator to facilitate quicker communication between the plurality of devices.
Additional advantages and novel features will be set forth in the description which follows and in part may become apparent to those skilled in the art upon examination of the following or may be learned by practice of the invention.
The present invention provides a mediator to efficiently conduct communication between various devices. The mediator enables a communication network that transports content, including video and audio, to efficiently utilize devices based on device offerings and content preferences. In one embodiment of the present invention, the devices are capable of communicating wirelessly and include devices such as smart phones, speakers, lights, projectors, laptops, monitors, personal digital assistants, etc. These devices are utilized such that a user's experience with the content is maximized.
The present invention is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
The present invention may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. The present invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
Computer 110 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 110 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by computer 110. Communication media typically embodies computer readable instructions, data structures, program modules or other data. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. The wireless communication media may be networks such as for example, Bluetooth or 802.11 networks. Combinations of the any of the above should also be included within the scope of computer readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in
When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
With reference to
The mediator 230 enables the network devices 212-214 and 220-224 to communicate with each other without pre-configuring each device. The mediator 230 is discussed in more detail with reference to
The content cloud 210 represent a content source such as the Internet, where content exists at various locations across the globe. The content includes multimedia content such as audio and video. The mediator allows the content cloud 210 to provide content to devices 220-224.
The content database 211 is a storage device that maintains content. The content database 211 may be a stand-alone device on an external communication network. The mediator 230 communicates with the content database 211 to access and retrieve content.
The content devices 212-214, include intelligent devices, such as, for example, personal computers, laptops and personal digital assistants. The content devices 212-214 are capable of storing content information.
The devices 220-224 are intelligent devices that receive content from a content source 210-214. Here, the devices 220-224 are operating as client devices and receive content stored on a content source 210-214. However, the devices 220-224 can also operate as servers to distribute content to other client devices.
In another embodiment of the present invention, the network 200 may be a network environment that includes non-intelligent devices.
The devices 610-630 include, light devices 610, proxy devices 611, blind devices 620 and display devices 630. The light devices 610 and the blind devices 620 are non-intelligent devices and the display devices 630 and the dynamic user interface device 640 are intelligent devices. The display devices 630 may include projectors, monitors, wide screen televisions, laptops, etc. The dynamic user interface device 640 may include portable devices such as, personal digital assistants, cell phones, etc. The light devices 610 and blind devices 620 control the ambient light in the network environment 600. The proxy devices 611 provide information about the non-intelligent devices' status and capabilities to the mediator 230, collect environment information, and receive commands from the dynamic user interface device 640 to control the non-intelligent devices 610 and 620.
The mediator 230 includes a ranking component 310, a listening component 320, an arbitration component 330 and a control component 340.
The ranking component 310 assigns values, indicative of importance, to content or to a device sending or receiving the content. The values may be assigned based on business rules or relevancy. The business rules may define which devices have priority when multiple devices are attempting to distribute content to a common device. For example, a door bell device sending a notification to a display device may take priority over a movie streaming on the display device depending on the time of day.
The listening component 320 collects information from the content and the devices. The information collected from the content may include metadata such as R-G-B values, author, size, optimal display and audio settings, etc. The device information may include attributes describing device offerings and capabilities, such as stereo, color, location, size of display, etc.
The arbitration component 330 resolves device or content conflicts. The arbitration component 320 utilizes the values assigned to the content and devices to decide which content is reproduced and which devices are utilized to reproduce the content. The arbitration component 330 may be configured to remedy device conflicts or content conflicts, or both.
The control component 340 specifies the level of user involvement for the mediator. This enables the mediator to either run automatically, with no user intervention, or to interact with the user to make decisions of where and how to reproduce the content.
It should be noted that the mediator might be mobile code distributed across the network. Each network device may run a mediator agent that implements one or more of the components described above. The mediator may also be part of the content.
With reference to
With reference to
With reference to
With reference to
With reference to
The method to resolve device contention enables a mobile device leaving an old network and entering into a new network to automatically synchronize with the other devices in the new network. With reference to
Referring to
When multiple network devices, such as, the display device 830, the speaker devices 820 and the new device 950 are streaming the same content the mediator creates a parent child relationship between the devices. The device on the network from which the streaming content originates, the new device 950, is considered a parent and the other network devices, the speaker devices 820 and the display device 830, are children. Thus, stopping reproduction at a child network device, the speaker devices 820 or the display device 830, does not stop reproduction at the parent, the new device 950, whereas stopping reproduction at the parent, the new device 950, stops reproduction on all devices, the display device 830 and the speaker devices 820, related with the parent, the new device 950.
Moreover, in an alternate embodiment of the present invention, content can be mixed, combined or scripted to create a multimedia presentation. For example, a token promoting a particular artist may contain licenses and links to images, videos, songs and text for that artist. A detailed description of this technology is provided in co-pending application Ser. No. 11/048,203, entitled “System and method for distributing digital content over a network,” which is herein incorporated by reference.
With reference to
In sum, embodiments of the present invention generate content-content, content-device relationships and device-device relationships and utilize the generated relationships to automatically create a suitable environment that maximizes a user's enjoyment when reproducing content. The foregoing descriptions of the invention are illustrative, and modifications in configuration and implementation will occur to persons skilled in the art. For instance, while the present invention has generally been described with relation to
This application is a continuation of prior application Ser. No. 11/117,571, filed 29 Apr. 2005, and entitled “Dynamically mediating multimedia content and devices.”
Number | Name | Date | Kind |
---|---|---|---|
5786823 | Madden et al. | Jul 1998 | A |
5818435 | Kozuka et al. | Oct 1998 | A |
5915067 | Nonomura et al. | Jun 1999 | A |
5956044 | Giorgianni et al. | Sep 1999 | A |
6198500 | Watanabe et al. | Mar 2001 | B1 |
6208428 | Chihara et al. | Mar 2001 | B1 |
6363429 | Ketcham | Mar 2002 | B1 |
6928262 | Kanemitsu | Aug 2005 | B1 |
7085761 | Shibata | Aug 2006 | B2 |
7356774 | Shah et al. | Apr 2008 | B2 |
7689095 | Sugiyama et al. | Mar 2010 | B2 |
7886318 | Wang et al. | Feb 2011 | B2 |
7987491 | Reisman | Jul 2011 | B2 |
8014759 | Komi et al. | Sep 2011 | B2 |
20010054180 | Atkinson | Dec 2001 | A1 |
20020011951 | Pepin et al. | Jan 2002 | A1 |
20020106193 | Park et al. | Aug 2002 | A1 |
20020169796 | Schwartz | Nov 2002 | A1 |
20030054821 | Kita et al. | Mar 2003 | A1 |
20030140158 | Lee et al. | Jul 2003 | A1 |
20040083015 | Patwari | Apr 2004 | A1 |
20040103216 | Lane | May 2004 | A1 |
20040255309 | Bhattacharya et al. | Dec 2004 | A1 |
20050002535 | Liu et al. | Jan 2005 | A1 |
20050034160 | Kim et al. | Feb 2005 | A1 |
20050262254 | Sherwani | Nov 2005 | A1 |
20060020973 | Hannum et al. | Jan 2006 | A1 |
20060025148 | Karaoguz et al. | Feb 2006 | A1 |
20060031882 | Swix et al. | Feb 2006 | A1 |
20060075460 | Anegawa et al. | Apr 2006 | A1 |
20060107194 | Gale | May 2006 | A1 |
20060171262 | Han | Aug 2006 | A1 |
20060223503 | Muhonen et al. | Oct 2006 | A1 |
20060242129 | Libes et al. | Oct 2006 | A1 |
20060280075 | Kanegae et al. | Dec 2006 | A1 |
20060288289 | Im | Dec 2006 | A1 |
20070031116 | Takatsuka et al. | Feb 2007 | A1 |
20070055566 | Gaughan et al. | Mar 2007 | A1 |
20070118521 | Jatowt et al. | May 2007 | A1 |
20070121625 | Youn et al. | May 2007 | A1 |
20070124796 | Wittkotter | May 2007 | A1 |
20070180468 | Gill et al. | Aug 2007 | A1 |
20070263818 | Sumioka et al. | Nov 2007 | A1 |
20080075428 | Hashimoto | Mar 2008 | A1 |
20080086678 | Herzman et al. | Apr 2008 | A1 |
20080151758 | Weinrib et al. | Jun 2008 | A1 |
20090022072 | Zhu et al. | Jan 2009 | A1 |
20090154477 | Heikens | Jun 2009 | A1 |
20090217061 | Yamamoto et al. | Aug 2009 | A1 |
20090307732 | Cohen et al. | Dec 2009 | A1 |
20100004014 | Coulombe | Jan 2010 | A1 |
20100030808 | Ress et al. | Feb 2010 | A1 |
20120076123 | Karaoguz et al. | Mar 2012 | A1 |
Number | Date | Country |
---|---|---|
2000-10539 | Jan 2000 | JP |
2001-94965 | Apr 2001 | JP |
2002-94396 | Mar 2002 | JP |
Number | Date | Country | |
---|---|---|---|
20080214104 A1 | Sep 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11117571 | Apr 2005 | US |
Child | 12105971 | US |