WO2002027431A2 - Portable devices and methods employing digital watermarking - Google Patents

Portable devices and methods employing digital watermarking Download PDF

Info

Publication number
WO2002027431A2
WO2002027431A2 PCT/US2001/030238 US0130238W WO0227431A2 WO 2002027431 A2 WO2002027431 A2 WO 2002027431A2 US 0130238 W US0130238 W US 0130238W WO 0227431 A2 WO0227431 A2 WO 0227431A2
Authority
WO
WIPO (PCT)
Prior art keywords
watermark
user
media
data
content
Prior art date
Application number
PCT/US2001/030238
Other languages
French (fr)
Other versions
WO2002027431A3 (en
Inventor
Geoffrey B. Rhoads
Bruce L. Davis
Original Assignee
Digimarc Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Digimarc Corporation filed Critical Digimarc Corporation
Priority to AU9634301A priority Critical patent/AU9634301A/en
Publication of WO2002027431A2 publication Critical patent/WO2002027431A2/en
Publication of WO2002027431A3 publication Critical patent/WO2002027431A3/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T1/00General purpose image data processing
    • G06T1/0021Image watermarking
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/166Editing, e.g. inserting or deleting
    • G06F40/169Annotation, e.g. comment data or footnotes

Definitions

  • FIG. 1 is a general block diagram that illustrates various embodiments according to the present invention.
  • a camera- equipped cell phone e.g., as announced by Sanyo/PacketVideo
  • a personal digital assistant e.g., Palm Pilot
  • a wrist camera watch e.g., the Casio WQV1-1CR
  • a digital camera or another portable device 10 with imaging capability
  • Image data is used to illustrate the same technology. The same principles are equally applicable with sound data.
  • the user device 10 can be a cell phone, an MP3 player/recorder, or other device with audio capture capability.
  • the device 10 transmits the image data to a remote processor 14.
  • the remote processor may be the user's home computer, or a server computer serving many users, or another remote computer, etc.
  • the transmission may be by wireless or by a wired connection.
  • the transmission can occur immediately, or the data can be stored in a memory in the device 10 and relayed at a later time, e.g., when network connectivity is established.
  • the remote processor 14 performs a watermark decoding operation on the received image data, and extracts a watermark payload.
  • Address information associated with this payload (e.g., a URL stored in a database record 12 indexed by an ID part of the payload, or a URL directly represented in the payload) is then obtained, and used to access an on-line resource 20 (e.g., a web page or music server) that provides content back to a desired destination device for storage or rendering.
  • the destination device can be an output device associated with the user (e.g., a display screen or an audio transducer, either integrated with the image capture device 10, or separate). Or it can be a home media appliance, permitting the user to view or listen to the content upon returning home.
  • the address information is forwarded back to a user device (e.g., device 10).
  • the user device then links to the specified resource 20 to acquire the content (so- called "pull" delivery).
  • the content available at the specified resource 20 is transmitted, at the instigation of the remote device 14, to the destination device (i.e., pushed, rather than pulled).
  • the watermark decoding is performed by a processor co-located with the user device 10, e.g., integrated therein.
  • the watermark decoding is performed locally, but the user device is unsuited for receiving or rendering the content provided from resource 20 (e.g., the device's rendering capabilities are limited, or the device's link to the network is of unsuitably low bandwidth).
  • the device 10 sends an ID decoded from the captured image (or sound) to a media server (e.g., the repository 20, together with instructions indicating what is to be done with content corresponding to the decoded ID.
  • the server may have a higher bandwidth connection with the ultimate destination, or may have more capability to process, render, or transmit the content, than the user device.
  • the server sends a higher fidelity version of the content (or some content related to the captured content) to the ultimate destination 22. (Or the server performs some other processing for which the portable device, or its lower bandwidth connection, are unsuited.)
  • the watermark payload transmitted from the user device serves as a proxy for the delivered content. Further details and variants of systems employing such proxy principles are found in cited application 09/504,239 (published as WOOl/48682).
  • the user's capture device may determine the available external bandwidth and then send the watermark data (rather than the captured content) only where bandwidth is insufficient (e.g., compared to a preset, or user-specified threshold) to transfer content from device 10 to a desired destination. Or this choice of sending the captured content, or the watermark proxy, can be specified by the user. If a first delivery approach fails (e.g., as indicated by an error message returned to one of the devices involved), then another delivery approach can be employed.
  • the user device can be so-informed and, in response, send the content it earlier captured.
  • the destination device 22 can also exercise some control in the method. For example, it might specify that it wants to receive a high resolution version of the content or a low resolution version of the content. Or, it may simply receive and store the watermark payload or a computer address corresponding thereto (e.g., as determined by the database record 12), permitting it to summon the content as desired, without dedicating local resources to store the content itself.
  • the destination device 22 may be a device distinct from the user device, this need not be the case.
  • the user device 10 may both serve as the content capturing node and the destination device.
  • an audio appliance e.g., an MP3 player/recorder
  • the appliance can signal the desired content either by locally decoding the watermark, and transferring same to a remote device.
  • the appliance can transfer the captured audio itself and allow a remote device to perform the watermark decoding.
  • the corresponding high fidelity MP3 version is returned for storage on the consumer device.
  • Patent US 6,122,403 and US application 09/503,881 (published as WOO 1/52181) detail illustrative watermark encoding and decoding methods. There are a great number of watermarking techniques known to those skilled in the art that can alternatively be employed. The embodiments detailed above, and in the cited applications, are illustrative only. A much larger class of embodiments are contemplated within the scope of the present invention - with elements from the detailed embodiments and the cited applications and publications incorporated applications interchanged, substituted and combined to yield other embodiments.
  • Digital watermarking is a process for modifying physical or electronic media to embed a machine-readable code into the media.
  • the media may be modified such that the embedded code is imperceptible or nearly imperceptible to the user, yet may be detected through an automated detection process.
  • digital watermarking is applied to media signals such as images, audio signals, and video signals.
  • documents e.g., through line, word or character shifting
  • software e.g., multi-dimensional graphics models, and surface textures of objects.
  • Digital watermarking systems typically have two primary components: an encoder that embeds the watermark in a host media signal, and a decoder that detects and reads the embedded watermark from a signal suspected of containing a watermark (a suspect signal).
  • the encoder embeds a watermark by altering the host media signal.
  • the reading component analyzes a suspect signal to detect whether a watermark is present. In applications where the watermark encodes information, the reader extracts this information from the detected watermark.
  • This invention relates to integrating watermark encoding and decoding functions in software applications, devices and systems.
  • Watermark encoders and decoders are integrated into operating systems, Internet browsers, media players, and other applications and devices. Such integration enables the watermark-enabled application or device to provide additional functionality and formation available via the watermark.
  • the watermark for example, may link to metadata or actions related to a media object.
  • the integrated application uses a watermark decoder to access the related metadata and actions.
  • the user interface of the integrated application is enhanced to present metadata and actions linked via the watermark.
  • watermark encoders may be integrated into applications to convert media objects into enhanced, watermarked objects.
  • the file browser enables the user to browse files, including media object files. It includes an extension to decode an object identifier from a selected media object file. The extension retrieves and displays metadata or actions associated with the media object file via the object identifier.
  • Another aspect of the invention is a file browser with an extension for encoding an object identifier.
  • This extension enables the user to encode an object identifier into a selected media object file.
  • it displays options for controlling the encoding of the object identifier.
  • the object identifier may be encoded into a watermark embedded in the media object.
  • the host application has a user interface for displaying a representation of media object files. It also has an extension for decoding a watermark from a selected media object file and for displaying metadata associated with the media object file via the watermark.
  • Another aspect of the invention is an enhanced internet browser.
  • the browser is enhanced with a listener program that identifies media objects in an HTML document, and inserts a handler into the HTML document when it finds an object marked with an object identifier.
  • the handler displays metadata linked via the object identifier in response to user input.
  • Another aspect of the invention is a method of rendering a media object with branding information. The method decodes an object identifier from the media object, sends the object identifier to a metadata server, receives a brand identifier from the metadata server, and displays a representation of the brand identifier.
  • Another aspect of the invention is a method for extending a user interface of a media player.
  • the method In response to input requesting playback of a media object, the method extracts an object identifier from the media object. It uses the object identifier to look up metadata associated with the media object. It then extends the user interface of the media player to include a representation of the metadata associated with the media object.
  • a watermark may be used to associate a media object such as an image, video or audio file to additional information and actions.
  • the watermark can associate the media object with metadata or processing actions encoded within or stored outside the media object.
  • Metadata may be encoded in a watermark message, stored within the media object file, or stored outside the media object file.
  • the watermark may encode an imperceptible and persistent link to this metadata, such as an object identifier (number, address, index, pointer, etc.) within the media object.
  • object identifier number, address, index, pointer, etc.
  • the specific infrastructure for retrieving metadata or actions associated with a media object via its watermark may vary.
  • the metadata or processing actions may reside in a metadata database in the same device or system as the media object, or in a remote device or system accessible via a wire or wireless network.
  • a distributed computing environment like the Internet one way is to implement a database server that takes a object identifier extracted from a watermark message and performs one or more tasks associated with the identifier, such as returning metadata or URL links to a requesting computer or device ("client"), routing the identifier to another server, executing some program or set of programs, etc.
  • the watermark message refers to the auxiliary data encoded into a host media object via the watermark.
  • a watermark decoder may be integrated in a file browser component of an operating system.
  • the decoder enables the file browser to extract a watermark and retrieve metadata for watermark enabled media objects.
  • the watermark decoder may operate as a foreground or background task, automatically or user-initiated, to detect a watermark.
  • Finding a watermark the browser annotates its representation of the media object as directed by the application(s) associated with the watermark.
  • the browser may proceed to retrieve additional information or actions associated with the object via the watermark and annotate its representation of the media object accordingly.
  • the browser may annotate the media object with a description of information or actions linked via the watermark (e.g., a brief description and/or http link), or may annotate the object with the actual information or actions.
  • the process of detecting a watermark and referencing information or actions via the watermark may be implemented to be transparent to the user.
  • the file browser displays information or options obtained via the watermark link without requiring the user to intervene in the watermark detection or information retrieval process.
  • the file browser can give the user the opportunity to control various stages of watermark detection and processing triggered by the watermark payload.
  • the user may be given the option to allow the watermark decoder to operate on media objects, and to determine whether and how actions triggered by the watermark payload should proceed.
  • the media object can be annotated with an indicator, such as a distinctive sound or logo, that informs the user that information and actions can be accessed via a link embedded in the watermark.
  • the user has the option to access additional information associated with the media object by, for example, selecting a visual logo associated with the object in the user interface.
  • An audio "logo" may be played when the user selects the object (e.g., passes a cursor over its graphical representation in the user interface).
  • the user interface of the application can be annotated with a variety of graphical and/or audio effects that inform the user of the presence of the watermark link and associated information and actions. Changes in the user interface may be used to convey different stages in the watermark detection and metadata retrieval process. For example, when it first detects the presence of a watermark, the decoder (or host application) plays a generic indicator, such as a simple logo or audio clip. Then, when the appropriate metadata server returns metadata and/or instructions linked via the watermark, the user interface presents specific information associated with the object.
  • a generic indicator such as a simple logo or audio clip.
  • the server may return program code, such as Java Applets, Visual Basic script, XML or some other set of instructions, that present information to the user and provide links to additional information and actions (e.g., URLs or hot links to web sites, other content or program code).
  • program code such as Java Applets, Visual Basic script, XML or some other set of instructions
  • the client typically is the computer or device that decoded the watermark link and issued a request based on the link to the server.
  • This code may perform a variety of functions, including controlling rendering of the watermarked media object and related media objects, some of which may be returned with the linked metadata.
  • the server may return code to control decoding or decrypting the media object or other related media signals to be played along with the watermarked media object.
  • the server may return code and/or links to enable the user to establish a license and obtain usage rights electronically with a licensing program executing locally and/or on a remote licensing computer (e.g., a licensing server on the Internet).
  • the server may return data, such as XML, that defines actions to be taken (by providing URLs, instructions, etc.).
  • the client computer or device receiving such a definition of actions may execute the action or present them to the user as options to be executed in response to user input (e.g., clicking on a graphical representation of the option in the user interface of a computer, responding to voice commands via a speech recognition engine, etc.).
  • the user can access linked information or actions by selecting a graphical representation of the object in a user interface. For example, the user can "click-on" an icon representing the object, or a rendered version of the object (e.g., an image) to determine whether metadata or actions are linked to the object, or to initiate a linked action or retrieval of the metadata.
  • the watermark decoder may be designed to search for the presence of watermarks in media objects in a specified location (e.g., directories, hard drive, etc.) in response to an event, at periodic intervals, or in response to a user request.
  • the watermark decoder maybe implemented as a utility service, similar to a file search utility, that the user may invoke to a extract watermark link from a media object file, or from a group of files.
  • the operating system can be designed to invoke the decoder at boot up on all files of a given type in a selected storage location (e.g., on the hard drive).
  • the operating system may also run the decoder as a background utility to periodically check for watermark links in media objects.
  • a timer or clock service may be used to trigger watermark detection when the timer elapses or at pre-determined time intervals.
  • the operating system may also run the decoder when prescribed events happen, such as downloading a file, saving a file, etc.
  • the file system may implement a scheme for tracking when and which media objects have been checked for watermarks.
  • One such scheme is to assign attributes to each media object to indicate whether it has been checked, whether or not it is watermarked, and if so, when the watermark was detected. Then, the decoder uses this information to check only media objects that have not been checked or have been modified, or for media objects for which a given period of time has elapsed since the last check. Each time a media object is modified, the attribute indicating that the mark has been checked may be reset to ensure that only new and modified objects are re-checked.
  • This "watermark aware" file browser augments the options of the context menu by listing options such as “Read Watermark” or “Watermark.”
  • the operating system invokes a watermark decoder on the media object.
  • the watermark decoder extracts the watermark link and acts in concert with network communication software to access the metadata database and retrieve the items from the database associated with the watermark link.
  • the file browser displays these items in a window.
  • the metadata may be stored locally (in the same machine as the media object), in a local area network or a wide area network. If the database is located on a remote computer on a computer network, such as the Internet, network communication software may be used to establish a connection with the database.
  • a window labeled Image Information displays metadata and actions associated with an image via a watermark link embedded in it.
  • the window displays a thumbnail of the image, image attributes (e.g., width, height, resolution, bits per pixel), and a series of HTML links to additional information and actions (such as a search for related images at other links).
  • Another way to display items linked via a watermark is to insert them in an additional property page.
  • the user accesses properties by right clicking the mouse while positioning the cursor over the media object's icon.
  • the operating system displays a properties window.
  • Each of the property pages associated with the media object has a tab (e.g., General, Image, Watermark, Security).
  • the Watermark page is selected.
  • the Watermark page lists a series of HTML links to additional information or actions.
  • the link invokes an Internet browser to retrieve information at the underlying URL. For actions like searches, the link may pass additional parameters such as attributes of the media object to the server at the URL, which in turn, executes a search using those parameters and returns the results to the Internet browser.
  • An additional way to reflect that a file includes watermarked data is to superimpose a graphical "watermark indicator" icon to the file's icon to signify the presence of a watermark in the file.
  • the decoder is implemented as a COM object client of the Windows Explorer.
  • the COM object client is registered with the operating system as a shell extension handler.
  • the former example referred to a context menu handler, while the second referred to a properties page handler.
  • Another possible implementation is to implement a shell extension that uses a shell execute command to launch a metadata retrieval application that gets and displays metadata options.
  • This implementation adds an extension to the file browser user interface, such as a context menu extension.
  • a context menu extension When the user selects a media file object within the file browser user interface, it displays a context menu with an option to launch the metadata retrieval program associated with media objects of a given type.
  • a number of actions can be tied to this option.
  • One action is to launch the metadata retrieval application program.
  • Another action is to launch a media player to play the selected option.
  • both actions can be initiated concurrently in a multitasking operating system.
  • a metadata retrieval application is a watermark decoder that extracts a watermark message, and forwards an object identifier from the message to a metadata server, which then returns metadata.
  • the retrieval application need not extract the object identifier from a watermark if it was already extracted and used recently to retrieve metadata. Instead, the retrieval application can proceed to display the metadata and actions to the user.
  • the shell execute command passes the name and location of the media object to the retrieval application.
  • the retrieval application may present its own user interface to display linked metadata and actions, or may pass them to the file browser, which then displays them within an extension such as a properties page or context menu extension.
  • the retrieval application may prompt the user to request permission before decoding a watermark or requesting an update of metadata from the metadata server.
  • the retrieval application may launch one or more other applications, such as an Internet browser to issue a request for metadata from a Web server and display metadata and actions in an HTML document returned from the server.
  • the approaches described above can be implemented for a variety of media object files, including image, video and audio files.
  • the object identifier need not be inserted in a watermark, but instead may be placed somewhere else in the media object file, such as a file header.
  • the watermark decoder may also be integrated into an Internet browser application.
  • an Internet browser can browse directories of files in a local computer or across a network.
  • Commercially available browsers like Internet Explorer from Microsoft Corporation and Netscape Navigator typically support transfer protocols like HTTP and FTP, and have additional components for interpreting or compiling code, including HTML, Java, Visual Basic and scripts (e.g., Java scripts, Visual Basic scripts, etc.).
  • Internet browsers can parse and render HTML for display in a computer or other device's user interface.
  • the Internet browser downloads and parses web pages with media objects on the Internet, it keeps a listing of these objects, and checks them for the presence of a watermark.
  • the listing it annotates the representation of the objects with watermarks to reflect the presence of the watermark, and potentially other data such as a URL where the media object originated.
  • the user may access the listing by viewing an application window (e.g., an application bar) that presents a visual representation of the media objects.
  • an application window e.g., an application bar
  • images one way to represent the media object is through the use of a thumbnail of the image. Images and other objects may be represented as a graphical icon, textual description, or both.
  • Watermark objects may be distinguished with a visual or audio indicator like a distinctive sound or logo.
  • the user views the metadata or actions associated with a media object by selecting the representation of the watermark-enabled object in some fashion. For example, the user can click on the thumbnail, icon, logo, or textual description to access a menu of metadata or actions linked to the object via the watermark.
  • Another way to indicate watermarked objects is to alter the appearance of a cursor in a graphical user interface of the software application when the user passes the cursor over the watermarked object or a representation of the object displayed in the graphical user interface.
  • One way to alter the cursor is to change it from a conventional pointer to a distinctive graphical icon associated with the detected watermarked object type.
  • Another way is to animate the cursor such that it morphs into some other shape or graphical design over a sequence of frames.
  • the user interface can alter the appearance of the watermarked object as the user passes the cursor over it.
  • the user interface can produce a distinctive sound when the user passes the cursor over the object to signify that it includes a watermark.
  • US Patent Application No. 09/165,142 provides an example of how to decode watermarks from images in HTML pages and annotate the images with a logo indicating that a watermark is present. It describes a way to present a representation of media objects (thumbnails of images) in an application window of a browser.
  • One such application window may be used to display thumbnails of images to present a history of images encountered while browsing web pages on the Internet or elsewhere. The user may click on an image to add it to a separate "bookmark" or "favorites" list.
  • Another application window may be used to display thumbnails of the images in this bookmark list.
  • the browser links to a network resource associated with the selected image (e.g., via an associated URL).
  • This network resource may be a web page where the image originated.
  • the resource may be a web page referenced via the watermark link embedded in the image.
  • the watermark message may encode a URL or an object identifier that is used to look up a URL of a network resource, such as a web page.
  • the URL might link to the web page of an owner, or to a licensing server.
  • One way to allow the user to access metadata and actions linked to a media object via a watermark is to display them in a menu in the user interface of the Internet browser.
  • a browser listener program receives events from the Internet browser indicating when a web page has been downloaded.
  • the listener requests from the browser the address or addresses of media objects in the web page.
  • the address indicates where the media object resides in memory (main memory, virtual memory, cache, etc.).
  • the listener invokes a watermark decoder on the media object or objects, passing it the address of the object in memory.
  • This handler program is responsible for presenting a logo or other indicator to the user indicating the presence of the watermark and providing hot links to information and actions.
  • the indicator may be a logo superimposed over a rendered version of a watermarked image object in the browser's user interface.
  • the handler program associated with it displays a menu of options.
  • the listener program retrieves these options by establishing a connection to a metadata server (e.g., a local or remote database), passing an object identifier extracted from the watermark to the server, and receiving associated items from the server.
  • a metadata server e.g., a local or remote database
  • object identifier extracted from the watermark to the server
  • receiving associated items from the server may include URL links to web pages related to the media object, information about the media object, or links to an action, such as licensing server.
  • Microsoft's dynamic HTML provides an interface that allows an Internet Explorer listener program to insert code to modify an HTML document. Using this interface, the listener program inserts a Java script that controls the display and responds to input to the logo superimposed on the image.
  • media content and web site developers may wish to selectively enable or disable functionality associated with a watermark link.
  • One way to implement this feature is to modify the media object file or some other file that acts as a container of a media object (e.g., an HTML) to include a control parameter (like a flag in a header file).
  • This control parameter indicates the presence of a watermark enabled media object and whether the watermark link is enabled or disabled.
  • the control parameter may be designed to default to being active, unless expressly turned off, or vice-versa.
  • content developers include the object in some multimedia work, such as a website, they can opt to disable the watermark link via the control parameter. Editing tools and other application programs and devices can be designed to turn the flag on unless expressly instructed to disable the watermark link.
  • the watermark act as a persistent link to associated metadata.
  • the media object may lose conventional metadata stored in the media object file.
  • the watermark link may be used to restore the metadata because the watermark is robust to various forms of transformations (e.g., digital to analog conversion, analog to digital conversion, compression, etc.).
  • the watermark can also be used as an attribute to the browser's file cache system. This allows cache browser applications to identify which cached files are watermarked and perform functions associated with the information embedded in the watermark as described throughout this document.
  • a media object database management system may implement similar functionality.
  • Digital asset management and digital rights management systems may use watermark enabled links to track and control the use of media objects.
  • File Open command is often used to browse file objects.
  • the context menu and properties page extensions described above can be implemented for applications that provide file browsing services.
  • Watermark encoding and decoding functions can also be integrated into file sharing systems, such as the peer to peer file sharing systems like Napster, Gnutella, Freenet, Scour, etc.
  • file sharing software executes on a number of client computers interconnected on a computer network. This software tracks the files available for sharing in the computer in which it executes, as well as other computers interconnected via the network.
  • File sharing software may use watermarks or other forms of embedded data in files to control file transfers (uploading and downloading files on the computer), verify that a file is complete and free of viruses, carry metadata that may be used to search for files in the file sharing system, carry links to additional information and opportunities to obtain usage rights or to buy intellectual property rights in the file, or related products or services.
  • the file sharing software includes watermark or other embedded data decoding software.
  • the file sharing software includes watermark or other embedded data encoding software.
  • Context Sensitive Watermark Links The actions or information linked to a media object via a watermark may be context sensitive.
  • Context examples include application context (e.g., referring to the application program that is operating on the object), the object location context (where the object resides relative to the user).
  • application context e.g., referring to the application program that is operating on the object
  • object location context where the object resides relative to the user.
  • the behavior of the link may be different when the user is manipulating the object in an editing tool as opposed to inserting the object in a document, such as a word processing document, a spreadsheet, or presentation.
  • the behavior of the watermark link may change based on whether the object is local, in an intranet, or on the Internet, relative to the user.
  • the decoder application may link to different metadata or processing actions depending on the context of the media object.
  • the watermark decoder provides context information to the metadata database, which in turn, provides context specific metadata or initiates context specific actions. For instance, if the object is being edited with an editing tool, the decoder provides information about the editing tool to the database in addition to the link extracted from the watermark. Similarly, the decoder may provide context information indicating where the object resides relative to the user's computer. Using the context information as a key, the metadata database returns metadata or initiates processing actions that are associated with the context. Another way to implement the context sensitive behavior is to allow the decoder to control the presentation of watermark-linked actions or information based on the context of the media object.
  • the context is defined by the application
  • this approach is akin to giving the application access to all of the linked metadata or actions, and then letting the application control presentation of the linked actions or information to the user.
  • the metadata database returns at least a descriptor of linked information and actions, and the application chooses which sub-set of the information or actions to apply based on the context.
  • the decoder operates in a similar fashion. For example, it may choose a sub-set of the linked actions of information based on the location of the object.
  • context information is user information supplied by the user's computer to a web server over the Internet using "cookie" technology.
  • the user's computer decodes a watermark from a media object, such as an image, audio, or video signal. It then sends information extracted from the watermark along with a cookie including user information to a metadata server or router (generally referred to as a server).
  • the server operates on user information from a cookie along with information extracted from a watermark in a media object to look up information or actions that are personalized to the user.
  • the metadata server for example, parses the cookie and uses it to reference information or addresses to network resources (URLs of web pages) in a database that relate to information in the cookie.
  • the server further narrows the pertinent information or links by using the watermark information to look up a subset of information or links that are pertinent to the watermarked object. Then either the server, or another network resource referenced by the database operations returns associated information back to the users computer for rendering on the display or audio output device.
  • This approach can be used to limit the information returned to specific news, advertising, content, etc. that is likely to be of interest to the user.
  • a similar effect can be achieved by programming the user's computer to supply user preferences that are used in a similar manner as the cookie information.
  • media objects may have different types of watermarks, each associated with a set of watermark encoders and decoders.
  • the decoder can be designed to support different watermark protocols.
  • the watermark protocols provide keys and other parameters specifying how to decode a watermark of a given type.
  • a common Application Programming Interface API can be specified for different core watermark encoder and decoder software modules or devices.
  • the user may install two or more different core watermark encoder/decoder modules.
  • the core modules may be implemented as plug-ins or dynamic link libraries.
  • the installation process updates a registry, such as the registry in the Windows Operating System, to reflect that a watermark type is supported. In this manner, watermark decoders for different media types, and different types of decoders for a single media type may be supported.
  • the media object file may specify the watermark type, e.g., through a parameter in a file header.
  • the file browser, or other client of the core watermark module may invoke the appropriate decoder by extracting the type parameter from the media object and passing it and a reference to the media object to the core module via the API.
  • the API routes the request to the appropriate core module, which in turn, extracts the watermark message, and returns it to the API.
  • the API passes the message to the requesting application.
  • the application or device processing the object may enumerate through all supported watermarking protocols to check if any protocol is present.
  • the watermark protocols for given media or file type may be registered in the device or application (e.g., in a registry of the operating system). To check for each one, the application invokes a watermark screening process for these protocols to determine whether a watermark associated with the protocols is present.
  • the watermark can be used to establish "branding" in addition to facilitating electronic access to other services.
  • a watermark decoder enabled application or device in a client reads the embedded watermark message from the object and use it to access a digital logo, such as a thumbnail image (e.g., a brand "brand image").
  • the decoder-enabled application sends an object identifier taken from the watermark message to a server (such as a metadata server on the Internet), which, in response, returns the logo.
  • the application then renders the logo, preferably superimposed on a rendered version of the media object or a graphical representation of it in the user interface of a client computer or device.
  • the server also returns an address (e.g., URL) pointing to either a generic "usage rights” server or a custom "usage rights” maintained by the media owner.
  • the server may return one or more links to related Web sites. Connection rights and corporate branding services may be provided via a central server on the Internet.
  • watermark enabled applications have many options to extend the branding and usage rights services.
  • An application could display "updatable" usage rights associated with the object identifier.
  • the application may display the branding logo visually superimposed over a portion of the rendered object (e.g., in a corner of a video frame, periodically for a predetermined period of time) or displayed as a splash screen initiation before playback of the media object begins.
  • the branding information may be accessible upon request through a menu (e.g., when the user clicks on a representation of the object or "help" menu).
  • the branding service transforms the notion of copyright notification into a substantial ever- present branding opportunity with additional functionality, such as a hot link to the home page of the content owner or to a licensing server.
  • the branding service may be combined with other watermark enabled functionality, such as a copy management instruction in the watermark payload, e.g., a control parameter indicating whether the object may be played, copied (number of copies allowed), recorded, transferred into other device or system, etc.
  • a copy management instruction in the watermark payload e.g., a control parameter indicating whether the object may be played, copied (number of copies allowed), recorded, transferred into other device or system, etc.
  • the watermark payload provides additional value to the consumer (e.g., linking to additional information and services associated with a media object) and ensures that the media object is well labeled and branded during playback.
  • More elaborate hot branding links, usage rights services, and context-sensitive linking may be added by associating the watermark link with software programs, metadata, and pointers to programs and metadata that support these features. These features may be added in the metadata server by adding them to the list of actions and/or metadata to be executed or returned in response to receiving the media object identifier.
  • the decoder enabled application may be programmed to send the media object identifier to two or more servers that provide different sets of services or metadata for the object identifier.
  • a media object may be associated with metadata from two or more different sources.
  • the metadata may be stored in a file that stores the media object.
  • file formats like JPEG2000, TIFF, JPEG, PSD may allow metadata to be stored along with the media signal (e.g., an image).
  • Metadata and instructions associated with a media object may be stored in the same device as the media object, or in a remote device (e.g., a remote database).
  • decoders may be programmed to extract metadata from each of the different sources.
  • the media type of file type may signal to the decoder to extract metadata from these different sources.
  • the watermark message or file metadata may enumerate the different sources of the metadata.
  • the decoder may be designed to get metadata from one or more sources and then present an aggregate of all information.
  • the decoder may perform an aggregation function automatically or prompt the user to select desired sources of metadata for display.
  • Metadata can be expressed in many forms and provide additional functionality.
  • metadata is information about the media object. It may also include machine instructions to be executed, or a reference to information or instructions (object, user, program, or machine identifiers, URLs, pointers, addresses, indices or keys to a database, etc.).
  • the machine instructions may, for example, control rendering, decoding, decrypting or other processing of the object. Alternatively, the instructions may provide some ancillary functionality.
  • One important application of metadata is to provide ownership information. Another is to provide licensing terms and usage rights.
  • the metadata can be used to describe attributes of the media object that the user or other applications may use. For example, one attribute may designate the content as restricted, which prevents an application from rendering the content for unauthorized users. Another attribute may designate the object as commercial, which requires an application to seek payment or a license before the object is rendered.
  • the media object may contain two or more watermarks or watermark messages, each associated with a distinct set of information or actions.
  • the media object may contain a creator ID, a distributor ID, etc. that link to information about the creator and distributor, respectively.
  • watermarks there are a number of ways to add watermarks to a media object, either at object creation time, or later as the object is transferred, copied, or edited.
  • One way is to interleave separate watermarks in different portions of the media object. This can be accomplished by modifying independent attributes of the media object. Independent, in this context, means that each watermark does not interfere with the detection of the other watermarks. While two independent watermarks may alter the same discrete sample of a media object, they do so in a manner that does not cause an invalid read of any of the watermarks.
  • Independent watermarks may be located in different spatial or temporal locations of the host media signal (e.g., image, video, audio, graphical model, etc.). The may also be located at different frequency bands or coefficients.
  • each independent watermark may be defined through a different protocol, which is used to encode a different watermark message (e.g., different watermark links for a creator, distributor, user, etc. of the media object).
  • Independent spatial watermarks may be interleaved by mapping each of the watermarks to a unique set of spatial locations in the image.
  • independent watermarks may be encoded in a temporal data sequence, like audio or video, by mapping each watermark to unique temporal locations.
  • the watermark may be linked to information and processing actions that control use of the media object.
  • the metadata may indicate the owner of the intellectual property rights in the object as well as licensing terms and conditions.
  • the watermark link or metadata trigger processing actions that control use of the object, such as requiring the user to submit payment, and exchanging decoding keys (e.g., decryption, decompression, etc.). While some amount of decoding of the object may be required to extract the watermark, the remainder of the content may remain encoded and/or encrypted until the user obtains appropriate usage rights.
  • the digital rights management functionality can be implemented in a licensing or usage rights server, such as the metadata server.
  • This server determines the owner and licensing terms based on the watermark message and executes actions required to authorize use of the object, e.g., electronically receiving payment information from the user, establishing and recording a user's assent to the license, forwarding transaction details to the owner, and returning a usage key to the user.
  • the watermark decoder can send a message to the server to log information about the usage, such as instances of use, machine ID of the player, time of use, etc.
  • Watermark decoders can also use context information along with information extracted from a watermark embedded in a media object to control use of that object.
  • the watermark decoder may be programmed to control the rendering, editing, copying or transfer of a media object depending on control data in the watermark and context information derived from the device or system in which the object resides.
  • the watermark may instruct the decoder to inhibit rendering of a media object if its outside of a given file (e.g., a specified web page, computer system, computer network, etc. ).
  • the decoder determines the pertinent context information that must be present to enable a particular operation.
  • identifiers are stored in association with the entities that they identify, or are dynamically derived from these entities.
  • a file identifier can be stored in a file header or footer, or derived from content in the file.
  • a storage device identifier can be stored on the storage device, or derived from content on the storage device or some attribute of it.
  • This context sensitive control of media objects is particularly useful in controlling the use of media files like music and movies, but applies to other types of media signals in which watermarks can be encoded.
  • context sensitive control can be used to prohibit rendering, copying or transfer of a media object when it is removed from the context of a web page, a computer, a storage device (e.g.., a CD or DVD), file sharing network, computers of paid subscribers of a subscription service, a collection of related media objects, etc.
  • the watermark embedded in a media object may play a role in asset management. Every time the object is processed (opened, edited, copied, etc.) an application equipped with a decoder can log information about the processing event. Alternatively, it can send a transaction event to a monitoring server via the Internet.
  • the transaction event may specify information about the object, such as its ID, the user's ID, the time and location of use, the nature of the use (number of playbacks).
  • the monitoring server or application records this transaction event in a database and, upon request, generates reports about the use of a given object, or by a given entity. Any of the fields of the transaction record can be used to query the database and generate custom reports.
  • Directory services like the Lightweight Directory Access Protocol (LDAP) can use the watermark or operate in conjunction with the watermark decoder to provide additional functionality.
  • LDAP Lightweight Directory Access Protocol
  • LDAP is an on-the-wire protocol used to perform directory operations such as read, search, add, and remove.
  • an LDAP service can be used to determine when to extract the watermark link and update attributes of a media object.
  • the LDAP service may control periodic updates of the media object's attributes by invoking a watermark decoder and retrieving an update of its attributes from a metadata server at predetermined times.
  • An LDAP search filter that includes or accesses a watermark decoder can also be provided to find watermarked media signals in files stored in file directories on computers.
  • a watermark decoder may be integrated with software and devices for playing or editing media objects.
  • Such integration allows metadata and actions linked to the media object to be accessible to the user in a seamless fashion through the user interface of the player.
  • a watermark enabled player may access and display linked metadata or actions automatically or at the user's selection. In either case, the user need not be aware that metadata or actions are obtained from a remote server via an object identifier.
  • such integration enables a content owner to link an object to licensing or assert usage control information or actions at playback time, whenever and wherever the object is played.
  • Such information and actions can be implemented by placing data or instructions in a watermark within the object, or putting an object identifier in the watermark that links to metadata or actions outside the object as detailed throughout this document.
  • the media player can be enhanced to display items linked via the watermark in a manner that appears to be a natural extension of the user interface.
  • the user or other program invokes the media player to play an object, it displays metadata or actions provided within or linked via the watermark in an extension of the media player's user interface.
  • Metadata or actions may be retrieved when the media player is launched or at some other time (e.g., as a background task, in response to user request, when the object is loaded to the computer or device where the media player resides, etc.).
  • the media player invokes a watermark decoder on an object in response to a user's request to play the object.
  • the media player passes the address of the object to the watermark decoder, which in turn, attempts to decode a watermark embedded in it.
  • the decoder Upon locating a watermark, the decoder forwards an object identifier extracted from it to a metadata server, which returns metadata or actions associated with the object identifier.
  • the media player proceeds to play the media object.
  • the extension to the media player displays returned metadata or actions.
  • Fig. 5 illustrates an example of an enhanced version of Microsoft's Windows Media player showing metadata and actions.
  • the user interface window of the player is expanded in a bottom section 502 to show metadata and links associated with a media object.
  • the bottom tab 504 displays a URL associated with that item.
  • the player invokes an Internet Browser, which sends a query to the resource at the selected URL (e.g., request an HTTP request to download an HTML document).
  • the watermark decoder may be invoked by another application, which launches the media player.
  • another application which launches the media player.
  • the user selects the object for playback. For example, the user could select a "Play" option via a context menu of the Windows Explorer, or via an insert in an HTML document as explained above.
  • a shell extension invokes the watermark decoder to get the associated metadata and executes a program (e.g., COM object, script, etc.) that runs the media player and displays the additional metadata linked via a watermark.
  • a Java script or other insert in the HTML document invokes the decoder and starts a program that runs the media player in a similar fashion.
  • ASX Advanced Streaming Redirector
  • Media content authoring tools may include watermark embedding functionality to embed watermarks into content, such as web page content. This embedded data then signals watermark decoder enabled devices and software to perform functions associated with the embedded watermark data.
  • Such tools may also include watermark decoding functionality to enable content developers to use the watermark decoding feature to screen media object for watermarks within the content authoring environment. If the watermark within a media object being edited conveys information (e.g., copyright owner information, licensing terms, etc.), then the authoring tool can convey this information to the user. If the watermark includes usage control information, then the authoring tool can control the use of the media object based on that information. For example, the watermark in a media object may convey an instruction that inhibits the authoring tool from editing the media object, unless the user obtains authorization from a licensing server.
  • information e.g., copyright owner information, licensing terms, etc.
  • Watermark encoding and decoding functions may also be integrated into network server application software to support functionality described in this document as well additional functionality.
  • watermark encoding and decoding can be integrated into web servers.
  • Watermark encoders can be integrated into web servers to embed watermarks in media content transferred to, from or through the server.
  • One reason for embedding watermarks at the server is to encode transaction specific information into a media object at the time of its transfer to, from or through the server.
  • the transaction specific information relates to an electronic transaction between the server and some other computer.
  • the server may embed information about the recipient/sender of the file into the media signal in the file (e.g., image, audio or video file). Since the watermark remains in the signal, information about the sender/recipient in the watermark remains with the media signal in the file through digital to analog — analog to digital conversion, file format changes, etc.
  • the server may embed a link to information or actions (links to related web sites) in the file that is uniquely tailored to the sender's/recipient's preferences.
  • the preferences may be obtained from the user's computer, such as through popular "cookie" technology commonly used in Internet browsers, or may reside in some other database that associates a user (a user identifier or an identifier of the user's computer) with the user's preferences (e.g., types of content preferences like news, financial information, sports, e-commerce opportunities, etc.).
  • the server obtains the user identifier and then queries the database for the associated preferences.
  • the server may also use the preferences obtained in this manner to control what forms of advertising is returned or linked with the file.
  • the user may request the server to download a desired audio, video, or image file.
  • the server gets the user's preferences and downloads the requested file along with advertising information and web site links that match the user's preferences.
  • the advertising information and links can be referenced by embedding a watermark that includes an address of the information, or that includes an index to a database entry that stores the information and or links to other information, web sites, etc.
  • the user's computer receiving the file downloaded from the server then renders the file and other related advertising information (e.g., provided in HTML, XML or some other conventional data format) from the server or some other server linked to the file via a watermark in the file.
  • the server may also embed usage control information into a watermark in a media file based on usage control rights requested by and paid for by the user in an electronic transaction between the server and the user's computer. These usage control rights can then be decoded by other applications and used to control rendering of the file, copying, recording, transfer, etc.
  • Network servers may also include watermark decoding functionality, such as software for decoding watermarks from media signals in files that are transferred to, from, or through the server. This enables the server to perform the many watermark-enabled functions described or incorporated into this document as well as to provide enhanced functionality.
  • the watermark may include usage control data that the server extracts and acts upon. Examples of usage control data include content rating information (adult content indicators), copy or transfer control information, rendering control information, compression/decompression control information, encryption decryption control information, links to external information or actions, etc.
  • the server can modify the file based on the extracted data. For example, the server may compress or encrypt the file in a manner specified in the watermark before transferring the file. The user at the computer receiving the file would then need to have a compatible decompression or decryption program or device to render the media object in the file.
  • the server can send related information or instructions to the receiving computer that controls of facilitates usage of the file.
  • the server could send additional information with the file (e.g., HTTP header information along with a web page including watermarked content) to instruct rendering software, such as the browser, how to render the watermarked content.
  • the rendering software on the receiving computer can then decide how to render the content. For example, if a child is logged onto the computer receiving the file, then the rendering software can opt not to render content in the file marked as "adult content.”
  • the server may decode a watermark that instructs it to send decryption or decompression keys to the rendering software to enable the receiving computer to decrypt or decompress the content. Public key encryption schemes can be used to perform key exchanges between the sending and receiving computers.
  • the server may decode a watermark that instructs it to send additional data along with the watermarked file including links to web sites based on information that the server decoded from the watermark.
  • Watermark decoders can be used in computers and computer networks to filter watermarked media objects and to count instances of watermarked media objects. Filtering refers to the use of the watermark decoder to decode watermarks from objects that reside in a particular location and control their use, transfer or rendering in response to control data in the watermark, and optionally, in response to additional context data outside the watermark. These media objects may be temporarily stored at the location of the filter, as in case of a device or computer responsible for transferring the media object. Examples of such systems are e-mail servers, firewalls, routers, or gateways in computer networks that use watermark decoding to control the transfer of certain media objects to other devices or computers based at least in part on watermarks found in the objects.
  • the media objects may also be stored at the location of a filter on a more permanent basis.
  • the filter may be used to screen media objects that a user downloads to or uploads from a mass storage device such as a hard drive or remote personal library of music, image and movie files on a mass storage device accessible via the Internet.
  • the filter may be used to inhibit downloading or uploading from the mass storage device in response to a watermark in a file being transferred, or alternatively, may be used to control rendering of the file.
  • Object counting refers to a way of logging the number of times a watermark media object is encountered, either by filtering media objects that pass through a particular device or system like a firewall or e-mail gateway, or by actively searching a network of systems like the Internet and screening for watermarked media objects found and downloaded as a result of the search.
  • the logs maintained by watermark decoding systems can be adapted to include additional information about the object, including information from the watermark, such as an owner, user or transaction identifier, tracer data, and information about the object, such as where it was found, how it was being used, who was using it, etc.
  • Tracer data includes data that is embedded in the file in response to some event, such as detecting unauthorized use, copying or transfer of the file.
  • the watermark decoder may be further augmented to send the log electronically to another device or computer in response to a specific request or in response to events.
  • the decoder can be programmed to send a report to a central database on another computer when the number of watermarked objects encountered has exceeded a threshold, and/or when certain information is found in a watermark, such as a particular identifier or tracer data that was embedded in the media object in response to detecting an unauthorized use or copying of it.
  • Programmatic rules can be established within the decoder to specify the conditions under which watermarked media objects are filtered and counted, to specify which information is logged, and to specify when the logged information is transmitted to another computer.
  • the watermark based filtering and counting functions can be implemented in a variety of software applications and devices. Some examples include a network firewall, and other client, server, or peer-to-peer software applications that encounter media objects (such as operating systems, media players, e-mail readers and servers, Internet browsers, file sharing software, file manager software, etc.).
  • media objects such as operating systems, media players, e-mail readers and servers, Internet browsers, file sharing software, file manager software, etc.
  • One particular use of watermark based filtering, screening and counting is to monitor watermarked content sent in or as an attachment to e-mails sent between computers.
  • watermark decoders can be employed in a distributed fashion to perform watermark screening and counting of watermarked media objects on networks, including the Internet.
  • watermark decoders can be deployed at a variety of locations on a computer network such as the Internet, including in Internet search engines that screen media objects gathered by each search engine, network firewalls that screen media objects that are encountered at the firewall, in local area networks and databases where spiders do not typically reach, in content filters, etc.
  • Each of these distributed decoders acts as a spider thread that logs watermark information as described in this document and those incorporated by reference.
  • Examples of the types of information include identifiers decoded from watermarks in watermarked media objects, media object counts, addresses of the location of the media objects (where they were found), and other context information (e.g., how the object was being used, who was using it, etc.).
  • the spider threads send their logs or reports to a central spider program that compiles them and aggregates the information into fields of a searchable database.
  • Watermark decoding may be used in conjunction with an event scheduler to schedule programmatic events that occur in response to decoding a watermark message of a given type.
  • event scheduler to schedule programmatic events that occur in response to decoding a watermark message of a given type.
  • triggering actions in response to decoding information, instructions, or links from a watermark message.
  • these actions are programmatic actions made by software in response to the watermark, while in other cases, these actions are device actions made by hardware circuitry, such as in the case of usage control of media signals in hardware implementations of audio and video players, recorders, etc.
  • an event scheduler can be used to schedule programmatic or device actions to occur at a later event, either at a specified time according to a clock or timer, or in response to a subsequent input, action, etc.
  • a watermark decoder implemented in a browser, operating system, media player or other software application decodes a watermark from a media object that links the object to one or more web sites.
  • the decoder schedules programmatic actions to occur at later times. Some examples of these actions include: displaying a window with a link to a specified web site at periodic intervals or in response to a programmatic action like the launching of a browser, media player or other application.
  • This approach can be used to prompt the user to buy a product, such as the media object (a music or video track) or some product depicted in the media object. Using this approach, many actions can be scheduled to occur in response to a single decoding of the watermark.
  • Watermark encoding functionality could be added to an operating system, Internet browser, or other applications. For instance, through a drag and drop procedure, a user could embed a watermark in a media object as a means of enabling the various functions outlined above.
  • a watermark encoder may be integrated in a file browser, Internet browser, media player, or other application using the same integration techniques outlined above for the decoder.
  • the watermark encoder is implemented as a shell extension handler. This handler is registered as a context menu extension in the registry of the Windows Operating system. As an alternative, it could be implemented as a properties page extension handler.
  • the handler displays a window.
  • This window enables the user to enter various Ids (e.g., a creator ID, image ID), which are encoded into an image via a watermark.
  • the user may also set or select attributes of the image object.
  • the user can control the embedding process by adjusting the durability of the watermark through a scroll bar control.
  • the user can compare the original and watermarked versions of the object by selecting the "Original" and "Watermarked” tabs. When satisfied, the user can save the watermarked image and exit the window (e.g., by selecting close).
  • Metadata and actions may be associated with the image object by forwarding them to the metadata server, which associates them with an object ID.
  • the shell extension may be designed to launch a media player to play the marked and unmarked objects as desired.
  • An operating environment for software implementations of the watermarking systems described above can be a conventional computer system.
  • the embedder and detector implementations can be implemented in C/C++ and are portable to many different computer systems.
  • An illustrative computer system includes a computer, including a processing unit, a system memory, and a system bus that interconnects various system components including the system memory to the processing unit.
  • the system bus may comprise any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using a bus architecture such as PCI, VESA,
  • MCA MicroChannel
  • ISA ISA
  • EISA EISA
  • the system memory includes read only memory (ROM) and random access memory (RAM).
  • ROM read only memory
  • RAM random access memory
  • BIOS basic input/output system
  • BIOS basic routines that help to transfer information between elements within the computer, such as during start-up, is stored in ROM.
  • the computer further includes a hard disk drive, a magnetic disk drive, e.g., to read from or write to a removable disk, and an optical disk drive, e.g., for reading a CD-ROM or DVD disk or to read from or write to other optical media.
  • the hard disk drive, magnetic disk drive, and optical disk drive are connected to the system bus by a hard disk drive interface, a magnetic disk drive interface, and an optical drive interface, respectively.
  • the drives and their associated computer-readable media provide nonvolatile storage of data, data structures, computer-executable instructions (program code such as dynamic link libraries, and executable files), etc. for the computer.
  • program code such as dynamic link libraries, and executable files
  • a number of program modules may be stored in the drives and RAM, including an operating system, one or more application programs, other program modules, and program data.
  • a user may enter commands and information into the personal computer through a keyboard and pointing device, such as a mouse.
  • Other input devices may include a microphone, sound card, radio or television tuner, joystick, game pad, satellite dish, digital camera, scanner, or die like.
  • a digital camera or scanner 43 may be used to capture the target image for the detection process described above.
  • the camera and scanner are each connected to the computer via a standard interface 44.
  • a standard interface 44 there are digital cameras designed to interface with a Universal Serial Bus (USB), Peripheral Component
  • PCI Peripheral Component Interconnect
  • USB2 and 1394 also known as firewire and iLink
  • watermarked images or video may be provided from other sources, such as a packaged media devices (e.g., CD, DVD, flash memory, etc), sfreaming media from a network connection, television tuner, etc.
  • watermarked audio may be provided from packaged devices, streaming media, radio tuner, sound cards, etc.
  • a port interface that is coupled to the system bus, either directly or indirectly.
  • Examples of such interfaces include a serial port, parallel port, game port or universal serial bus (USB).
  • a monitor or other type of display device is also connected to the system bus via an interface, such as a video adapter.
  • personal computers typically include other peripheral output devices (not shown), such as speakers and printers.
  • the computer operates in a networked environment using logical connections to one or more remote computers, such as a remote computer.
  • the remote computer may be a server, a router, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 1220, although only a memory storage device has been described.
  • the logical connections include a local area network (LAN) and a wide area network (WAN).
  • LAN local area network
  • WAN wide area network
  • the computer When used in a LAN networking environment, the computer is connected to the local network through a network interface or adapter. When used in a WAN networking environment, the personal computer typically includes a modem or other means for establishing communications over the wide area network, such as the Internet.
  • the modem which may be internal or external, is connected to the system bus via the serial port interface.
  • program modules depicted relative to the personal computer, or portions of them, may be stored in the remote memory storage device.
  • the processes detailed above can be implemented in a distributed fashion, and as parallel processes. It will be appreciated that the network connections shown are exemplary and that other means of establishing a communications link between the computers may be used.
  • media objects may be linked to their metadata via data structures other than a watermark embedded in the object.
  • the object identifier need not be inserted in a watermark, but instead may be placed somewhere else in the media object file, such as a file header.
  • Such an identifier may be inserted into the header of coded or compressed files.
  • a decoder parses the header and extracts the object identifier. Then, the decoder forwards the identifier to a metadata server, either directly, or by launching another application, such as web browser, to issue the metadata request and output the data and/or interpret code returned from the metadata server.

Abstract

Portable consumer electronic devices featuring image- or audio-capture capabilities, such as cell phones, wristwatches, digital cameras, personal digital assistants, and MP3 players, are becoming increasingly prevalent. Watermark information embedded in the captured content can be used to trigger distribution of corresponding content (web pages, high fidelity audio, etc.) from on-line repositories. Thus for example, music 'heard' by a user's cell phone microphone (10) can be processed and used to trigger the electronic delivery of a high fidelity version (20) of the same (or different) music to the portable device (22) or to the user's home computer (22). Likewise, an object 'shown' to a cell phone camera (10) can initiate a link to a corresponding web page, launch a corresponding application program, or otherwise control the device. The watermark can be decoded from the content in the consumer device, or the content can be transferred to a remote device (14) for decoding.

Description

PORTABLE DEVICES AND METHODS EMPLOYING DIGITAL WATERMARKING
Related Application Data The subject matter of this application is related to that disclosed in U.S. application 09/636, 102, filed August 10, 2000 (excerpts of which are attached as Exhibit A).
The subject matter of this application is also related to that disclosed in the following applications (which have now been published and are thus known to artisans in the field):
• US application 09/504,239, filed February 15, 2000 (published as WOO 1/48682); • US application 09/571,422, filed May 15, 2000 (published as WO00/70585); and
• US application 09/503,881 (published as WO01/52181).
Background Portable consumer electronic devices featuring image- or audio-capture capabilities, such as cell phones, wristwatches, digital cameras, personal digital assistants, and MP3 players, are becoming increasingly prevalent. Watermark information embedded in the captured content can be used to trigger distribution of corresponding content (web pages, high fidelity audio, etc.) from on-line repositories. Thus, for example, music "heard" by a user's cell phone microphone can be processed and used to trigger the electronic delivery of a high fidelity version of the same (or different) music to the user's home computer. The following specification details many such arrangements.
Brief Description of the Drawings Fig. 1 is a general block diagram that illustrates various embodiments according to the present invention.
Detailed Description In accordance with one embodiment of the present invention (Fig. 1), a camera- equipped cell phone (e.g., as announced by Sanyo/PacketVideo), a personal digital assistant (e.g., Palm Pilot), a wrist camera watch (e.g., the Casio WQV1-1CR), a digital camera, or another portable device 10 with imaging capability, captures one or more frames of image data. (Image data is used to illustrate the same technology. The same principles are equally applicable with sound data. In such case the user device 10 can be a cell phone, an MP3 player/recorder, or other device with audio capture capability.)
In response to a user command (e.g., a dedicated physical or virtual (Ul-implemented) button, or a series of keystrokes, etc.), or autonomously (e.g., whenever an image is captured), the device 10 transmits the image data to a remote processor 14. (The remote processor may be the user's home computer, or a server computer serving many users, or another remote computer, etc. The transmission may be by wireless or by a wired connection. The transmission can occur immediately, or the data can be stored in a memory in the device 10 and relayed at a later time, e.g., when network connectivity is established.) The remote processor 14 performs a watermark decoding operation on the received image data, and extracts a watermark payload. Address information associated with this payload (e.g., a URL stored in a database record 12 indexed by an ID part of the payload, or a URL directly represented in the payload) is then obtained, and used to access an on-line resource 20 (e.g., a web page or music server) that provides content back to a desired destination device for storage or rendering. The destination device can be an output device associated with the user (e.g., a display screen or an audio transducer, either integrated with the image capture device 10, or separate). Or it can be a home media appliance, permitting the user to view or listen to the content upon returning home. hi some embodiments, the address information is forwarded back to a user device (e.g., device 10). The user device then links to the specified resource 20 to acquire the content (so- called "pull" delivery). In other embodiments, the content available at the specified resource 20 is transmitted, at the instigation of the remote device 14, to the destination device (i.e., pushed, rather than pulled).
In other embodiments, the watermark decoding is performed by a processor co-located with the user device 10, e.g., integrated therein.
In still other embodiments, the watermark decoding is performed locally, but the user device is unsuited for receiving or rendering the content provided from resource 20 (e.g., the device's rendering capabilities are limited, or the device's link to the network is of unsuitably low bandwidth). In such case, the device 10 sends an ID decoded from the captured image (or sound) to a media server (e.g., the repository 20, together with instructions indicating what is to be done with content corresponding to the decoded ID. The server may have a higher bandwidth connection with the ultimate destination, or may have more capability to process, render, or transmit the content, than the user device. The server sends a higher fidelity version of the content (or some content related to the captured content) to the ultimate destination 22. (Or the server performs some other processing for which the portable device, or its lower bandwidth connection, are unsuited.)
In the example just given, it will be recognized that the watermark payload transmitted from the user device serves as a proxy for the delivered content. Further details and variants of systems employing such proxy principles are found in cited application 09/504,239 (published as WOOl/48682).
In other embodiments, the user's capture device may determine the available external bandwidth and then send the watermark data (rather than the captured content) only where bandwidth is insufficient (e.g., compared to a preset, or user-specified threshold) to transfer content from device 10 to a desired destination. Or this choice of sending the captured content, or the watermark proxy, can be specified by the user. If a first delivery approach fails (e.g., as indicated by an error message returned to one of the devices involved), then another delivery approach can be employed. For example, if a watermark proxy is first sent, but the content respository 20 identified thereby does not have corresponding content, or is otherwise unable to transmit content to a destination device, the user device can be so-informed and, in response, send the content it earlier captured.
The destination device 22 can also exercise some control in the method. For example, it might specify that it wants to receive a high resolution version of the content or a low resolution version of the content. Or, it may simply receive and store the watermark payload or a computer address corresponding thereto (e.g., as determined by the database record 12), permitting it to summon the content as desired, without dedicating local resources to store the content itself.
While the destination device 22 may be a device distinct from the user device, this need not be the case. The user device 10 may both serve as the content capturing node and the destination device. For example, an audio appliance (e.g., an MP3 player/recorder) may capture a part of a watermarked song broadcast over the radio, and thereby obtain a high fidelity version of the same song from an on-line music repository. Again, the appliance can signal the desired content either by locally decoding the watermark, and transferring same to a remote device. Or the appliance can transfer the captured audio itself and allow a remote device to perform the watermark decoding. In any event, and possibly through one or more intermediary devices and databases, the corresponding high fidelity MP3 version is returned for storage on the consumer device. (In some methods, only the decoded watermark data is returned to the user device, permitting it to thereby summon the corresponding content on- demand from a repository 20 without dedicating local resources for storage.) Further information on systems in which machine-readable indicia (e.g., watermarks) are sensed by a consumer device, and used to link to associated internet content, is found in application 09/571,422 (published as WO00/70585). That application discloses information on cell phones and the like for use in such applications. Application 09/636,102 (Exhibit A) details other arrangements in which content captured by one device is provided to a second device for watermark decoding.
Patent US 6,122,403 and US application 09/503,881 (published as WOO 1/52181) detail illustrative watermark encoding and decoding methods. There are a great number of watermarking techniques known to those skilled in the art that can alternatively be employed. The embodiments detailed above, and in the cited applications, are illustrative only. A much larger class of embodiments are contemplated within the scope of the present invention - with elements from the detailed embodiments and the cited applications and publications incorporated applications interchanged, substituted and combined to yield other embodiments.
APPENDIX A Excerpts from U.S. Application 09/636,102
Background and Summary Digital watermarking is a process for modifying physical or electronic media to embed a machine-readable code into the media. The media may be modified such that the embedded code is imperceptible or nearly imperceptible to the user, yet may be detected through an automated detection process. Most commonly, digital watermarking is applied to media signals such as images, audio signals, and video signals. However, it may also be applied to other types of media objects, including documents (e.g., through line, word or character shifting), software, multi-dimensional graphics models, and surface textures of objects.
Digital watermarking systems typically have two primary components: an encoder that embeds the watermark in a host media signal, and a decoder that detects and reads the embedded watermark from a signal suspected of containing a watermark (a suspect signal). The encoder embeds a watermark by altering the host media signal. The reading component analyzes a suspect signal to detect whether a watermark is present. In applications where the watermark encodes information, the reader extracts this information from the detected watermark.
A great number of particular watermarking techniques are known. The reader is presumed to be familiar with the literature in this field. Particular techniques for embedding and detecting imperceptible watermarks in media signals are detailed in the present assignee's copending application serial number 09/503,881. Other watermarking techniques are known from published patents to NEC (inventor Cox et al), IBM (inventors Morimoto and Braudaway et al), Dice (inventor Cooperman), Philips (inventors Kalker, Linnartz, Talstra, etc. Audio watermarking techniques are known from published patents to Aris (inventor Winograd, Metois, Wolosewicz, etc.), Solana (inventor Lee, Warren, etc.), Dice, AudioTrack, Philips, etc.
This invention relates to integrating watermark encoding and decoding functions in software applications, devices and systems. Watermark encoders and decoders are integrated into operating systems, Internet browsers, media players, and other applications and devices. Such integration enables the watermark-enabled application or device to provide additional functionality and formation available via the watermark. The watermark, for example, may link to metadata or actions related to a media object. To exploit this watermark enabled functionality, the integrated application uses a watermark decoder to access the related metadata and actions. The user interface of the integrated application is enhanced to present metadata and actions linked via the watermark. Similarly, watermark encoders may be integrated into applications to convert media objects into enhanced, watermarked objects.
One aspect of the invention is an enhanced file browser system. The file browser enables the user to browse files, including media object files. It includes an extension to decode an object identifier from a selected media object file. The extension retrieves and displays metadata or actions associated with the media object file via the object identifier.
Another aspect of the invention is a file browser with an extension for encoding an object identifier. This extension enables the user to encode an object identifier into a selected media object file. In an extension to the file browser's user interface, it displays options for controlling the encoding of the object identifier. The object identifier may be encoded into a watermark embedded in the media object.
Another aspect of the invention is a watermark decoder system incorporated into a host application. The host application has a user interface for displaying a representation of media object files. It also has an extension for decoding a watermark from a selected media object file and for displaying metadata associated with the media object file via the watermark.
Another aspect of the invention is an enhanced internet browser. The browser is enhanced with a listener program that identifies media objects in an HTML document, and inserts a handler into the HTML document when it finds an object marked with an object identifier. The handler displays metadata linked via the object identifier in response to user input. Another aspect of the invention is a method of rendering a media object with branding information. The method decodes an object identifier from the media object, sends the object identifier to a metadata server, receives a brand identifier from the metadata server, and displays a representation of the brand identifier.
Another aspect of the invention is a method for extending a user interface of a media player. In response to input requesting playback of a media object, the method extracts an object identifier from the media object. It uses the object identifier to look up metadata associated with the media object. It then extends the user interface of the media player to include a representation of the metadata associated with the media object.
Further features of the invention will become apparent with reference to the following detailed description and accompanying drawings.
Detailed Description Introduction
A watermark may be used to associate a media object such as an image, video or audio file to additional information and actions. The watermark can associate the media object with metadata or processing actions encoded within or stored outside the media object. Metadata may be encoded in a watermark message, stored within the media object file, or stored outside the media object file. When metadata is stored outside the media object, the watermark may encode an imperceptible and persistent link to this metadata, such as an object identifier (number, address, index, pointer, etc.) within the media object. Wherever me media object travels, watermark decoder-enabled software or devices can extract the watermark from the media signal, and access the metadata or actions associated with the object via the watermark link. The specific infrastructure for retrieving metadata or actions associated with a media object via its watermark may vary. The metadata or processing actions may reside in a metadata database in the same device or system as the media object, or in a remote device or system accessible via a wire or wireless network. In a distributed computing environment like the Internet, one way is to implement a database server that takes a object identifier extracted from a watermark message and performs one or more tasks associated with the identifier, such as returning metadata or URL links to a requesting computer or device ("client"), routing the identifier to another server, executing some program or set of programs, etc. The watermark message refers to the auxiliary data encoded into a host media object via the watermark. The following sections summarize ways to take advantage of this functionality in an operating system, Internet browser, and other applications (whether implemented in hardware devices, software, or a combination of hardware and software).
I. Integrating a Watermark Decoder in Operating Systems and Other Applications
1. In Operating System
A watermark decoder may be integrated in a file browser component of an operating system. The decoder enables the file browser to extract a watermark and retrieve metadata for watermark enabled media objects. As the user browses files, the watermark decoder may operate as a foreground or background task, automatically or user-initiated, to detect a watermark. Finding a watermark, the browser annotates its representation of the media object as directed by the application(s) associated with the watermark. Depending on the implementation, the browser may proceed to retrieve additional information or actions associated with the object via the watermark and annotate its representation of the media object accordingly. For example, the browser may annotate the media object with a description of information or actions linked via the watermark (e.g., a brief description and/or http link), or may annotate the object with the actual information or actions.
The process of detecting a watermark and referencing information or actions via the watermark may be implemented to be transparent to the user. For example, the file browser displays information or options obtained via the watermark link without requiring the user to intervene in the watermark detection or information retrieval process.
Alternatively, the file browser can give the user the opportunity to control various stages of watermark detection and processing triggered by the watermark payload. For instance, the user may be given the option to allow the watermark decoder to operate on media objects, and to determine whether and how actions triggered by the watermark payload should proceed. Upon detection of a watermark, for example, the media object can be annotated with an indicator, such as a distinctive sound or logo, that informs the user that information and actions can be accessed via a link embedded in the watermark. The user has the option to access additional information associated with the media object by, for example, selecting a visual logo associated with the object in the user interface. An audio "logo" may be played when the user selects the object (e.g., passes a cursor over its graphical representation in the user interface).
The user interface of the application can be annotated with a variety of graphical and/or audio effects that inform the user of the presence of the watermark link and associated information and actions. Changes in the user interface may be used to convey different stages in the watermark detection and metadata retrieval process. For example, when it first detects the presence of a watermark, the decoder (or host application) plays a generic indicator, such as a simple logo or audio clip. Then, when the appropriate metadata server returns metadata and/or instructions linked via the watermark, the user interface presents specific information associated with the object. The server may return program code, such as Java Applets, Visual Basic script, XML or some other set of instructions, that present information to the user and provide links to additional information and actions (e.g., URLs or hot links to web sites, other content or program code). Upon receiving this code, a client computer or device executes it. The client typically is the computer or device that decoded the watermark link and issued a request based on the link to the server. This code may perform a variety of functions, including controlling rendering of the watermarked media object and related media objects, some of which may be returned with the linked metadata. The server may return code to control decoding or decrypting the media object or other related media signals to be played along with the watermarked media object. In addition, the server may return code and/or links to enable the user to establish a license and obtain usage rights electronically with a licensing program executing locally and/or on a remote licensing computer (e.g., a licensing server on the Internet).
The server may return data, such as XML, that defines actions to be taken (by providing URLs, instructions, etc.). The client computer or device receiving such a definition of actions may execute the action or present them to the user as options to be executed in response to user input (e.g., clicking on a graphical representation of the option in the user interface of a computer, responding to voice commands via a speech recognition engine, etc.).
The user can access linked information or actions by selecting a graphical representation of the object in a user interface. For example, the user can "click-on" an icon representing the object, or a rendered version of the object (e.g., an image) to determine whether metadata or actions are linked to the object, or to initiate a linked action or retrieval of the metadata. The watermark decoder may be designed to search for the presence of watermarks in media objects in a specified location (e.g., directories, hard drive, etc.) in response to an event, at periodic intervals, or in response to a user request. For instance, the watermark decoder maybe implemented as a utility service, similar to a file search utility, that the user may invoke to a extract watermark link from a media object file, or from a group of files. As another example, the operating system can be designed to invoke the decoder at boot up on all files of a given type in a selected storage location (e.g., on the hard drive). The operating system may also run the decoder as a background utility to periodically check for watermark links in media objects. A timer or clock service may be used to trigger watermark detection when the timer elapses or at pre-determined time intervals. The operating system may also run the decoder when prescribed events happen, such as downloading a file, saving a file, etc. Triggering the decoder in response to such events enables the operating system to ensure that media objects are checked whenever they enter the system or device in which the operating system is executing, and whenever they are edited. To improve the efficiency of the watermark decoder, the file system may implement a scheme for tracking when and which media objects have been checked for watermarks. One such scheme is to assign attributes to each media object to indicate whether it has been checked, whether or not it is watermarked, and if so, when the watermark was detected. Then, the decoder uses this information to check only media objects that have not been checked or have been modified, or for media objects for which a given period of time has elapsed since the last check. Each time a media object is modified, the attribute indicating that the mark has been checked may be reset to ensure that only new and modified objects are re-checked.
To illustrate the concept, consider an implementation in the Windows Operating System, particularly an extension of the Windows Explorer user interface to support watermark embedding and reading of media objects. Media object files are typically represented as icons in the user interface of the Windows Explorer file browser. By right clicking the mouse while positioning a cursor over the file icon, the user can access a context menu of options associated with the selected media object.
This "watermark aware" file browser augments the options of the context menu by listing options such as "Read Watermark" or "Watermark." When the user positions the cursor over the "Read Watermark" option, the operating system invokes a watermark decoder on the media object. The watermark decoder extracts the watermark link and acts in concert with network communication software to access the metadata database and retrieve the items from the database associated with the watermark link. The file browser displays these items in a window.
There are a variety of ways to access the metadata database. The metadata may be stored locally (in the same machine as the media object), in a local area network or a wide area network. If the database is located on a remote computer on a computer network, such as the Internet, network communication software may be used to establish a connection with the database.
When selected, the "Watermark" option displays further options for reading and embedding information ("Read Information..." and "Embed Information..."). A window labeled Image Information displays metadata and actions associated with an image via a watermark link embedded in it. In this example, the window displays a thumbnail of the image, image attributes (e.g., width, height, resolution, bits per pixel), and a series of HTML links to additional information and actions (such as a search for related images at other links).
Another way to display items linked via a watermark is to insert them in an additional property page. While executing the file browser, the user accesses properties by right clicking the mouse while positioning the cursor over the media object's icon. In response to selecting properties, the operating system displays a properties window. Each of the property pages associated with the media object has a tab (e.g., General, Image, Watermark, Security). The Watermark page is selected. Like the options displayed in the window earlier discussed, the Watermark page lists a series of HTML links to additional information or actions. When selected, the link invokes an Internet browser to retrieve information at the underlying URL. For actions like searches, the link may pass additional parameters such as attributes of the media object to the server at the URL, which in turn, executes a search using those parameters and returns the results to the Internet browser.
An additional way to reflect that a file includes watermarked data is to superimpose a graphical "watermark indicator" icon to the file's icon to signify the presence of a watermark in the file.
While the implementation may vary, the examples discussed above are shell extensions of the Windows Explorer file browser. The decoder is implemented as a COM object client of the Windows Explorer. The COM object client is registered with the operating system as a shell extension handler. The former example referred to a context menu handler, while the second referred to a properties page handler.
Another possible implementation is to implement a shell extension that uses a shell execute command to launch a metadata retrieval application that gets and displays metadata options. This implementation adds an extension to the file browser user interface, such as a context menu extension. When the user selects a media file object within the file browser user interface, it displays a context menu with an option to launch the metadata retrieval program associated with media objects of a given type. A number of actions can be tied to this option. One action is to launch the metadata retrieval application program. Another action is to launch a media player to play the selected option. Of course, both actions can be initiated concurrently in a multitasking operating system.
One example of a metadata retrieval application is a watermark decoder that extracts a watermark message, and forwards an object identifier from the message to a metadata server, which then returns metadata. As noted above, the retrieval application need not extract the object identifier from a watermark if it was already extracted and used recently to retrieve metadata. Instead, the retrieval application can proceed to display the metadata and actions to the user.
To launch the retrieval application, the shell execute command passes the name and location of the media object to the retrieval application. The retrieval application may present its own user interface to display linked metadata and actions, or may pass them to the file browser, which then displays them within an extension such as a properties page or context menu extension. The retrieval application may prompt the user to request permission before decoding a watermark or requesting an update of metadata from the metadata server. Additionally, the retrieval application may launch one or more other applications, such as an Internet browser to issue a request for metadata from a Web server and display metadata and actions in an HTML document returned from the server.
The approaches described above can be implemented for a variety of media object files, including image, video and audio files. Also, the object identifier need not be inserted in a watermark, but instead may be placed somewhere else in the media object file, such as a file header. In Browser
The watermark decoder may also be integrated into an Internet browser application. Like the file browser, an Internet browser can browse directories of files in a local computer or across a network. Commercially available browsers like Internet Explorer from Microsoft Corporation and Netscape Navigator typically support transfer protocols like HTTP and FTP, and have additional components for interpreting or compiling code, including HTML, Java, Visual Basic and scripts (e.g., Java scripts, Visual Basic scripts, etc.). In addition, Internet browsers can parse and render HTML for display in a computer or other device's user interface.
To illustrate integrating a watermark decoder in an Internet browser, consider the following example. As the Internet browser downloads and parses web pages with media objects on the Internet, it keeps a listing of these objects, and checks them for the presence of a watermark. In the listing, it annotates the representation of the objects with watermarks to reflect the presence of the watermark, and potentially other data such as a URL where the media object originated. The user may access the listing by viewing an application window (e.g., an application bar) that presents a visual representation of the media objects. For images, one way to represent the media object is through the use of a thumbnail of the image. Images and other objects may be represented as a graphical icon, textual description, or both. Watermark objects may be distinguished with a visual or audio indicator like a distinctive sound or logo. The user views the metadata or actions associated with a media object by selecting the representation of the watermark-enabled object in some fashion. For example, the user can click on the thumbnail, icon, logo, or textual description to access a menu of metadata or actions linked to the object via the watermark.
Another way to indicate watermarked objects is to alter the appearance of a cursor in a graphical user interface of the software application when the user passes the cursor over the watermarked object or a representation of the object displayed in the graphical user interface. One way to alter the cursor is to change it from a conventional pointer to a distinctive graphical icon associated with the detected watermarked object type. Another way is to animate the cursor such that it morphs into some other shape or graphical design over a sequence of frames. Similarly, the user interface can alter the appearance of the watermarked object as the user passes the cursor over it. In addition, the user interface can produce a distinctive sound when the user passes the cursor over the object to signify that it includes a watermark.
US Patent Application No. 09/165,142 provides an example of how to decode watermarks from images in HTML pages and annotate the images with a logo indicating that a watermark is present. It describes a way to present a representation of media objects (thumbnails of images) in an application window of a browser. One such application window may be used to display thumbnails of images to present a history of images encountered while browsing web pages on the Internet or elsewhere. The user may click on an image to add it to a separate "bookmark" or "favorites" list. Another application window may be used to display thumbnails of the images in this bookmark list. By selecting an image or a representation of it, the browser links to a network resource associated with the selected image (e.g., via an associated URL). This network resource may be a web page where the image originated. Alternatively, the resource may be a web page referenced via the watermark link embedded in the image. The watermark message may encode a URL or an object identifier that is used to look up a URL of a network resource, such as a web page. For example, the URL might link to the web page of an owner, or to a licensing server.
The methods described in US Patent Application No. 09/165,142 may be applied to other media objects like video and audio signals.
One way to allow the user to access metadata and actions linked to a media object via a watermark is to display them in a menu in the user interface of the Internet browser. Consider such an interface that displays metadata and actions associated with a media object in the user interface of an
Internet browser. A browser listener program receives events from the Internet browser indicating when a web page has been downloaded. The listener requests from the browser the address or addresses of media objects in the web page. The address indicates where the media object resides in memory (main memory, virtual memory, cache, etc.). The listener invokes a watermark decoder on the media object or objects, passing it the address of the object in memory.
Finding a watermark, the listener inserts a handler program into the web page in memory. This handler program is responsible for presenting a logo or other indicator to the user indicating the presence of the watermark and providing hot links to information and actions. For example, the indicator may be a logo superimposed over a rendered version of a watermarked image object in the browser's user interface.
When the user passes the cursor over a logo and selects it, the handler program associated with it displays a menu of options. The listener program retrieves these options by establishing a connection to a metadata server (e.g., a local or remote database), passing an object identifier extracted from the watermark to the server, and receiving associated items from the server. These items may include URL links to web pages related to the media object, information about the media object, or links to an action, such as licensing server.
While specific implementations may vary, the examples discussed above are implemented using document view extensions to the Internet Explorer browser from Microsoft Corporation. Microsoft's dynamic HTML provides an interface that allows an Internet Explorer listener program to insert code to modify an HTML document. Using this interface, the listener program inserts a Java script that controls the display and responds to input to the logo superimposed on the image.
In some applications, media content and web site developers may wish to selectively enable or disable functionality associated with a watermark link. One way to implement this feature is to modify the media object file or some other file that acts as a container of a media object (e.g., an HTML) to include a control parameter (like a flag in a header file). This control parameter indicates the presence of a watermark enabled media object and whether the watermark link is enabled or disabled. The control parameter may be designed to default to being active, unless expressly turned off, or vice-versa. When content developers include the object in some multimedia work, such as a website, they can opt to disable the watermark link via the control parameter. Editing tools and other application programs and devices can be designed to turn the flag on unless expressly instructed to disable the watermark link.
In other applications, it is important that the watermark act as a persistent link to associated metadata. As the media object travels through different systems, gets coded/decoded, gets modified, etc., it may lose conventional metadata stored in the media object file. In these cases, the watermark link may be used to restore the metadata because the watermark is robust to various forms of transformations (e.g., digital to analog conversion, analog to digital conversion, compression, etc.).
Another way to selectively control functionality made available via the watermark is to enable the user to enable or disable watermark decoding on media objects. The watermark can also be used as an attribute to the browser's file cache system. This allows cache browser applications to identify which cached files are watermarked and perform functions associated with the information embedded in the watermark as described throughout this document.
In Other Applications The features outlined above can be implemented in any software applications or devices that process media objects. For example, a media object database management system may implement similar functionality. Digital asset management and digital rights management systems may use watermark enabled links to track and control the use of media objects.
Other applications that encounter media objects, like Word processing, spreadsheet, presentation programs, media object editing tools, etc. can all use some version of the features outlined above to link media objects with additional information and actions.
Many application programs have file browser capabilities that can be enhanced using the technology described in this document. For example, the File Open command is often used to browse file objects. The context menu and properties page extensions described above can be implemented for applications that provide file browsing services.
Watermark encoding and decoding functions can also be integrated into file sharing systems, such as the peer to peer file sharing systems like Napster, Gnutella, Freenet, Scour, etc. In a file sharing system, file sharing software executes on a number of client computers interconnected on a computer network. This software tracks the files available for sharing in the computer in which it executes, as well as other computers interconnected via the network. File sharing software may use watermarks or other forms of embedded data in files to control file transfers (uploading and downloading files on the computer), verify that a file is complete and free of viruses, carry metadata that may be used to search for files in the file sharing system, carry links to additional information and opportunities to obtain usage rights or to buy intellectual property rights in the file, or related products or services. To access this functionality, the file sharing software includes watermark or other embedded data decoding software. To insert or alter this functionality, the file sharing software includes watermark or other embedded data encoding software. For more information on this application, see US Patent Application No. 09/620,019, filed July 20, 2000, and entitled Using Embedded Data with File Sharing which is incorporated by reference above.
Context Sensitive Watermark Links The actions or information linked to a media object via a watermark may be context sensitive.
Some examples of "context" include application context (e.g., referring to the application program that is operating on the object), the object location context (where the object resides relative to the user). For example, the behavior of the link may be different when the user is manipulating the object in an editing tool as opposed to inserting the object in a document, such as a word processing document, a spreadsheet, or presentation. Also, the behavior of the watermark link may change based on whether the object is local, in an intranet, or on the Internet, relative to the user.
The decoder application may link to different metadata or processing actions depending on the context of the media object. To implement this functionality, the watermark decoder provides context information to the metadata database, which in turn, provides context specific metadata or initiates context specific actions. For instance, if the object is being edited with an editing tool, the decoder provides information about the editing tool to the database in addition to the link extracted from the watermark. Similarly, the decoder may provide context information indicating where the object resides relative to the user's computer. Using the context information as a key, the metadata database returns metadata or initiates processing actions that are associated with the context. Another way to implement the context sensitive behavior is to allow the decoder to control the presentation of watermark-linked actions or information based on the context of the media object. In the case where the context is defined by the application, this approach is akin to giving the application access to all of the linked metadata or actions, and then letting the application control presentation of the linked actions or information to the user. In such a scenario, the metadata database returns at least a descriptor of linked information and actions, and the application chooses which sub-set of the information or actions to apply based on the context. In the case where the context is defined by the location of the object, the decoder operates in a similar fashion. For example, it may choose a sub-set of the linked actions of information based on the location of the object.
A specific example of context information is user information supplied by the user's computer to a web server over the Internet using "cookie" technology. First, the user's computer decodes a watermark from a media object, such as an image, audio, or video signal. It then sends information extracted from the watermark along with a cookie including user information to a metadata server or router (generally referred to as a server). The server operates on user information from a cookie along with information extracted from a watermark in a media object to look up information or actions that are personalized to the user. The metadata server, for example, parses the cookie and uses it to reference information or addresses to network resources (URLs of web pages) in a database that relate to information in the cookie. The server further narrows the pertinent information or links by using the watermark information to look up a subset of information or links that are pertinent to the watermarked object. Then either the server, or another network resource referenced by the database operations returns associated information back to the users computer for rendering on the display or audio output device. This approach can be used to limit the information returned to specific news, advertising, content, etc. that is likely to be of interest to the user. A similar effect can be achieved by programming the user's computer to supply user preferences that are used in a similar manner as the cookie information.
Supporting Multiple Watermark Types
As watermark technology proliferates, media objects may have different types of watermarks, each associated with a set of watermark encoders and decoders. To accommodate different watermark types, the decoder can be designed to support different watermark protocols. The watermark protocols provide keys and other parameters specifying how to decode a watermark of a given type. Alternatively, a common Application Programming Interface (API) can be specified for different core watermark encoder and decoder software modules or devices. These schemes facilitate the development of many different types of applications and devices that invoke watermark encoder and decoder functions, yet are independent of the watermark protocol and/or core watermark methods.
To support different core watermark methods, the user may install two or more different core watermark encoder/decoder modules. For example, the core modules may be implemented as plug-ins or dynamic link libraries. When installing a module, the installation process updates a registry, such as the registry in the Windows Operating System, to reflect that a watermark type is supported. In this manner, watermark decoders for different media types, and different types of decoders for a single media type may be supported.
In cases where a media object contains a watermark of unknown type, the media object file may specify the watermark type, e.g., through a parameter in a file header. The file browser, or other client of the core watermark module, may invoke the appropriate decoder by extracting the type parameter from the media object and passing it and a reference to the media object to the core module via the API. The API routes the request to the appropriate core module, which in turn, extracts the watermark message, and returns it to the API. The API passes the message to the requesting application.
In the event that a type parameter is not available, the application or device processing the object may enumerate through all supported watermarking protocols to check if any protocol is present. The watermark protocols for given media or file type may be registered in the device or application (e.g., in a registry of the operating system). To check for each one, the application invokes a watermark screening process for these protocols to determine whether a watermark associated with the protocols is present.
Media Object Branding
The watermark can be used to establish "branding" in addition to facilitating electronic access to other services. In such a branding application, a watermark decoder enabled application or device in a client reads the embedded watermark message from the object and use it to access a digital logo, such as a thumbnail image (e.g., a brand "brand image"). The decoder-enabled application sends an object identifier taken from the watermark message to a server (such as a metadata server on the Internet), which, in response, returns the logo. The application then renders the logo, preferably superimposed on a rendered version of the media object or a graphical representation of it in the user interface of a client computer or device.
In some scenarios, the server also returns an address (e.g., URL) pointing to either a generic "usage rights" server or a custom "usage rights" maintained by the media owner. In an Internet context, the server may return one or more links to related Web sites. Connection rights and corporate branding services may be provided via a central server on the Internet. Using the object identifier to link to actions and metadata, watermark enabled applications have many options to extend the branding and usage rights services. An application could display "updatable" usage rights associated with the object identifier. In visual media objects, the application may display the branding logo visually superimposed over a portion of the rendered object (e.g., in a corner of a video frame, periodically for a predetermined period of time) or displayed as a splash screen initiation before playback of the media object begins. To make the branding information less obtrusive, it may be accessible upon request through a menu (e.g., when the user clicks on a representation of the object or "help" menu).
The branding service transforms the notion of copyright notification into a substantial ever- present branding opportunity with additional functionality, such as a hot link to the home page of the content owner or to a licensing server. The branding service may be combined with other watermark enabled functionality, such as a copy management instruction in the watermark payload, e.g., a control parameter indicating whether the object may be played, copied (number of copies allowed), recorded, transferred into other device or system, etc. In addition to providing this instruction to control usage, the watermark payload provides additional value to the consumer (e.g., linking to additional information and services associated with a media object) and ensures that the media object is well labeled and branded during playback.
More elaborate hot branding links, usage rights services, and context-sensitive linking may be added by associating the watermark link with software programs, metadata, and pointers to programs and metadata that support these features. These features may be added in the metadata server by adding them to the list of actions and/or metadata to be executed or returned in response to receiving the media object identifier. In addition, the decoder enabled application may be programmed to send the media object identifier to two or more servers that provide different sets of services or metadata for the object identifier.
Aggregating Metadata
In some applications, a media object may be associated with metadata from two or more different sources. The metadata may be stored in a file that stores the media object. For instance, file formats like JPEG2000, TIFF, JPEG, PSD may allow metadata to be stored along with the media signal (e.g., an image). Metadata and instructions associated with a media object may be stored in the same device as the media object, or in a remote device (e.g., a remote database). In these types of applications, decoders may be programmed to extract metadata from each of the different sources. The media type of file type may signal to the decoder to extract metadata from these different sources. Alternatively, the watermark message or file metadata may enumerate the different sources of the metadata.
In these applications, the decoder may be designed to get metadata from one or more sources and then present an aggregate of all information. The decoder may perform an aggregation function automatically or prompt the user to select desired sources of metadata for display.
Additional Functionality
A number of features can be implemented that take advantage of the watermark message payload and watermark links to other data and actions. Several examples are highlighted below: Metadata
Metadata can be expressed in many forms and provide additional functionality. In general, metadata is information about the media object. It may also include machine instructions to be executed, or a reference to information or instructions (object, user, program, or machine identifiers, URLs, pointers, addresses, indices or keys to a database, etc.). The machine instructions may, for example, control rendering, decoding, decrypting or other processing of the object. Alternatively, the instructions may provide some ancillary functionality. One important application of metadata is to provide ownership information. Another is to provide licensing terms and usage rights.
The metadata can be used to describe attributes of the media object that the user or other applications may use. For example, one attribute may designate the content as restricted, which prevents an application from rendering the content for unauthorized users. Another attribute may designate the object as commercial, which requires an application to seek payment or a license before the object is rendered. Multiple Watermarks
The media object may contain two or more watermarks or watermark messages, each associated with a distinct set of information or actions. For example, the media object may contain a creator ID, a distributor ID, etc. that link to information about the creator and distributor, respectively.
There are a number of ways to add watermarks to a media object, either at object creation time, or later as the object is transferred, copied, or edited. One way is to interleave separate watermarks in different portions of the media object. This can be accomplished by modifying independent attributes of the media object. Independent, in this context, means that each watermark does not interfere with the detection of the other watermarks. While two independent watermarks may alter the same discrete sample of a media object, they do so in a manner that does not cause an invalid read of any of the watermarks. Independent watermarks may be located in different spatial or temporal locations of the host media signal (e.g., image, video, audio, graphical model, etc.). The may also be located at different frequency bands or coefficients. Also, they may be made independent by modulating independent features of the signal, such as phase, energy, power, etc. of different portions of the signal. To illustrate the concept, consider an example of a still image object. Each independent watermark may be defined through a different protocol, which is used to encode a different watermark message (e.g., different watermark links for a creator, distributor, user, etc. of the media object). Independent spatial watermarks may be interleaved by mapping each of the watermarks to a unique set of spatial locations in the image. In a similar fashion independent watermarks may be encoded in a temporal data sequence, like audio or video, by mapping each watermark to unique temporal locations.
Digital Rights Management
The watermark may be linked to information and processing actions that control use of the media object. For example, the metadata may indicate the owner of the intellectual property rights in the object as well as licensing terms and conditions. Further, the watermark link or metadata trigger processing actions that control use of the object, such as requiring the user to submit payment, and exchanging decoding keys (e.g., decryption, decompression, etc.). While some amount of decoding of the object may be required to extract the watermark, the remainder of the content may remain encoded and/or encrypted until the user obtains appropriate usage rights.
The digital rights management functionality can be implemented in a licensing or usage rights server, such as the metadata server. This server determines the owner and licensing terms based on the watermark message and executes actions required to authorize use of the object, e.g., electronically receiving payment information from the user, establishing and recording a user's assent to the license, forwarding transaction details to the owner, and returning a usage key to the user. As the user plays or renders the media object, the watermark decoder can send a message to the server to log information about the usage, such as instances of use, machine ID of the player, time of use, etc.
Watermark and Context Information for Usage Control Watermark decoders can also use context information along with information extracted from a watermark embedded in a media object to control use of that object. For example, the watermark decoder may be programmed to control the rendering, editing, copying or transfer of a media object depending on control data in the watermark and context information derived from the device or system in which the object resides. For example, the watermark may instruct the decoder to inhibit rendering of a media object if its outside of a given file (e.g., a specified web page, computer system, computer network, etc. ). After decoding the watermark including such control data, the decoder determines the pertinent context information that must be present to enable a particular operation. This may encompass such actions as verifying the presence of a user identifier, computer identifier, file identifier, storage media identifier, computer identifier, network identifier, etc. before enabling the operation. These identifiers are stored in association with the entities that they identify, or are dynamically derived from these entities. For example, a file identifier can be stored in a file header or footer, or derived from content in the file. A storage device identifier can be stored on the storage device, or derived from content on the storage device or some attribute of it.
This context sensitive control of media objects is particularly useful in controlling the use of media files like music and movies, but applies to other types of media signals in which watermarks can be encoded. For instance, such context sensitive control can be used to prohibit rendering, copying or transfer of a media object when it is removed from the context of a web page, a computer, a storage device (e.g.., a CD or DVD), file sharing network, computers of paid subscribers of a subscription service, a collection of related media objects, etc.
Asset Management
The watermark embedded in a media object may play a role in asset management. Every time the object is processed (opened, edited, copied, etc.) an application equipped with a decoder can log information about the processing event. Alternatively, it can send a transaction event to a monitoring server via the Internet. The transaction event may specify information about the object, such as its ID, the user's ID, the time and location of use, the nature of the use (number of playbacks). The monitoring server or application records this transaction event in a database and, upon request, generates reports about the use of a given object, or by a given entity. Any of the fields of the transaction record can be used to query the database and generate custom reports.
Integration with Directory Services
Directory services like the Lightweight Directory Access Protocol (LDAP) can use the watermark or operate in conjunction with the watermark decoder to provide additional functionality.
LDAP is an on-the-wire protocol used to perform directory operations such as read, search, add, and remove.
For example, an LDAP service can be used to determine when to extract the watermark link and update attributes of a media object. For example, the LDAP service may control periodic updates of the media object's attributes by invoking a watermark decoder and retrieving an update of its attributes from a metadata server at predetermined times. An LDAP search filter that includes or accesses a watermark decoder can also be provided to find watermarked media signals in files stored in file directories on computers.
Media Object Player and Delivery Integration
A watermark decoder may be integrated with software and devices for playing or editing media objects. There are a variety of commercially available players from Liquid Audio, Microsoft, and RealNetworks, to name a few. Such integration allows metadata and actions linked to the media object to be accessible to the user in a seamless fashion through the user interface of the player. For example, when a user is playing a video or audio file, a watermark enabled player may access and display linked metadata or actions automatically or at the user's selection. In either case, the user need not be aware that metadata or actions are obtained from a remote server via an object identifier. Also, such integration enables a content owner to link an object to licensing or assert usage control information or actions at playback time, whenever and wherever the object is played. Such information and actions can be implemented by placing data or instructions in a watermark within the object, or putting an object identifier in the watermark that links to metadata or actions outside the object as detailed throughout this document. In many cases, it is desirable to access the functionality provided via the watermark transparently to the user. As such, the media player can be enhanced to display items linked via the watermark in a manner that appears to be a natural extension of the user interface. When the user or other program invokes the media player to play an object, it displays metadata or actions provided within or linked via the watermark in an extension of the media player's user interface. These metadata or actions may be retrieved when the media player is launched or at some other time (e.g., as a background task, in response to user request, when the object is loaded to the computer or device where the media player resides, etc.). In one scenario, the media player invokes a watermark decoder on an object in response to a user's request to play the object. In this scenario, the media player passes the address of the object to the watermark decoder, which in turn, attempts to decode a watermark embedded in it. Upon locating a watermark, the decoder forwards an object identifier extracted from it to a metadata server, which returns metadata or actions associated with the object identifier. During metadata retrieval, the media player proceeds to play the media object. When the linked metadata arrives, the extension to the media player displays returned metadata or actions.
Fig. 5 illustrates an example of an enhanced version of Microsoft's Windows Media player showing metadata and actions. In this example, the user interface window of the player is expanded in a bottom section 502 to show metadata and links associated with a media object. When the user positions the cursor over the items, "Clip," "Author," or "Copyright, the bottom tab 504 displays a URL associated with that item. By clicking on one of the items, the player invokes an Internet Browser, which sends a query to the resource at the selected URL (e.g., request an HTTP request to download an HTML document).
The watermark decoder may be invoked by another application, which launches the media player. Consider a case where a user is browsing audio or video files, either with a file browser or Internet browser. After finding a desired media object for playback, the user selects the object for playback. For example, the user could select a "Play" option via a context menu of the Windows Explorer, or via an insert in an HTML document as explained above. In the first case, a shell extension invokes the watermark decoder to get the associated metadata and executes a program (e.g., COM object, script, etc.) that runs the media player and displays the additional metadata linked via a watermark. In the second case, a Java script or other insert in the HTML document invokes the decoder and starts a program that runs the media player in a similar fashion.
One way to implement a program to control the Windows Media player is through the use of an Advanced Streaming Redirector (ASX) file. The file contains a script that launches the player and displays the metadata (e.g., URL links and information about the object) linked via the watermark. For information about ASX files and the use of these files to control Windows Media Player, see Microsoft's Developer's Network.
Content Authoring Tools Media content authoring tools, including web page design tools, may include watermark embedding functionality to embed watermarks into content, such as web page content. This embedded data then signals watermark decoder enabled devices and software to perform functions associated with the embedded watermark data.
Such tools may also include watermark decoding functionality to enable content developers to use the watermark decoding feature to screen media object for watermarks within the content authoring environment. If the watermark within a media object being edited conveys information (e.g., copyright owner information, licensing terms, etc.), then the authoring tool can convey this information to the user. If the watermark includes usage control information, then the authoring tool can control the use of the media object based on that information. For example, the watermark in a media object may convey an instruction that inhibits the authoring tool from editing the media object, unless the user obtains authorization from a licensing server.
Web Server Integration and Related Applications
Watermark encoding and decoding functions may also be integrated into network server application software to support functionality described in this document as well additional functionality. In particular, watermark encoding and decoding can be integrated into web servers.
Watermark encoders can be integrated into web servers to embed watermarks in media content transferred to, from or through the server. One reason for embedding watermarks at the server is to encode transaction specific information into a media object at the time of its transfer to, from or through the server. The transaction specific information relates to an electronic transaction between the server and some other computer. For example, before downloading or uploading a media object file, the server may embed information about the recipient/sender of the file into the media signal in the file (e.g., image, audio or video file). Since the watermark remains in the signal, information about the sender/recipient in the watermark remains with the media signal in the file through digital to analog — analog to digital conversion, file format changes, etc.
The server may embed a link to information or actions (links to related web sites) in the file that is uniquely tailored to the sender's/recipient's preferences. The preferences may be obtained from the user's computer, such as through popular "cookie" technology commonly used in Internet browsers, or may reside in some other database that associates a user (a user identifier or an identifier of the user's computer) with the user's preferences (e.g., types of content preferences like news, financial information, sports, e-commerce opportunities, etc.). In this case, the server obtains the user identifier and then queries the database for the associated preferences. The server may also use the preferences obtained in this manner to control what forms of advertising is returned or linked with the file. For example, the user may request the server to download a desired audio, video, or image file. In response, the server gets the user's preferences and downloads the requested file along with advertising information and web site links that match the user's preferences. The advertising information and links can be referenced by embedding a watermark that includes an address of the information, or that includes an index to a database entry that stores the information and or links to other information, web sites, etc. The user's computer receiving the file downloaded from the server then renders the file and other related advertising information (e.g., provided in HTML, XML or some other conventional data format) from the server or some other server linked to the file via a watermark in the file. The server may also embed usage control information into a watermark in a media file based on usage control rights requested by and paid for by the user in an electronic transaction between the server and the user's computer. These usage control rights can then be decoded by other applications and used to control rendering of the file, copying, recording, transfer, etc.
Network servers may also include watermark decoding functionality, such as software for decoding watermarks from media signals in files that are transferred to, from, or through the server. This enables the server to perform the many watermark-enabled functions described or incorporated into this document as well as to provide enhanced functionality. For example, the watermark may include usage control data that the server extracts and acts upon. Examples of usage control data include content rating information (adult content indicators), copy or transfer control information, rendering control information, compression/decompression control information, encryption decryption control information, links to external information or actions, etc.
After extracting this data from the watermark, the server can modify the file based on the extracted data. For example, the server may compress or encrypt the file in a manner specified in the watermark before transferring the file. The user at the computer receiving the file would then need to have a compatible decompression or decryption program or device to render the media object in the file. In addition to, or as an alternative to modifying the file based on the extracted watermark data, the server can send related information or instructions to the receiving computer that controls of facilitates usage of the file. For example, if the server determined from the watermark that the content was marked as "adult content", then it could send additional information with the file (e.g., HTTP header information along with a web page including watermarked content) to instruct rendering software, such as the browser, how to render the watermarked content.. The rendering software on the receiving computer can then decide how to render the content. For example, if a child is logged onto the computer receiving the file, then the rendering software can opt not to render content in the file marked as "adult content." As another example, the server may decode a watermark that instructs it to send decryption or decompression keys to the rendering software to enable the receiving computer to decrypt or decompress the content. Public key encryption schemes can be used to perform key exchanges between the sending and receiving computers. As another example, the server may decode a watermark that instructs it to send additional data along with the watermarked file including links to web sites based on information that the server decoded from the watermark.
Content Filtering and Counting
Watermark decoders can be used in computers and computer networks to filter watermarked media objects and to count instances of watermarked media objects. Filtering refers to the use of the watermark decoder to decode watermarks from objects that reside in a particular location and control their use, transfer or rendering in response to control data in the watermark, and optionally, in response to additional context data outside the watermark. These media objects may be temporarily stored at the location of the filter, as in case of a device or computer responsible for transferring the media object. Examples of such systems are e-mail servers, firewalls, routers, or gateways in computer networks that use watermark decoding to control the transfer of certain media objects to other devices or computers based at least in part on watermarks found in the objects. The media objects may also be stored at the location of a filter on a more permanent basis. For example, the filter may be used to screen media objects that a user downloads to or uploads from a mass storage device such as a hard drive or remote personal library of music, image and movie files on a mass storage device accessible via the Internet.
The filter may be used to inhibit downloading or uploading from the mass storage device in response to a watermark in a file being transferred, or alternatively, may be used to control rendering of the file.
Object counting refers to a way of logging the number of times a watermark media object is encountered, either by filtering media objects that pass through a particular device or system like a firewall or e-mail gateway, or by actively searching a network of systems like the Internet and screening for watermarked media objects found and downloaded as a result of the search. The logs maintained by watermark decoding systems can be adapted to include additional information about the object, including information from the watermark, such as an owner, user or transaction identifier, tracer data, and information about the object, such as where it was found, how it was being used, who was using it, etc. Tracer data includes data that is embedded in the file in response to some event, such as detecting unauthorized use, copying or transfer of the file.
The watermark decoder may be further augmented to send the log electronically to another device or computer in response to a specific request or in response to events. For example, the decoder can be programmed to send a report to a central database on another computer when the number of watermarked objects encountered has exceeded a threshold, and/or when certain information is found in a watermark, such as a particular identifier or tracer data that was embedded in the media object in response to detecting an unauthorized use or copying of it. Programmatic rules can be established within the decoder to specify the conditions under which watermarked media objects are filtered and counted, to specify which information is logged, and to specify when the logged information is transmitted to another computer.
The watermark based filtering and counting functions can be implemented in a variety of software applications and devices. Some examples include a network firewall, and other client, server, or peer-to-peer software applications that encounter media objects (such as operating systems, media players, e-mail readers and servers, Internet browsers, file sharing software, file manager software, etc.). One particular use of watermark based filtering, screening and counting is to monitor watermarked content sent in or as an attachment to e-mails sent between computers.
Watermark Based Spiders
Prior patent documents by the assignee of this patent application describe systems and methods of automated searching and watermark screening of media object files on computer networks like the Internet. See U.S. Patent No. 5,862,260, which is hereby incorporated by reference. The software used to perform automated searching and compiling of Internet content or links is sometimes referred to as a web crawler or spider.
As extension of the watermark based information retrieval described in US Patent 5,862,260 and marketed by Digimarc Corporation, watermark decoders can be employed in a distributed fashion to perform watermark screening and counting of watermarked media objects on networks, including the Internet. In particular, watermark decoders can be deployed at a variety of locations on a computer network such as the Internet, including in Internet search engines that screen media objects gathered by each search engine, network firewalls that screen media objects that are encountered at the firewall, in local area networks and databases where spiders do not typically reach, in content filters, etc. Each of these distributed decoders acts as a spider thread that logs watermark information as described in this document and those incorporated by reference. Examples of the types of information include identifiers decoded from watermarks in watermarked media objects, media object counts, addresses of the location of the media objects (where they were found), and other context information (e.g., how the object was being used, who was using it, etc.). The spider threads, in turn, send their logs or reports to a central spider program that compiles them and aggregates the information into fields of a searchable database.
Event Scheduling Based on Embedded Data
Watermark decoding may be used in conjunction with an event scheduler to schedule programmatic events that occur in response to decoding a watermark message of a given type. Throughout this document, there are many instances of triggering actions in response to decoding information, instructions, or links from a watermark message. In some cases, these actions are programmatic actions made by software in response to the watermark, while in other cases, these actions are device actions made by hardware circuitry, such as in the case of usage control of media signals in hardware implementations of audio and video players, recorders, etc. Rather than taking an action immediately upon decoding a watermark message, an event scheduler can be used to schedule programmatic or device actions to occur at a later event, either at a specified time according to a clock or timer, or in response to a subsequent input, action, etc.
One example of this is to schedule a link to a web site to be activated at later, and perhaps periodic events. For example, a watermark decoder implemented in a browser, operating system, media player or other software application decodes a watermark from a media object that links the object to one or more web sites. In response to decoding the watermark, the decoder schedules programmatic actions to occur at later times. Some examples of these actions include: displaying a window with a link to a specified web site at periodic intervals or in response to a programmatic action like the launching of a browser, media player or other application. This approach can be used to prompt the user to buy a product, such as the media object (a music or video track) or some product depicted in the media object. Using this approach, many actions can be scheduled to occur in response to a single decoding of the watermark.
Integrating a Watermark Encoder in Operating Systems and Other Applications
In some applications, it will be useful to encode a watermark or overlay one or more additional watermarks to perform any of the functions mentioned above (e.g., to track uses, refresh usage rights, add links to additional information and actions, etc.). Watermark encoding functionality could be added to an operating system, Internet browser, or other applications. For instance, through a drag and drop procedure, a user could embed a watermark in a media object as a means of enabling the various functions outlined above.
As another example, a watermark encoder may be integrated in a file browser, Internet browser, media player, or other application using the same integration techniques outlined above for the decoder. An example earlier discussed, for example, described watermark encoder functionality integrated into the Windows Explorer file browser via a shell extension. In particular, the watermark encoder is implemented as a shell extension handler. This handler is registered as a context menu extension in the registry of the Windows Operating system. As an alternative, it could be implemented as a properties page extension handler.
To access the watermark encoder in this example, the user right clicks on a media object, and selects the context menu option called "Embed Information." In response, the handler displays a window. This window enables the user to enter various Ids (e.g., a creator ID, image ID), which are encoded into an image via a watermark. The user may also set or select attributes of the image object. Finally, the user can control the embedding process by adjusting the durability of the watermark through a scroll bar control. The user can compare the original and watermarked versions of the object by selecting the "Original" and "Watermarked" tabs. When satisfied, the user can save the watermarked image and exit the window (e.g., by selecting close). Metadata and actions may be associated with the image object by forwarding them to the metadata server, which associates them with an object ID.
While the example just discussed involves a still image object, a similar approach maybe used to embed watermarks in other media objects, such as video and audio objects. To compare marked and unmarked audio or video objects, the shell extension may be designed to launch a media player to play the marked and unmarked objects as desired.
Operating Environment for Computer Implementations
An operating environment for software implementations of the watermarking systems described above can be a conventional computer system. The embedder and detector implementations can be implemented in C/C++ and are portable to many different computer systems.
An illustrative computer system includes a computer, including a processing unit, a system memory, and a system bus that interconnects various system components including the system memory to the processing unit.
The system bus may comprise any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using a bus architecture such as PCI, VESA,
MicroChannel (MCA), ISA and EISA, to name a few. The system memory includes read only memory (ROM) and random access memory (RAM). A basic input/output system (BIOS), containing the basic routines that help to transfer information between elements within the computer, such as during start-up, is stored in ROM.
The computer further includes a hard disk drive, a magnetic disk drive, e.g., to read from or write to a removable disk, and an optical disk drive, e.g., for reading a CD-ROM or DVD disk or to read from or write to other optical media. The hard disk drive, magnetic disk drive, and optical disk drive are connected to the system bus by a hard disk drive interface, a magnetic disk drive interface, and an optical drive interface, respectively. The drives and their associated computer-readable media provide nonvolatile storage of data, data structures, computer-executable instructions (program code such as dynamic link libraries, and executable files), etc. for the computer. Although the description of computer-readable media above refers to a hard disk, a removable magnetic disk and an optical disk, it can also include other types of media that are readable by a computer, such as magnetic cassettes, flash memory cards, digital video disks, and the like.
A number of program modules may be stored in the drives and RAM, including an operating system, one or more application programs, other program modules, and program data. A user may enter commands and information into the personal computer through a keyboard and pointing device, such as a mouse. Other input devices may include a microphone, sound card, radio or television tuner, joystick, game pad, satellite dish, digital camera, scanner, or die like. A digital camera or scanner 43 may be used to capture the target image for the detection process described above.
The camera and scanner are each connected to the computer via a standard interface 44. Currently, there are digital cameras designed to interface with a Universal Serial Bus (USB), Peripheral Component
Interconnect (PCI), and parallel port interface. Two emerging standard peripheral interfaces for cameras include USB2 and 1394 (also known as firewire and iLink).
In addition to a camera or scanner, watermarked images or video may be provided from other sources, such as a packaged media devices (e.g., CD, DVD, flash memory, etc), sfreaming media from a network connection, television tuner, etc. Similarly, watermarked audio may be provided from packaged devices, streaming media, radio tuner, sound cards, etc.
These and other input devices are often connected to the processing unit through a port interface that is coupled to the system bus, either directly or indirectly. Examples of such interfaces include a serial port, parallel port, game port or universal serial bus (USB).
A monitor or other type of display device is also connected to the system bus via an interface, such as a video adapter. In addition to the monitor, personal computers typically include other peripheral output devices (not shown), such as speakers and printers. The computer operates in a networked environment using logical connections to one or more remote computers, such as a remote computer. The remote computer may be a server, a router, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 1220, although only a memory storage device has been described. The logical connections include a local area network (LAN) and a wide area network (WAN). Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets and the Internet. When used in a LAN networking environment, the computer is connected to the local network through a network interface or adapter. When used in a WAN networking environment, the personal computer typically includes a modem or other means for establishing communications over the wide area network, such as the Internet. The modem, which may be internal or external, is connected to the system bus via the serial port interface.
In a networked environment, program modules depicted relative to the personal computer, or portions of them, may be stored in the remote memory storage device. The processes detailed above can be implemented in a distributed fashion, and as parallel processes. It will be appreciated that the network connections shown are exemplary and that other means of establishing a communications link between the computers may be used.
Extensions to Other Forms of Media Object Linking
The approaches described above can be implemented for a variety of media object files, including image, graphics, video and audio files, or files containing two more different media types. Also, media objects may be linked to their metadata via data structures other than a watermark embedded in the object. For example, the object identifier need not be inserted in a watermark, but instead may be placed somewhere else in the media object file, such as a file header. Such an identifier may be inserted into the header of coded or compressed files. To extract the identifier, a decoder parses the header and extracts the object identifier. Then, the decoder forwards the identifier to a metadata server, either directly, or by launching another application, such as web browser, to issue the metadata request and output the data and/or interpret code returned from the metadata server.

Claims

E CLAIM:
1. A method of operating a portable device that includes a sensor to capture image or audio data, comprising: transferring the captured data to a remote device; decoding a watermark at the remote device; and returning corresponding data to the portable device.
2. The method of claim 1 in which the corresponding data is decoded watermark data.
3. The method of claim 1 which further includes indexing a database with reference to at least a portion of the decoded watermark to obtain a computer address corresponding thereto, and returning the computer address to the portable device.
4. The method of claim 1 which further includes indexing a database with reference to at least a portion of the decoded watermark to obtain a computer address corresponding thereto, and receiving content data from said computer address at a destination device.
5. The method of claim 4 in which the destination device is co-located with the portable device.
6. The method of claim 5 in which the destination device comprises the portable device.
7. The method of claim 4 in which the destination device is remote from the portable device.
8. The method of claim 1 in which the transferring step occurs autonomously, without user intervention.
9. The method of claim 1 in which a user initiates the transferring step by performing an action.
10. The method of claim 9 in which the user initiates the transferring step by operating a button.
11. The method of claim 1 in which the corresponding data is audio or image data like that captured by the portable device sensor, but of higher fidelity.
12. The method of claim 1 in which the corresponding data is audio or image data that is not simply a higher fidelity version of the audio or image data captured by the portable device sensor.
13. An MP3 player for performing the method of claim 1.
14. A cell phone for performing the method of claim 1.
15. A cell phone equipped with an image sensor for performing the method of claim 1.
16. A wristwatch with an audio or image sensor for performing the method of claim 1.
17. A method of operating a portable device that includes a sensor to capture image or. audio data, comprising: decoding watermark data from the image or audio data, the watermark serving to identify corresponding content stored in a repository; and transferring at least a portion of the watermark data to a remote device, and sending instruction data with said watermark data, said instruction data serving to specify an action to be taken with the content stored in the repository.
18. The method of claim 17 in which the action is transmission of the content from the repository to the portable device.
19. The method of claim 17 in which the action is transmission of the content from the repository to a destination remote from the portable device.
20. The method of claim 17 in which the instruction data depends, at least in part, on the bandwidth of a network connection available to link the portable device to another device.
21. The method of claim 17 in which said content is audio or image data like that captured by the portable device sensor, but of higher fidelity.
22. The method of claim 17 in which said content is audio or image data that is not simply a higher fidelity version of the audio or image data captured by the portable device sensor.
PCT/US2001/030238 2000-09-26 2001-09-26 Portable devices and methods employing digital watermarking WO2002027431A2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU9634301A AU9634301A (en) 2000-09-26 2001-09-26 Portable devices and methods employing digital watermarking

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US67011500A 2000-09-26 2000-09-26
US09/670,115 2000-09-26

Publications (2)

Publication Number Publication Date
WO2002027431A2 true WO2002027431A2 (en) 2002-04-04
WO2002027431A3 WO2002027431A3 (en) 2002-07-04

Family

ID=24689056

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2001/030238 WO2002027431A2 (en) 2000-09-26 2001-09-26 Portable devices and methods employing digital watermarking

Country Status (2)

Country Link
AU (1) AU9634301A (en)
WO (1) WO2002027431A2 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2302599A1 (en) * 2009-09-21 2011-03-30 Aquamobile, S.L. Digital watermarks recognition method using mobile phones
US8126200B2 (en) 1999-05-19 2012-02-28 Digimarc Corporation Methods and systems employing digital content
WO2016126176A1 (en) * 2015-02-05 2016-08-11 Telefonaktiebolaget Lm Ericsson (Publ) Video distribution control
EP3332505A4 (en) * 2015-08-03 2018-12-12 TRUEPIC Inc. Systems and methods for authenticating photographic image data
US10360668B1 (en) 2018-08-13 2019-07-23 Truepic Inc. Methods for requesting and authenticating photographic image data
US10361866B1 (en) 2018-08-13 2019-07-23 Truepic Inc. Proof of image authentication on a blockchain
US10375050B2 (en) 2017-10-10 2019-08-06 Truepic Inc. Methods for authenticating photographic image data
US11037284B1 (en) 2020-01-14 2021-06-15 Truepic Inc. Systems and methods for detecting image recapture

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1997043736A1 (en) * 1996-05-16 1997-11-20 Digimarc Corporation Computer system linked by using information in data objects
US5806005A (en) * 1996-05-10 1998-09-08 Ricoh Company, Ltd. Wireless image transfer from a digital still video camera to a networked computer
US6035035A (en) * 1996-12-19 2000-03-07 Classicom, Llc Wrist mounted telephone device
US6122526A (en) * 1997-04-24 2000-09-19 Eastman Kodak Company Cellular telephone and electronic camera system with programmable transmission capability
US6243480B1 (en) * 1998-04-30 2001-06-05 Jian Zhao Digital authentication with analog documents

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5806005A (en) * 1996-05-10 1998-09-08 Ricoh Company, Ltd. Wireless image transfer from a digital still video camera to a networked computer
WO1997043736A1 (en) * 1996-05-16 1997-11-20 Digimarc Corporation Computer system linked by using information in data objects
US6035035A (en) * 1996-12-19 2000-03-07 Classicom, Llc Wrist mounted telephone device
US6122526A (en) * 1997-04-24 2000-09-19 Eastman Kodak Company Cellular telephone and electronic camera system with programmable transmission capability
US6243480B1 (en) * 1998-04-30 2001-06-05 Jian Zhao Digital authentication with analog documents

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
RESEARCH DISCLOSURE vol. 418, no. 015, 28 February 1999, ERICSSON INC., XP002908398 *

Cited By (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8126200B2 (en) 1999-05-19 2012-02-28 Digimarc Corporation Methods and systems employing digital content
EP2302599A1 (en) * 2009-09-21 2011-03-30 Aquamobile, S.L. Digital watermarks recognition method using mobile phones
WO2016126176A1 (en) * 2015-02-05 2016-08-11 Telefonaktiebolaget Lm Ericsson (Publ) Video distribution control
US10142693B2 (en) 2015-02-05 2018-11-27 Telefonaktiebolaget Lm Ericsson (Publ) Video distribution control
US11334687B2 (en) 2015-08-03 2022-05-17 Truepic Inc. Systems and methods for authenticating photographic image data
EP3332505A4 (en) * 2015-08-03 2018-12-12 TRUEPIC Inc. Systems and methods for authenticating photographic image data
US11734456B2 (en) 2015-08-03 2023-08-22 Truepic Inc. Systems and methods for authenticating photographic image data
US10733315B2 (en) 2015-08-03 2020-08-04 Truepic Inc. Systems and methods for authenticating photographic image data
US11968199B2 (en) 2017-10-10 2024-04-23 Truepic Inc. Methods for authenticating photographic image data
US10375050B2 (en) 2017-10-10 2019-08-06 Truepic Inc. Methods for authenticating photographic image data
US11632363B2 (en) 2017-10-10 2023-04-18 Truepic Inc. Methods for authenticating photographic image data
US11159504B2 (en) 2017-10-10 2021-10-26 Truepic Inc. Methods for authenticating photographic image data
US10726533B2 (en) 2018-08-13 2020-07-28 Truepic Inc. Methods for requesting and authenticating photographic image data
US11403746B2 (en) 2018-08-13 2022-08-02 Truepic Inc. Methods for requesting and authenticating photographic image data
US11646902B2 (en) 2018-08-13 2023-05-09 Truepic Inc. Methods for requesting and authenticating photographic image data
US10360668B1 (en) 2018-08-13 2019-07-23 Truepic Inc. Methods for requesting and authenticating photographic image data
US10361866B1 (en) 2018-08-13 2019-07-23 Truepic Inc. Proof of image authentication on a blockchain
US11544835B2 (en) 2020-01-14 2023-01-03 Truepic Inc. Systems and methods for detecting image recapture
US11037284B1 (en) 2020-01-14 2021-06-15 Truepic Inc. Systems and methods for detecting image recapture

Also Published As

Publication number Publication date
AU9634301A (en) 2002-04-08
WO2002027431A3 (en) 2002-07-04

Similar Documents

Publication Publication Date Title
US10304152B2 (en) Decoding a watermark and processing in response thereto
US8645838B2 (en) Method for enhancing content using persistent content identification
US9740373B2 (en) Content sensitive connected content
KR100799090B1 (en) Watermark encoder and decoder enabled software and devices
US7095871B2 (en) Digital asset management and linking media signals with related data using watermarks
US7372976B2 (en) Content indexing and searching using content identifiers and associated metadata
US8099403B2 (en) Content identification and management in content distribution networks
EP1785890B1 (en) Using embedded data with file sharing
WO2002027431A2 (en) Portable devices and methods employing digital watermarking
JP2001154984A (en) Method and system for protecting copyright of digital image transmitted through network
CN1382279A (en) Network advertisement method and system
WO2008126050A2 (en) Embedding tv-anytime data in content

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

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

AL Designated countries for regional patents

Kind code of ref document: A2

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

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

Kind code of ref document: A3

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

AL Designated countries for regional patents

Kind code of ref document: A3

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

121 Ep: the epo has been informed by wipo that ep was designated in this application
REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase in:

Ref country code: JP