Summarization of media object collections

Abstract
In one example, an apparatus and method are provided for summarizing (or selecting a representative subset from) a collection of media objects. A method includes selecting a subset of media objects from a collection of geographically-referenced (e.g., via GPS coordinates) media objects based on a pattern of the media objects within a spatial region. The media objects may further be selected based on (or be biased by) various social aspects, temporal aspects, spatial aspects, or combinations thereof relating to the media objects and/or a user. Another method includes clustering a collection of media objects in a cluster structure having a plurality of subclusters, ranking the media objects of the plurality of subclusters, and selection logic for selecting a subset of the media objects based on the ranking of the media objects.
Description

BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates an exemplary environment in which some aspects and examples described herein may by used;



FIGS. 2A and 2B illustrate a display of a collection of media objects and a subset or summary of the media objects, respectively, according to one example;



FIG. 3 illustrates conceptually an exemplary hierarchical clustering according to one example; and



FIG. 4 illustrates an exemplary display of a map having geographically referenced tags according to one example.





DETAILED DESCRIPTION

The following description is presented to enable a person of ordinary skill in the art to make and use the inventions. Descriptions of specific devices, techniques, and applications are provided only as examples. Various modifications to the examples described herein will be readily apparent to those of ordinary skill in the art, and the general principles defined herein may be applied to other examples and applications without departing from the spirit and scope of the inventions. Thus, the present inventions are not intended to be limited to the examples described herein and shown, but are to be accorded the scope consistent with the claims.


For the sake of convenience, at times, digital photographs or still images are used and described as examples of media objects manipulated by the exemplary system, but those skilled in the art will recognize that the various examples apply similarly or equally to other media objects, subject to appropriate modifications and use of other functions where appropriate (e.g., viewing a media object may apply to viewing a still or moving image or listening to an audio media object, such as a soundtrack).



FIG. 1 illustrates an exemplary environment in which some examples of summarizing a collection of media objects as described may be used. In particular, FIG. 1 illustrates a client-server system in which one or more clients 110 may communicate with a media server 100 via a network 112. Media server 100 may include a web server 102 interfacing with network 112 and including http web server logic, for example. Further, media server 100 includes a database 106 for storing media objects and summarization logic 108 for processing one or more collections of media objects stored in database 106 (or otherwise associated with media server 100).


Clients 110 and media server 100 may communicate, e.g., via suitable communication interfaces via a network 112, such as the Internet. Clients 110 and media server 100 may communicate, in part or in whole, via wireless or hardwired communications, such as Ethernet, IEEE 802.11b wireless, or the like. Additionally, communication between clients 110 and media server 100 may include various servers such as a photograph/image server, map server, mail server, mobile server, and the like.


Media server 100 includes logic or is programmed to process media objects and format data, accessed from local or remote databases or other sources of data, for presentation to users of clients 110, preferably in the format discussed in the examples herein. To that end, media server 100 may utilize various Web data interface techniques such as Common Gateway Interface (CGI) protocol and associated applications (or “scripts”), Java® “servlets”, i.e., Java® applications running on the Web server, or the like to present information and receive input from clients 110. Media server 100, although described herein in the singular, may actually comprise plural computers, devices, backends, and the like, communicating (wired and/or wireless) and cooperating to perform some or all of the functions described herein. An exemplary media server is described in U.S. patent application Ser. No. 11/350,635, entitled “MEDIA OBJECT METADATA ASSOCIATION AND RANKING”, and filed Feb. 8, 2006, which is hereby incorporated by reference in its entirety as if fully set forth herein. Of course, media server 100 may be implemented in various fashions and include various hardware, software, or firmware to carry out the examples described herein.


In one example, media server 100 includes various components known in the art, e.g., a scripting engine (such as a PHP scripting engine), an aggregation engine, and the like. A scripting engine may include authentication logic, upload logic, metadata processing logic, and permissions handling logic. The authentication logic authenticates a user signing on to the media server web site. The upload logic may be used to upload from the client to the server data conforming to any media format, e.g., still image (e.g., JPEG, TIFF), video (e.g., MPEG, AVI), or audio (e.g., MP3, OGG). The aggregation engine may include a statistics engine and a search engine. A client for use with the server of the invention may include a typical web browser application.


Metadata processing logic permits a user to enter metadata to describe each image (as used herein, “metadata” may refer to one metadatum or plural metadata). Metadata may take the form ozone or more tags for a media object. Other types of metadata include, e.g., a title, a description of the image, annotations, and comments. Additionally, metadata associated with a device (e.g., device-supplied metadata) such as metadata from a digital camera that took the picture, including metadata regarding time of capture, aperture, shutter speed, and other settings. Such metadata may be extracted, for example, from the EXIF (Exchangeable Image File) header stored inside the uploaded file by many digital cameras, or the IPTC (International Press Telecommunications Council) header stored inside the uploaded file by many photograph management and organization software packages.


Additionally, metadata may include geographical reference data associated with the media object. For example, the device may generate a geographical location (e.g., from a GPS location device, cell identification, or other location technologies). Additionally or alternatively, a user may enter or edit the geographical location associated with a particular media object (either at the time of capture or later).


One or more clients 110 may transfer media objects and/or related metadata to media server 100 for inclusion within database 106. Further, one or more clients 10 may request summaries of a portion or all of the collection of media objects and/or related metadata included with database 106 or otherwise accessible via media server 100. For example, summarization logic 108 may process a collection of media objects stored locally, remotely, or combinations thereof.


In one example, a system and method are described for selecting and displaying a subset (or summary) of a collection of media objects. In one example, media objects of a collection are geographically referenced and pertain generally to a particular spatial region (e.g., a map or categorization of a specified spatial region). An exemplary method and system select a subset of the collection based on a pattern of the media objects within the spatial region. The pattern may be based on spatial aspects, temporal aspects, social aspects (e.g., groups, contacts, connections and the like associated with a particular user or users), or combinations thereof associated with the media objects and/or user. For example, the summary may be based on a pattern of the media objects, e.g., relating to a density of the media objects within a spatial region at particular locations, and also based on one or more characteristics of a user requesting the summary.



FIG. 2A illustrates a display of a collection of geo-referenced media objects 210 pertaining generally to a particular spatial region. In this example, the spatial region is associated with San Francisco, Calif., and accordingly, the display includes a map 200 of San Francisco, Calif., and media objects 210 displayed overlying map 200 according to their associated geo-references. In this example, each media object is represented by a square (or other indicia on the map), which may be selected by a user to access content of the media object. As the number of media objects 210 in the collection grows, the display may become cluttered and crowded, making viewing the collection of media objects difficult.


Exemplary summarization logic (included with media server 100, for example) as described in greater detail below, may produce a summary of the media objects as shown in FIG. 2B based on one or more patterns of the media objects as well as various other social, temporal, and/or spatial aspects of the media objects and/or a user requesting the summary. For example, the system and method may select a subset of media objects 220 for display with the particular spatial region of interest. Such a subset of the media objects 220, referred to herein as a summary of the collection, may enable users to find items more easily and browse more efficiently through large scale geo-referenced photograph collections in a manner that improves rather than degrades with the addition of more photographs. It is noted that map 200 may be generated or stored locally with media server 100, or alternatively generated or stored remotely to media server 100.


Additionally, display logic may present or display the media objects as thumbnail images over map 200, and which may be expanded in response to user input (e.g., scrolling over media object 220a generates the display of a larger image 230). It will be recognized that in some example a client may further expand image 230, download image 230 to a user device, transfer (e.g., via email) image 230 to other clients, and the like.


In other examples, the system could summarize a collection of media objects according to a spatial region without displaying a map. For example, a summary of the collection could be categorized within the database or presented under headings according to the summarization processing and spatial region of interest. In yet other examples, the summary of media objects (or at least data associated therewith) may be supplied to a third party, which may present the summary with a map, advertisements, and the like, for example.


An exemplary system and method having summarization logic may be used in a number of applications. For example, such an algorithm may be used for geographic image search, returning a summary of photographs from a region in response to a search query (that can be specified as a text term or a map region), and the like. The algorithm can be used to assist in map-based browsing of images, for example, by enabling a “semantic zoom,” wherein as a user changes zoom levels, panned to any region, the system displays a subset of images that represent that region. For example, FIG. 2B shows a map of San Francisco in which a limited set of eleven images that were selected by an exemplary system are marked on the map. When the user zooms in, the system logic may operate to generate a new subset or summary of images to display to the user at the new zoom level. Additionally, a user may use the exemplary system and method to browse one's own image collection or a group of other user image collections to get an overview of a location.


Selecting representative media objects from a collection of media objects and for a given spatial region posses several difficulties. For instance, image analysis alone is generally poor at understanding the semantic content of an image, for example, making purely visual relevance insufficient for summarizing a collection of media objects. In collection from multiple users, the biases of one user's data may also bias the selection towards generally insignificant subjects. The notion of relevance is not well defined, and often subjective; it is therefore difficult for an automated system to learn and assess the relevance of photographs without appropriate models of human interest.


In one example, the summarization logic 108 of media server 100 includes metadata-based heuristics associated with patterns in the photographs and users' photographic behavior. An exemplary heuristic includes the premise that photographs taken at a particular geographical location typically imply the presence of something interesting at the particular geographical location; for example, the attention paid to an object is generally an indicator of its importance. Thus, in one example, the summarization logic includes an algorithm operable to input one or more of a multitude of spatial, social, and temporal metadata, such as where the photograph was taken, by whom, at what time, etc., as well as textual-topical patterns in the data, such as textual tags associated with the photograph (e.g., user inputted tags). Furthermore, the algorithm may be adjusted to bias the set of results using various factors such as the social network distance of the photographers to the user making the query.


It is noted that the specific example and algorithms described are illustrative of a specific implementation of selecting a summary of media objects from a collection of media objects. Those of ordinary skill in the art will recognize that other systems and methods, utilizing various algorithms and inputs related to the media objects or the user, may be used to select summaries based on patterns within the collection of media objects. Accordingly, the following example is not intended to be limiting.


In this example, summarization logic 108 operates on a collection of media objects to produce a subset or summary of the collection of media objects. For instance, given a collection of n photographs, A={P1, . . . , PN}, the exemplary method and system determines a permutation π of A such that any k-length prefix of π(A) is a k-element summary of A. It is desired that a summary, generally referring to a subset of the media collection, capture representativeness, relevance, and breadth in the original collection, for example. In one example, a summary is captured through a subset of one or more metadata attributes that are associated with the photographs. Exemplary metadata attributes may include, but are not limited to, any combination of location (e.g., photograph Pi was taken at location (xi, yi)), time (e.g., photograph Pi was taken at time ti), photographer (e.g., photograph Pi was taken by user ui), tags (e.g., photograph Pi was manually assigned the list of textual tags wi), quality (photograph Pi is associated with an externally derived parameter qi that represents its image quality), bias (also referred to herein as “relevance,” e.g., photograph Pi is associated with a relevance factor ri; relevance may include arbitrary biases (or preferences) based on parameters such as recency, time of day, day of the week, social aspects such as a social network of the user, textual tags associated with that photo, etc.), user profiles, and the like.


The system includes logic for selecting a subset of the collection of photographs following a few heuristics, which may be adjusted by a user or the media server. Exemplary heuristics include, for example, that photographs are taken at locations that provide views of some interesting object or landmark, a location is more relevant if photographs were taken at the location by a large number of distinct photographers, and if available, location-specific patterns of textual tags can reflect the presence of interesting landmarks in a location.


It is noted that a distinction is made herein between the location of the camera (or other device used to capture the media object) and the location of the photographed object. For example, most geographic data associated with photographs pertains to the camera location. In some instances the two locations are near each other (for example, when the photograph is of a house or, say, a fountain), while in other cases (a photograph of, say, the Golden Gate Bridge) the camera may be a considerable distance from the object (e.g., miles away). In one example, the system receives as input the location of the camera, and associates the tags with that location even if the photographed object is remote.


In addition to heuristics listed above, an exemplary system may also operate to represent a broad range of subjects, instead of thoroughly display a few, and allow personal or query bias to modify the system's results. For example, an exemplary system may include the flexibility to allow a user to specify a personal bias, or preference, toward any of the available features of the system and/or to utilize implicit bias in the query context and history. For example, a user may bias by any quantifiable feature of the photographs, such as the social distance of the photographer to the user, preference for weekend photographs, the externally determined quality of the image, and the like.


In one example, the system includes logic for producing an ordering of photographs in the collection. Generally, producing the ordering of photographs comprises two broad processes: clustering the photographs of the collection, and ranking the photographs. These processes may be carried out by clustering logic and ranking logic included with summarization logic 108 (see, e.g., FIG. 1).


In one example, the clustering logic may cluster photographs of a media collection based on their respective geographic locations. This may be accomplished by various known clustering methods. In one example, the clustering logic is operable for clustering the photographs based on their geographical locations into a hierarchical clustered structure (for example, having a series of subclusters). The exemplary system further includes ranking logic for ordering the photographs within the cluster generated by the clustering logic. An ordering of the photographs may be generated, for example, by interleaving photographs from the collection subclusters, prioritized according to a calculated score. The ranking logic may then recursively rank the photographs for each of the subclusters, starting from the leaf clusters. A summarization of the photographs, e.g., via a display of the photographs, for a specified spatial region may then be generated based on the ranking of photographs within the collection subclusters.


To illustrate the summarization process and scoring mechanism, an exemplary hierarchical cluster structure is illustrated in FIG. 3. In particular, the leaf nodes represent photographs, each annotated with the identity of the photographer and a single textual tag (in practice, of course, different and additional tags may be used). The tree represents the hierarchy created by the clustering logic of the apparatus or system.


In one example, the clustering logic and particular clustering algorithm may include a Hungarian method, which is known in the art, or a modification thereof. One particular modification to the Hungarian method includes the method described in “The Hungarian Clustering Method,” by Jacob Goldberger and Tamir Tassa, the content of which is published at, http://www.openu.ac.il/Personal_sites/tamirtassa/Publications/hcm.pdf, and which is incorporated herein by reference. Other exemplary clustering methods may include conglomerative clustering, partitional clustering, hierarchical agglomerative, divisive clustering, or the like.


In this example, the clustering logic is generally operable to identify a hierarchy of clusters within a given dataset (e.g., generated from the collection of media objects) of points in n dimensions, based only on the distances between those points. The input to that algorithm is a set of points in the plane






A={(xi,yi,1≦i≦n}  (1)


and the output is a clustering of those points C(A), where C(A) is a tree; each node in the tree represents a subset of A; and the children of each node are a partition (or clustering) of the subset that is associated with that node.


Given a hierarchical clustering based on the locations of the photographs, for example, the ranking logic is operable to produce a ranking of each object or item in the collection. In one example, the ranking logic first assigns a score to each cluster, and performs a recursive interleaving algorithm that uses the clustered structure and the corresponding scores in order to produce a natural flat ordering. For example, given a hierarchical clustering C(A) of A, where A is possibly itself a subcluster in a larger hierarchy, the algorithm outputs a permutation π on A that represents ranking on A. That ordered sequence is denoted henceforth by S=π(A).


Assume that m subclusters are identified in A, A=Ui−1m=Ai, and that






f(A1)≧f(A2)≧ . . . f(Am)


where f represents a black box determining the cluster score. In one example, each cluster represents a different site or focal point in the area where the photographs were taken. Moreover, the subclusters of each of the clusters may represent different locations within the corresponding site.


In one example, it is desired that the ranking logic produce a ranking that would balance the contradicting properties of depth and breadth of coverage. For example, consider the second level of the exemplary hierarchy shown in FIG. 3, which includes two clusters C2 and C3, and assume f(C2):f(C3)=5:3. In one example, the system interleaves the photographs from the two clusters so that in any section of the sequence S, the frequencies of photographs from the clusters relate to each other as closely as possible to their score ratio in the whole dataset, i.e., 5:3. On the other hand, for purposes of breadth, it is desired that each reasonably good subcluster should be at least somewhat represented early in the ranking of its parent.


Accordingly, in an attempt to balance some amount of depth, breadth, and consistency according to one example, the summarization logic and algorithm assumes that the photographs in each subcluster of a current A have been ranked recursively according to the algorithm. The ordered sequence of photographs for A will then have two parts: a short header H followed by a trailer T, where S(A)=H∥T.


The header H will include a photograph from all prominent clusters. To that end, a threshold 0<w<1 is defined and a cluster Ai is deemed prominent if








f


(

A
i

)






j
=
1

m







f


(

A
j

)






w
.





Assume that there are m′ prominent clusters among the m clusters, with 0≦m′≦m. Then the header is






H=(A1,1,A2,1 . . . Am′,1),


where Ai,j means the jth most relevant photograph from cluster Ai.


Next, a trailer is generated. In one example, each cluster is assigned a probability that equals its score divided by the sum of scores of all clusters. These probabilities are then used to randomly select a cluster. If cluster Ai was selected, its top-ranked remaining photograph is removed and appended to T and the score and probability of that cluster is recalculated to reflect the removal of its top photo. The process of selecting photographs and appending them to the trailer is repeated until all photographs have been selected.


The score of a cluster Ai may depend on several factors or attributes of the clusters, including, for example, the following (which will be described in greater detail below):


The sum of bias factors (e.g., relevance) of all photographs in the cluster,







ρ
i

=





P
j



A
i






r
j

.






The tag-distinguishability of the cluster, τi.


The photographer-distinguishability of the cluster, øi.


The density of the cluster. More specifically, let σx,i and σy,i denote the standard deviation of the x and y coordinates, respectively, of all points in Ai, and let





σi=((σx,i)2+(σy,i)2)1/2.


The cluster density may be defined as





δi=1/(1+σi).   (2)


The sum of image qualities of all photographs in the cluster,







κ
i

=





P
j



A
i






q
j

.






It is noted that while most of the above factors may be derived from data that is contained in the collection of media objects (e.g., included with the metadata), the bias factor depends on subjective requirements that are introduced through the query to the photograph collection (e.g., set by the system for a particular application or by a user via their particular request).


Bias (relevance) Factors: In one example, the bias factor ri of a photograph Pi may depend on one or more parameters such as recency, the time of day, the time of the week, the photographer, textual tags associated with that photo, and the like. Each photograph may be assigned a score θ(Pi) in the range [0,1] for each such parameter. The final bias score can be a weighted average of all these scores, which is the bias score ri of photograph Pi. The amount to which each feature contributes to the overall bias calculation can be specified by a user, or set by the system according to the application.


For example, a user may request photographs taken during the day, or by a set of one or more photographers (e.g., their contacts, friends, family, etc.). These inputs will weight the bias factors accordingly, thereby biasing the results per the user query.


Tag distinguishability of the cluster: In one example, tag distinguishability aims to detect distinct or unique concepts that are represented by a given cluster by examination of the tags. The assumption is that the more unique concepts a cluster represents, the more semantically meaningful a cluster tends to be. For example, in FIG. 2, the tag “bridge” appears in two photographs from Cluster 2, and does not appear elsewhere. As a consequence, the score of Cluster 2 improves. On the other hand, the tag “car” appears in photographs from both Cluster 2 and Cluster 3 and therefore does not help to distinguish either cluster over the other.


Formally, each photography Pj, 1≦j≦n, is tagged with tags that are drawn from a finite dictionary. Let Ft,i denote the frequency (count) of t in Ai, (the usual term frequency of the tag/term t in the cluster/document Ai, as often used in information retrieval). There are several ways to measure how the term t distinguishes the cluster Ai from other clusters. Denoting such measures by Tt,I; the usual measure in information retrieval is the tf-idf weight (where term frequency—inverse document frequency is also familiar and well known in the art of information retrieval). The measure is defined as






T
t,i
:=tfidf
t,i
=tf
t,i
·idf
t,   (3)


where, tft,i32 Ft,i, while










idf
t

=

n



{


P
j



A
:

t


T


(

P
j

)





}








(
4
)







is a measure of the overall frequency of the tag t in the entire photograph collection. Another alternative to (3) which is used in information retrieval is






T
t,i
:=tfidf
t,i
=tf
t,i·log(idft).   (5)


Large values of both weights indicate that the number of occurrences of t in Ai is large with respect to its number of occurrences elsewhere.


It is noted that in the usual tf-idf weight, the document-frequency is defined as the frequency of clusters in which the tag appears, as opposed to the frequency of actual tag occurrences. However, the usual definition is generally not suitable for cases where the number of clusters (documents) is small. In such cases, a single random occurrence of a tag in a cluster may have a significant effect on the usual measure, while in this instance it would be hardly noticeable.


Next, an overall tag-distinguishability measure for Ai, Ti, is defined based on the tag-distinguishability measures of all tags in the cluster, {Tt,i: t ε T}. The overall score may be computed by using the Euclidean measure based on the 12-norm,










τ
i

=



(




t

T




τ

t
,
i

2


)


1
/
2


.





(
6
)







Photographer distinguishability of clusters: In one example, a measure of photographer distinguishability (or user distinguishability) is determined, which may indicate how much a given cluster is associated with a small number of photographers, making the cluster less likely to be semantically meaningful. For example, in FIG. 3, all photographs in Cluster 3 were taken by the same user (U3), and that that user did not take any photographs at other locations. This may suggest that Cluster 3 may have less general appeal than, for example, Cluster 2 in FIG. 3, which includes photographs from two users (U1 and U2).


Hence, much like for tags, a tf-idf-like score for the correlation between a cluster Ai and a photographer u may be used. For example, let Bu denote the set of locations of photographs that were taken by the photographer u (as with the set A, (1), of all photograph locations, Bu is a multiset, in the sense that it may include repeated values). The score may then be given by





φu,i:=tfu,i·idfu   (7)


where










tf

u
,
i


=





A
i



B
u







A
i








(
8
)







idf
u

=


n



B
u




.





(
9
)







and


Note that (7) and (9) are equivalent to (3) and (4), respectively. As previously, compare (5) with (3), and (7) may be replaced with





φu,i:=tfu,i·log(idfu).   (10)


Finally, the overall photographer-distinguishability may then be defined, in this example, as:










φ
i

=



(



u



φ

u
,
i

2


)


1
/
2


.





(
11
)







When dealing with tag-distinguishability, the more a given cluster is associated with some tags, the more it is conceived as a ‘well-defined’ cluster that has prominent distinguishability from other clusters. Photographer-distinguishability, on the other hand, has an opposite effect. The more a given cluster is associated with a single photographer (or few photographers), the less interesting that cluster becomes.


Overall Cluster Score: The score s(Ai) of the cluster Ai depends, in one example, in a monotonically increasing manner on the bias factor, ρi, and the image quality factor, κi. It also depends in a monotonically increasing manner on the density measure of the cluster, δi, (2). The score s(Ai) may also depend in a monotonically increasing manner on Ti, the tag-distinguishability measure of the cluster. Finally, the score may depend in a monotonically increasingly manner on øi−1, the inverse photographer-distinguishability measure of the cluster, as discussed above. Therefore, the overall score may be represented as





h(κii,Tii−1)·ρi   (12)


where h is, for example, a weighted average of its variables, and the weights may be chosen and fine-tuned by experimentation.


It will be understood that the above scoring methods are illustrative of some exemplary methods in which a system may score clusters, and is not intended to be exhaustive or limiting. In other examples, additional or different factors may be used. Additionally, similar factors as described herein, such as bias factors, tag-distinguishability of clusters, etc., may be determined in alternative manners.


A media server including summarization logic as described herein has a number of possible applications and uses. In one example, the media server and summarization logic may be used to as part of or to support a “semantic zoom” application using a large collections of digital images (or other media objects), or assist in browsing/searching a large collection of media objects by initially showing summarized results.


Semantic zoom generally refers to changing the space of interest in which the media objects are related, such as a map, timeline, or combination thereof, where the zoom or change in space is accompanied by a corresponding shift in the level of content represented on the map or timeline. In the example of a spatial map, this may include presenting to a user a number of photographs appropriate to an initial or current zoom level for a given spatial map. The system selects images for display according to the summarization logic (e.g., based on a determined pattern, the particular ranking, etc.). As the user zooms in, more photographs (e.g., that were ranked lower) are revealed, thus bringing the content into more detail. At any zoom level, panned to any region, the system and associated logic automatically displays a summary of photographs that represent that region per the particular summarization logic inputs. Given an ordering on a collection of photographs, a system may quickly display a summary of photographs for varying levels in response to user input. When viewing any region, the system may display the k best photographs that were taken within that region. Alternatively, the system may display a fixed number of photographs for any zoom level, letting the number of photographs that appear in a particular region at that level implicitly correspond to the relevance of that particular region.


In addition, the exemplary summarization logic and algorithm described may be used to generate or seed “tag maps,” e.g., a visualization for geo-referenced collections based on textual tags that are associated with the data. FIG. 4 illustrates an exemplary tag map 400 based on a manipulation by a summarization logic as described herein. Tag map 400 displays tags 430, e.g., textual topics, that are associated with specific locations on a map. Tags that are deemed relevant (e.g., according to summarization logic or methods described) may be shown at the location where they “occur” (e.g., based on their geo-locations or user supplied metadata), and in one example may be displayed in a size that corresponds to the tag's importance (which may be based on various attributes of the collection, system, or user), as shown in FIG. 4.


In this example, exemplary summarization logic and methods as described herein generated tag map 400, which represents photo-taking in San Francisco, Calif. Rather than display representative photographs at their respective locations (e.g., as shown in FIG. 2B), this example conveys concepts represented in the dataset through the metadata tags themselves. Further, note that in this example, tags 430 displayed with tag map 400 represent “photograph spots” and not necessarily the locations of the object themselves. For example, the “Golden Gate Bridge” tags, which are shown in multiple locations, are in locations other than the physical location of the Golden Gate Bridge.


In one example, in the tag-distinguishability process described previously, a tag-distinguishability score τi is calculated for each cluster Ai at each level of the hierarchy. In the process, an individual score τt,i is calculated for each tag t. This tag score, as a variant of tf-idf, can be thought of as a measure for how well and how uniquely t represents Ai. Thus, consider the following mapping: for some ‘natural’ level of the hierarchy, (to be determined later) let qi be the tag t ε T that maximizes τt,i. The displayed size of the tag corresponds to its score. In this example, the tags are displayed above the centroids of their given cluster on the map. Additionally, in other examples, other types of information can be encoded in the tag map; for example, recency can be represented via the color of the tag text.


Various aspects described may also be combined in various manners. For example, a tag map can be displayed or selected at different zoom levels via process and methods describe with respect to the zoom aspects. Moreover, tag maps may be used for collections other than geo-referenced photographs: e.g. for visualizing popular search keywords from different areas on the map.


Additionally, the various aspects and examples may be combined or used with other known methods and system. In one example, the exemplary system may operate to select a subset of a collection of media objects (stored remotely or locally) as described herein in response to a search request or function. For example, a subset may be returned or included with search results when a text, image, or other search is performed on an object that is recognized by the system as a spatial object (e.g., Germany, San Francisco, Central Park, or the like).


The various aspects and examples of the inventions can be implemented in any suitable form including hardware, software, firmware or any combination of these. Different aspects of the invention may be implemented at least partly as computer software or firmware running on one or more data processors and/or digital signal processors. The elements and components of an embodiment of the invention may be physically, functionally, and logically implemented in any suitable way. Indeed the functionality may be implemented in a single unit, in a plurality of units or as part of other functional units. As such, the invention may be implemented in a single unit or may be physically and functionally distributed between different units and processors.


Although the present invention has been described in connection with some embodiments, it is not intended to be limited to the specific form set forth herein. Rather, the scope of the present invention is limited only by the claims. Additionally, although a feature may appear to be described in connection with a particular embodiment, one skilled in the art would recognize that various features of the described embodiments may be combined in accordance with the invention. Moreover, aspects of the invention describe in connection with an embodiment may stand alone as an invention.


Moreover, it will be appreciated that various modifications and alterations may be made by those skilled in the art without departing from the spirit and scope of the invention. The invention is not to be limited by the foregoing illustrative details, but is to be defined according to the claims.

Claims
  • 1. An apparatus for selecting a representative subset from a collection of geographically referenced media objects, the apparatus comprising: selection logic for selecting a subset of media objects from a collection of geographically referenced media objects based on a pattern of the media objects within a spatial region.
  • 2. The apparatus of claim 1, wherein the pattern relates to a density of the media objects within the spatial region.
  • 3. The apparatus of claim 1, the selection logic further for selecting the subset based upon an identity of a user and a characteristic associated with the user.
  • 4. The apparatus of claim 3, wherein the characteristic comprises a social aspect related to the user.
  • 5. The apparatus of claim 1, the selection logic further for selecting the subset based upon a temporal aspect of the media objects,
  • 6. The apparatus of claim 5, wherein the temporal aspect relates to recency of the media objects.
  • 7. The apparatus of claim 1, the selection logic further for selecting the subset based on a visual feature of the media objects.
  • 8. The apparatus of claim 1, the selection logic further for selecting the subset based on text associated with the media objects.
  • 9. The apparatus of claim 1, the selection logic further for selecting the subset based on data associated with the media objects.
  • 10. The apparatus of claim 9, wherein the data comprises a user generated tag.
  • 11. The apparatus of claim 1, wherein the selection logic selects the subset in response to a search query, the search query on an object having a spatial aspect.
  • 12. An apparatus for summarizing a collection of media objects, the apparatus comprising: clustering logic for clustering a collection of media objects in a cluster structure having a plurality of subclusters;ranking logic for ranking the media objects of the plurality of subclusters; andselection logic for selecting a subset of the media objects based on the ranking of the media objects.
  • 13. The apparatus of claim 12, wherein the media objects are clustered based on geographical data associated with each of the media objects.
  • 14. The apparatus of claim 12, wherein the selected media objects each have a geographical reference associated therewith, the apparatus further comprising logic for displaying the media objects with a map according to the geographical references.
  • 15. The apparatus of claim 12, further comprising logic for scoring each subcluster according to at least one metadata attribute of the media objects.
  • 16. The apparatus of claim 15, wherein the at least one metadata attribute comprises at least one of the group consisting of: bias, tag-distinguishability, photographer-distinguishability, density, and the sum of image qualities of the cluster.
  • 17. The apparatus of claim 15, wherein the at least one metadata attribute comprises at least one bias factor, the apparatus further comprising logic for receiving input from a user, the input determining the at least one bias factor.
  • 18. The apparatus of claim 12, the selection logic further selecting the subset of the media objects based on a zoom level.
  • 19. The apparatus of claim 12, further comprising display logic for displaying tags with a map, wherein the tags are displayed according to associated geographically references.
  • 20. A method for summarizing a collection of geographically referenced media objects associated with a spatial region, the method comprising: selecting a subset of media objects from the collection of geographically referenced media objects based on a pattern of the media objects within the spatial region.
  • 21. The method of claim 20, wherein the pattern relates to a density of the media objects within the spatial region.
  • 22. The method of claim 20, wherein selecting the subset is further based upon a user identity and a characteristic associated with the user.
  • 23. The method of claim 22, wherein the characteristic comprises a social aspect related to the user.
  • 24. The method of claim 20, wherein selecting the subset is further based upon a temporal aspect of the media objects.
  • 25. The method of claim 20, wherein selecting the subset is further based on a visual feature of the media objects.
  • 26. The method of claim 20, wherein selecting the subset is further based on text associated with the media objects.
  • 27. The method of claim 20, wherein selecting the subset is further based on data associated with the media objects.
  • 28. The method of claim 27, wherein the data comprises a user generated tag.
  • 29. The method of claim 20, wherein the subset is selected in response to a search query, the search query on an object having a spatial aspect.
  • 30. A method for summarizing a collection of media objects, the method comprising: clustering a plurality of media objects according to a cluster structure, the cluster structure having a plurality of subclusters;ranking the media objects of the plurality of subclusters; andselecting a subset of the media objects based on the ranking of the media objects.
  • 31. The method of claim 30, further comprising clustering the media objects based on geographical data associated with the media objects.
  • 32. The method of claim 30, wherein the displayed media objects have a geographical reference associated therewith, the method further comprising displaying the subset of the media objects with a map according to the geographical references.
  • 33. The method of claim 30, further comprising scoring each subcluster according to at least one metadata attribute of the subclusters.
  • 34. The method of claim 33, wherein the at least one metadata attribute comprises at least one of the group consisting of: bias, tag-distinguishability, photographer-distinguishability, density, and the sum of image qualities of the cluster.
  • 35. The method of claim 30, wherein selecting the subset of the media objects is based on a zoom level.
  • 36. The method of claim 30, further comprising displaying tags with a map based, wherein the tags are displayed according to associated geographical references.
  • 37. A computer program product comprising computer-executable program code for summarizing a collection of media objects, the product comprising program code for: selecting a subset of media objects from a collection of geographically referenced media objects based on a pattern of the media objects within a spatial region.
  • 38. The computer program product of claim 37, wherein the pattern relates to a density of the media objects within the spatial region.
  • 39. The computer program product of claim 37, wherein selecting the subset is further based upon a social aspect relating to the user.
  • 40. The computer program product of claim 37, wherein selecting the subset is further based upon a temporal aspect of the media objects.
  • 41. The computer program product of claim 37, wherein selecting the subset is further based on a visual feature of the media objects.
  • 42. The computer program product of claim 37, wherein selecting the subset is further based on data associated with the media objects.
  • 43. The computer program product of claim 42, wherein the data comprises a user generated tag.
  • 44. The computer program product of claim 37, wherein the subset is selected in response to a search query, the search query on an object having a spatial aspect.
  • 45. A computer program product comprising computer-executable program code for summarizing a collection of media objects, the product comprising program code for: clustering a plurality of media objects according to a cluster structure, the cluster structure having a plurality of subclusters;ranking the media objects of the plurality of subclusters; andselecting a subset of the media objects based on the ranking of the media objects.
  • 46. The computer program product of claim 45, further comprising program code for clustering the media objects based on geographical locations associated with the media objects.
  • 47. The computer program product of claim 45, wherein the displayed media objects have a geographical reference associated therewith, the program code further for displaying the subset of the media objects with a map according to the geographic references.
  • 48. The computer program product of claim 45, further comprising program code for scoring each subcluster according to at least one metadata attribute of the subclusters.
  • 49. The computer program product of claim 48, wherein the at least one metadata attribute comprises at least one of the group consisting of: bias, tag-distinguishability, photographer-distinguishability, density, and the sum of image qualities of the cluster.
  • 50. The computer program product of claim 45, wherein selecting the subset of the media objects is based on a zoom level.
  • 51. The computer program product of claim 45, further comprising program code for displaying tags with a map based on the selected subset.