The subject matter described herein relates to methods, systems, and computer program products for automatically associating data with a resource as metadata. More particularly, the subject matter described herein relates to methods, systems, and computer program products for automatically associating data with a resource as metadata based on a characteristic of the resource.
In computer file systems, files are used to store data created by users, software applications, and devices. In addition to user-created content, a computer file may be associated with descriptive information regarding the contents or other aspects of the file. This descriptive information is referred to as metadata. In some instances, metadata is stored in the file. In other instances, metadata is stored outside of the file but is linked to the file.
Some application programs allow users to manually create and associate metadata with a file. For example, digital image organization programs sold with digital cameras may allow a user to manually enter captions to be stored and/or displayed with an image. While such manual metadata creation tools are useful, they require unnecessary time and labor on the part of the end user, because the end user is required to manually input the metadata for each resource.
Some current computer operating systems include limited functionality for automatically associating file system information with files. For example, the Windows® 98 and Windows® 2000 operating systems automatically associate a file's location in a file directory tree with the file in response to the file being stored in a particular directory. However, the Windows® 98 and Windows® 2000 operating systems do not allow a user to define his or her own metadata that is automatically associated with the file. In addition, the Windows® 98 and Windows® 2000 operating systems do not allow metadata to be selectively associated with a file based on a characteristic of the file. For example, it may be desirable to automatically associate different metadata with image files and documents stored in the same folder. Windows® 98 and Windows® 2000 would treat all files stored in the folder identically by associating the folder's location in the directory tree with a location tag in each file.
Newer operating systems include file systems that are more database-oriented than previous operating systems. For example, the Longhorn operating system expected to be released by Microsoft in 2006 includes an unstructured file system and a structured file system. The unstructured file system is the same NTFS file system included in Windows® 98 and Windows® 2000. The structured file system is a database-oriented file system in which file properties are stored and organized as structured database objects. When an application modifies unstructured properties of a file, structured database objects corresponding to the unstructured properties are updated. The process of updating the structured database objects is referred to as promotion. However, the promotion process only maps existing unstructured properties of the file to structured objects maintained by the structured file system. There is no ability in the promotion process to automatically associate data that is independent from a file with the structured objects or to selectively associate data with a file as metadata based on a file characteristic.
It may be desirable to allow users to define data and automatically associate, as metadata, the data with a resource, such as a file. In addition, it may be desirable to allow users to define rules that associate data with resources as metadata based on characteristics of the resources. Such capability would allow the user to organize files or other resources in an efficient manner. Because current file systems lack such capabilities, there exists a need for improved methods, systems, and computer program products for automatically associating data with a resource as metadata based on a characteristic of the resource.
According to one aspect, the subject matter described herein includes a method for automatically associating data with a resource as metadata. The method includes defining a metadata association rule for a metadata associator. The metadata association rule maps a data value to the resource as metadata based on a characteristic of the resource in response to the resource being associated with the metadata associator. When the resource is associated with the metadata associator, the data value may be associated with a resource based on the metadata association rule. The specified data value may be defined prior to the resource being associated with the metadata associator and independently from a file system for storing the resource. For example, the specified data value may be user-defined text that is descriptive of the contents of the resource.
The subject matter described herein can be implemented as a computer program product comprising computer executable instructions embodied in a computer readable medium. As used here, a “computer-readable medium” can include one or more of any suitable media for storing the executable instructions of a computer program in one or more of an electronic, magnetic, optical, and electromagnetic, such that the instruction execution machine, system, apparatus, or device can read (or fetch) the instructions from the computer readable medium and execute the instructions for carrying out the described methods. Exemplary computer readable media suitable for implementing the subject matter described herein include disk memory devices, chip memory devices, application specific integrated circuits, programmable logic devices, and downloadable electrical signals. In addition, a computer program product that implements the subject matter described herein may be located on a single device or computing platform. Alternatively, the subject matter described herein can be implemented on a computer program product that is distributed across multiple devices or computing platforms.
Preferred embodiments of the subject matter described herein will now be explained with reference to the accompanying drawings of which:
According to one aspect, a system for automatically associating data with a resource as metadata based on a characteristic of the resource may be implemented as software components designed to execute on a general-purpose computing platform.
A metadata associator may be any suitable data structure capable of associating one or more metadata association rules with one or more resources. In one example, a metadata associator may be a file folder. In an alternate example, a metadata associator may be a smart folder. In another example, a metadata associator may be a database. In still an alternative example, a metadata associator may be a graphical representation, such as an icon, for performing the functions of the herein disclosed invention.
The system illustrated in
The system illustrated in
In block 202, the user may define a metadata association rule for the metadata associator. The metadata association rule may specify a data value to be associated with a resource as metadata based on a characteristic of the resource. Defining a metadata association rule may be accomplished via a user interface provided by metadata association rules creation tool 100.
In the illustrated example, the resource characteristic being mapped to different metadata tags and values is file type. Each row in the table corresponds to a metadata association rule for a file type. Each rule includes an Information field that stores the data to be associated with the file type specified in the File Type field. Each rule also includes a Field field that stores the metadata tag with which the data in the Information field is to be associated. The metadata tags may be predefined, user-defined, or customizable.
Each rule in the table may further include an Additive/Replacing field that specifies whether the data to be associated with each file type is additive or replacing. A selection of “Additive” in the Additive/Replacing field means that the data in the Information field will be added to data currently stored in the tag specified in the Field field of the file. A selection of “Replacing” in the Additive/Replacing field means that the data in the Information field will replace any data currently associated with the tag specified in the Field field of the file.
Rules specification interface 300 may include Add and Remove buttons to allow a user to respectively add metadata association rules to the table and remove metadata association rules from the table. If the user selects the Add button, the user may be directed to a rules creation interface for creating a new metadata association rule. If the user selects the remove button and highlights one of the rules in the table, that rule may be removed from the table and thereby disassociated from the metadata associator for which it was created. Disassociating a rule from a metadata associator may trigger metadata association engine 108 to automatically disassociate metadata corresponding to the rule from the resources associated with the metadata associator when the rule is disassociated. Alternatively, disassociating a rule from a metadata associator may not trigger the disassociation of the corresponding metadata from resources associated with the metadata associator. Instead, resources associated with the metadata associator prior to removal of the rule will retain their metadata, and the rule will not be applied to resources associated with the associator after removal of the rule. Adding or associating a rule with a previously created metadata associator may trigger metadata association engine 108 to automatically associate, as metadata, data corresponding to the rule with the resources previously associated with the metadata associator. Alternatively, adding or associating a rule with a previously created metadata associator may not trigger metadata association engine 108 to automatically associate, as metadata, data corresponding to the rule with the resources previously associated with the metadata associator.
Although in the description above for
Returning to
In block 206, the data value is associated with the resource based on the metadata association rule. The action specified by block 206 may be implemented by metadata association engine 108 illustrated in
In block 502, the file characteristic defined for the rule or rules associated with the metadata associator is attempted to be identified. In block 504, it is determined whether the file and/or its characteristics are recognizable. The action specified by block 504 is optional and may be bypassed. If the file and/or its characteristics are recognizable, control proceeds to block 506 where it is determined whether the metadata associator representation has data values that map to the file's characteristics. Block 506 may include determining whether the characteristics specified by the rule or rules match the characteristics of the resource. If it is determined that the metadata associator representation has rules mapped to the file's characteristics, control proceeds to block 508 where it is determined whether the metadata already exists. If the metadata already exists, it may not be desirable to associate the resource with the metadata. The action specified by block 508 is optional and may be bypassed. In block 508, if it is determined that the metadata does not already exist, control proceeds to block 510 where data values from the metadata associator representation is associated with the resource as metadata.
Returning to block 504, if the file and/or its characteristics are unrecognizable, the metadata association process may end. Similarly, in block 506, if the metadata associator representation does not have a rule defined for the particular file's characteristics, the metadata association process ends. In block 508, if the metadata already exists, the metadata association process may end.
The subject matter described herein may be used to associate any type of data with a resource as metadata. Such data may include descriptive information regarding the contents of the resource, its creation, or any other data that the user desires to associate with the resource. Once the data is associated with the resource, the data may be classified as metadata, since it may be descriptive of data associated with the resource. The metadata may be intrinsic metadata, which describes the contents of the resource, or extrinsic metadata, which describes the implementation of a resource in an operating environment, such as a file system. For example, intrinsic metadata regarding a document file may include the title of the document. Extrinsic metadata regarding a document file may include the location of the document in a file system. Either or both types of metadata may be defined and associated with a metadata associator without departing from the scope of the subject matter described herein.
Metadata may be associated with the resource in any suitable manner. For example, the metadata may be stored within the resource or stored in a location that is separate from but associated with the resource. In one exemplary implementation, metadata may be stored in an instance of a database object linked to the resource. Metadata associated with a resource may be stored on the same computing platform or storage device as the resource or on a storage device or computing platform separate from the storage device or computing platform that stores the resource.
The subject matter described herein may be used to automatically associate, as metadata, data with metadata fields that are specified as part of a resource format specification, such as a file format specification. Alternatively, metadata associated with a resource may be extended using the resource description framework (RDF).
Metadata may be associated with smart folders. Smart folders are a new technology that automatically establishes a grouping of files or resources based on algorithms or rules. For example, a smart folder may be established for all files that use the word “elephant” in their text. The smart folder may automatically be populated with the relevant files by the file system. Any new file that is created or introduced to the file system and contains the word “elephant” will automatically become a member of the smart folder. The subject matter described herein may be used to automatically associate, as metadata, data with files that are associated with smart folders. For example, the subject matter described herein may associate the subject field of all resources that are associated with the elephant smart folder, and were created between two specified dates, with the word “elephant” or more descriptive user-specified text, such as, “trip to the zoo.”
Because the subject matter described herein allows metadata to be selectively associated with a resource based on a characteristic of the resource, resources with different characteristics that are associated with the same metadata associator may be associated with different metadata. For example, files of different file format types may receive different metadata, even though the files are stored in the same folder. File characteristics other than file format type that may be used to determine the subset of data values associated with a file may include file size, creation date, and/or other characteristics without dependence on file type. Such selective metadata association can be contrasted with the operation performed by some conventional file systems of storing the same directory tree information in all files in a file folder, regardless of the file type or any other file characteristic.
In one example of how the file format type may be used to associate different files associated with the same folder with different metadata, a user may define a file folder named “furniture.” The user may define a first metadata association rule for the furniture folder that specifies that all .pdf files in the folder have the keywords field being associated with “building instructions for Mission Furniture.” The user may define in the same metadata association rule or in separate metadata association rule that all .jpg files stored in the folder have the subject metadata field associated with “furniture joint image”. Such a folder would be useful if the user maintains or places into the folder pictures of mission style furniture as well as documents that describe how to build mission style furniture.
According to another aspect, the subject matter described herein may allow the user to create new customized metadata tags, in addition to populating existing tags. For example, in some file formats and some metadata schemes, users are permitted to create their own metadata tags or fields. The subject matter described herein may allow a user to create customized tags that are to be automatically associated with files having a certain characteristic when the files are associated with a particular metadata associator. For example, a user may create an <astrological sign> custom tag for a contact list of files or business card files. The user may also specify a definition of the custom tag or field that specifies the semantic meaning of the tag or field. Such a customized tag or field may be included in any of the metadata association rules that the user defines.
According to another aspect, the subject matter described herein allows a resource to be associated with more than one metadata associator. For example, a user may have a folder of resources all relating to a particular city and a separate folder of resources all relating to a particular person. In such an instance, a user may define a metadata association rule that associates a location tag to all the images in the city folder with “city name.” Similarly, the user may specify that all images associated with a person-specific folder may have a subject tag corresponding to the person's name. If a file is associated with the city folder and the person-specific folder, the subject field of the file may be associated with “person's name” and the location field of the file may be associated with “city name.” Accordingly, the subject matter described herein allows multiple metadata associators and association rules to be applied with a particular resource.
The subject matter described herein is not limited to defining metadata association rules that associate data with resources as metadata based on the file format type. Other characteristics may be used instead of or in addition to file format type in defining metadata association rules. One example of a characteristic that may be used includes the type of device that created a particular file. For example, all image files in a folder related to a user's vacation may have their respective subject fields associated with data that indicates the location of the vacation. Another metadata association rule that may be defined within the same folder may indicate that all images that were captured with a specific camera model that corresponds to an underwater camera may be associated with data that describes the dive or snorkeling site where the pictures were taken.
Another characteristic that may be used to selectively associate files with metadata according to the subject matter described herein is the time that a file was last accessed. For example, a user may define a metadata association rule that associates files that have not been accessed since a user-specified time with metadata that indicates that the files should be manually deleted or archived.
Yet another example of a characteristic that may be used to selectively associate data with resources as metadata includes access or security features of resources. For example, files having the word “confidential” or “private” may be automatically associated with metadata that indicates that the files are confidential or private, upon being associated with a metadata associator. Similarly, files that have been exposed to potential unauthorized viewing determined by differences in a resource's creation date and last accessed date may be associated with metadata indicating such post-creation access.
Yet another example of a resource characteristic that may be used to selectively associate data with files as metadata is file size. For example, files that have a size larger than 2 megabytes but smaller than 2.5 megabytes may be associated with a tag that indicates that the files contain image content. Such a characteristic may created by a user based on knowledge that only files associated with this particular associator in this range of file sizes contain image content.
The following scenarios illustrate examples of metadata that may be automatically associated with a resource based on resource characteristic according to embodiments of the subject matter described herein:
Scenario A:
The subject matter described herein may be used to facilitate resource classification and organization. Exemplary uses of the subject matter described herein include enhancing resources with metadata that describe any one or more of the following items:
Different Uses:
According to one enhancement, the subject matter described herein may be coupled with digital media organization software, such as digital camera software or digital music software to facilitate organization of image files or audio files. In addition, the subject matter described herein may be used with conventional directory-tree-based file systems or future file systems that are database oriented.
In a further enhancement, the subject matter described herein may determine whether duplicate metadata is associated with a resource before associating the metadata with the resource. For example, the data to be associated with a resource as metadata may be compared with metadata currently associated with the resource. If the data to be associated with the resource as metadata is equivalent to metadata currently associated with the resource, the metadata association engine may skip the particular data/metadata association as redundant. However, if it is determined that the data to be associated with the resource as metadata is not equivalent to metadata currently associated with the resource, the data may be associated with the resource as metadata.
Although the examples described above relate primarily to associating textual data with resources as metadata, the subject matter described herein is not limited to associating textual data with resources as metadata. Any data that is desired to be associated with a resource as metadata may be associated with a resource as metadata without departing from the scope of the subject matter described herein. Examples of non-textual data types that may be associated with a resource as metadata using the subject matter described herein include image data, video data, audio data, and/or non-image graphics data. Thus, the term “data value,” as used herein refers to data of any one or more of these data types.
It will be understood that various details of the invention may be changed without departing from the scope of the invention. Furthermore, the foregoing description is for the purpose of illustration only, and not for the purpose of limitation.
This application is a continuation of U.S. patent application Ser. No. 11/238,453, titled “ Methods, Systems, And Computer Program Products For Automatically Associating Data With A Resource As Metadata Based On A Characteristic Of The Resource,” filed Sep. 29, 2005, which is commonly owned with this application, the entire disclosure of which is hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5301268 | Takeda | Apr 1994 | A |
5398312 | Hoffmann | Mar 1995 | A |
5428734 | Haynes et al. | Jun 1995 | A |
5878410 | Zbikowski et al. | Mar 1999 | A |
5899995 | Millier et al. | May 1999 | A |
5920861 | Hall et al. | Jul 1999 | A |
5980096 | Thalhammer-Reyero | Nov 1999 | A |
6002402 | Schacher | Dec 1999 | A |
6009442 | Chen et al. | Dec 1999 | A |
6035323 | Narayen et al. | Mar 2000 | A |
6151624 | Teare et al. | Nov 2000 | A |
6243724 | Mander et al. | Jun 2001 | B1 |
6259448 | McNally et al. | Jul 2001 | B1 |
6353823 | Kumar | Mar 2002 | B1 |
6418448 | Sarkar | Jul 2002 | B1 |
6466238 | Berry et al. | Oct 2002 | B1 |
6501911 | Malloy Desormeaux | Dec 2002 | B1 |
6505003 | Malloy Desormeaux | Jan 2003 | B1 |
6510434 | Anderson et al. | Jan 2003 | B1 |
6516154 | Parulski et al. | Feb 2003 | B1 |
6582474 | LaMarca et al. | Jun 2003 | B2 |
6613101 | Mander et al. | Sep 2003 | B2 |
6643639 | Biebesheimer et al. | Nov 2003 | B2 |
6711577 | Wong et al. | Mar 2004 | B1 |
6741994 | Kang et al. | May 2004 | B1 |
6757684 | Svendsen et al. | Jun 2004 | B2 |
6760884 | Vertelney et al. | Jul 2004 | B1 |
6810404 | Ferguson et al. | Oct 2004 | B1 |
6820094 | Ferguson et al. | Nov 2004 | B1 |
6877138 | Fitzpatrick et al. | Apr 2005 | B2 |
7047253 | Murthy et al. | May 2006 | B1 |
7162488 | DeVorchik et al. | Jan 2007 | B2 |
7171468 | Yeung et al. | Jan 2007 | B2 |
7269612 | Devarakonda et al. | Sep 2007 | B2 |
7386532 | Kiessig et al. | Jun 2008 | B2 |
20020016800 | Spivak et al. | Feb 2002 | A1 |
20020065741 | Baum et al. | May 2002 | A1 |
20020065844 | Robinson et al. | May 2002 | A1 |
20020073104 | Nunez | Jun 2002 | A1 |
20020087601 | Anderson et al. | Jul 2002 | A1 |
20020093678 | Skidgel et al. | Jul 2002 | A1 |
20020135801 | Tessman et al. | Sep 2002 | A1 |
20030034892 | Light et al. | Feb 2003 | A1 |
20030078968 | Needham et al. | Apr 2003 | A1 |
20030078987 | Serebrennikov | Apr 2003 | A1 |
20030087601 | Agam et al. | May 2003 | A1 |
20030105795 | Anderson et al. | Jun 2003 | A1 |
20030105831 | O'Kane | Jun 2003 | A1 |
20030110188 | Howard et al. | Jun 2003 | A1 |
20030131002 | Gennetten et al. | Jul 2003 | A1 |
20030131013 | Pope et al. | Jul 2003 | A1 |
20030154178 | McIntyre et al. | Aug 2003 | A1 |
20030208499 | Bigwood et al. | Nov 2003 | A1 |
20040006575 | Visharam et al. | Jan 2004 | A1 |
20040019658 | Plastina et al. | Jan 2004 | A1 |
20040027382 | Kuehn et al. | Feb 2004 | A1 |
20040096110 | Yogeshwar et al. | May 2004 | A1 |
20040111728 | Schwalm | Jun 2004 | A1 |
20040117358 | von Kaenel et al. | Jun 2004 | A1 |
20040133589 | Kiessig et al. | Jul 2004 | A1 |
20040153467 | Conover et al. | Aug 2004 | A1 |
20040168118 | Wong et al. | Aug 2004 | A1 |
20040172241 | Mahe et al. | Sep 2004 | A1 |
20040177319 | Horn | Sep 2004 | A1 |
20040210552 | Friedman et al. | Oct 2004 | A1 |
20040210946 | Shin | Oct 2004 | A1 |
20040220926 | Lamkin et al. | Nov 2004 | A1 |
20040250215 | Chen et al. | Dec 2004 | A1 |
20040260702 | Cragun et al. | Dec 2004 | A1 |
20050015391 | Pohlan | Jan 2005 | A1 |
20050044089 | Wu et al. | Feb 2005 | A1 |
20050050537 | Thompson et al. | Mar 2005 | A1 |
20050060653 | Fukase et al. | Mar 2005 | A1 |
20050063083 | Dart et al. | Mar 2005 | A1 |
20050071865 | Martins | Mar 2005 | A1 |
20050080802 | Cras et al. | Apr 2005 | A1 |
20050091184 | Seshadri et al. | Apr 2005 | A1 |
20050091285 | Krishnan et al. | Apr 2005 | A1 |
20050097120 | Cooper et al. | May 2005 | A1 |
20050114356 | Bhatti | May 2005 | A1 |
20050114381 | Borthakur et al. | May 2005 | A1 |
20050120021 | Tang et al. | Jun 2005 | A1 |
20050131871 | Howard et al. | Jun 2005 | A1 |
20050166159 | Mondry et al. | Jul 2005 | A1 |
20050177796 | Takahashi | Aug 2005 | A1 |
20060031486 | Miner | Feb 2006 | A1 |
20070067290 | Makela | Mar 2007 | A1 |
20070073688 | Fry | Mar 2007 | A1 |
20070073751 | Morris et al. | Mar 2007 | A1 |
20070073770 | Morris | Mar 2007 | A1 |
Entry |
---|
“An Opinion,” http://anopinion.net/posts/248.aspx, pp. 1-30 (Nov. 16, 2003). |
“An Opinion—Windows Foo System,” http://anopinion.net/posts/241/aspx, pp. 1-33 (Nov. 15, 2003). |
Rector, “Chapter 4: Storage (Introducing Longhorn for Developers),” Microsoft.com, pp. 1-19 (Jan. 2004). |
Spanbauer, “Longhorn Preview,” PC World, pp. 1-5 (Copyright 2005). |
Mackey, “Longhorn So Far,” http://arstechnica.com/journals/microsoft.ars/2005/5/2/194, p. 1 (May 2, 2005). |
“More Effective at Work and Home,” Microsoft Corp. Apr. 25, 2005 [online] http://www.microsoft.com/windows/longhorn/infomanagement.mspx, Microsoft Windows, pp. 1-3. |
Finnie, “The Lowdown on Longhorn,” TechWeb.com, pp. 1-5 (May 2, 2005). |
Number | Date | Country | |
---|---|---|---|
20100332559 A1 | Dec 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11238453 | Sep 2005 | US |
Child | 12854521 | US |