EP2599016A1 - Automatic media sharing via shutter click - Google Patents

Automatic media sharing via shutter click

Info

Publication number
EP2599016A1
EP2599016A1 EP11741726.1A EP11741726A EP2599016A1 EP 2599016 A1 EP2599016 A1 EP 2599016A1 EP 11741726 A EP11741726 A EP 11741726A EP 2599016 A1 EP2599016 A1 EP 2599016A1
Authority
EP
European Patent Office
Prior art keywords
images
collection
content data
media
user
Prior art date
Legal status (The legal status 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 status listed.)
Ceased
Application number
EP11741726.1A
Other languages
German (de)
French (fr)
Inventor
Keith Shoji Kiyohara
Henry Benjamin
Darren Delaye
Ping Hsin Chen
Simon Han
Kevin Smilak
Brian Axe
Hyduke Noshadi
Kedar Kanitkar
Evan Tsang
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Google LLC
Original Assignee
Google LLC
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 Google LLC filed Critical Google LLC
Publication of EP2599016A1 publication Critical patent/EP2599016A1/en
Ceased legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/50Information retrieval; Database structures therefor; File system structures therefor of still image data
    • G06F16/58Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
    • G06F16/583Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually using metadata automatically derived from the content
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q50/00Systems or methods specially adapted for specific business sectors, e.g. utilities or tourism
    • G06Q50/10Services
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/40Information retrieval; Database structures therefor; File system structures therefor of multimedia data, e.g. slideshows comprising image and additional audio data
    • G06F16/43Querying
    • G06F16/435Filtering based on additional data, e.g. user or group profiles
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/50Information retrieval; Database structures therefor; File system structures therefor of still image data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources

Definitions

  • This disclosure relates generally to the field of digital media, including photos and video, and more particularly to the sharing of digital media between users.
  • the sharing of digital media typically involves a user uploading media to a media sharing web site such as, for example, Picasa and Picasa Web Albums, using a browser or other application running on the user's computing device.
  • the media is stored at a remote web server operated by the web site and later accessed by other users, with whom the user has chosen to share the media.
  • searching for particular images to share with certain users becomes cumbersome.
  • Embodiments relate to a computer-implemented method for automatically sharing media.
  • a first collection of images and a second collection of images associated with a first user and a second user, respectively are received.
  • the first collection of images contains first content data and the second collection of images contains second content data.
  • the first and second users are associated with each other.
  • the first and second collections are automatically grouped, without user intervention, into an event group according to the first and second content data.
  • the first and second users are then automatically provided, without user intervention, access to the event group.
  • the event group may be automatically updated with one or more new images associated with at least one of the first and second users, and the first and second users may be automatically provided access to the updated event group.
  • a system for automatically sharing media includes at least one memory, a media input module, and a media sharing module.
  • the media input module and the media sharing module are located in the at least one memory.
  • the media input module is configured to receive a first collection of images associated with a first user and a second collection of images associated with a second user, where the first collection contains first content data and the second collection contains second content data.
  • the first and second users are associated with each other.
  • the media sharing module is configured to automatically group, without user intervention, the first and second collections into an event group according to the first and second content data.
  • the media sharing module is further configured to automatically provide, without user intervention, the first and second users access to the event group.
  • the event group may be automatically updated by the media sharing module with one or more new images associated with at least one of the first and second users, and the first and second users may be automatically provided access to the updated event group.
  • Embodiments may be implemented using hardware, firmware, software, or a combination thereof and may be implemented in one or more computer systems or other processing systems.
  • FIG. 1 is a diagram of an exemplary system in which embodiments may be implemented.
  • FIG. 2 is a diagram of an example of a client application in accordance with an embodiment.
  • FIG. 3 is a diagram of an example of a system in which a media sharing service may be implemented in accordance with an embodiment.
  • FIG. 4 A is a flowchart of an example of a method for automatically sharing media between users in accordance with an embodiment.
  • FIG. 4B is a flowchart of an example of a method for updating an event group with one or more new images in accordance with an embodiment.
  • FIG. 5 is a flowchart of an example of a method for capturing and sending media using a client application in accordance with an embodiment.
  • FIG. 6 is a flowchart of an example of a method for grouping images into albums in accordance with an embodiment.
  • FIG. 7 is a flowchart of an example of a method for grouping albums into event groups in accordance with an embodiment.
  • FIG. 8 is a diagram of an example of a computer system in which embodiments can be implemented.
  • tags include one or more keywords that describe the content of the image.
  • organization schemes involving user- provided tags do not scale well for large image collections from diverse sources. For example, users may fail to consistently and/or accurately tag all available images, and there may be differences in tags provided by different users for the same image.
  • significant user input is required to tag a large number of images and consequently, users are unlikely to tag all of the available images.
  • To share a group of images each user must manually organize, tag, and upload a group of images to a media sharing web site. Moreover, this is particularly difficult for mobile phone users for whom data entry is cumbersome or for users who do not have the time to organize and enter descriptive data for media they wish to share.
  • media sharing sites generally do not provide the capability to automatically group images from multiple users. For example, a user may wish to share images taken at an event with other attendees of the event. Similarly, other attendees may wish to share their images from the event with the user. Although two or more users may be able to create a collaborative album or image collection that contains images from multiple users, the creation and update of such an album or image collection is still a manual process for the users.
  • Embodiments relate to automatically sharing media between users. Embodiments automatically group, without user intervention, digital media, including photos and video, associated with a user into one or more albums based on the content of the media objects.
  • embodiments automatically group, without user intervention, albums from multiple users into one or more event groups based on the content of the albums.
  • the automatically generated event group(s) may then be shared between multiple users depending on the users' associations with each other and their individual sharing preferences.
  • Embodiments also enable the event group(s) to be updated with new images and automatically share the update event group(s) between the users.
  • a first user and a second user may belong to a social network in which each user allows the other access to each other's digital media collection, including photos and videos.
  • the first and second users may capture photos from a particular event they both attend.
  • Each user may store event photos along with other unrelated photos.
  • Embodiments automatically determine the content of the photos associated with each user, group the photos corresponding to the event into an event group, and share the event group, including any new event photos, between the users.
  • Embodiments may use a number of different techniques including, but not limited to, face recognition, landmark recognition, and scene or object recognition to determine the content of media.
  • Embodiments may also extract metadata from media to determine its content.
  • references to "one embodiment,” “an embodiment,” “an example embodiment,” etc. indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
  • the terms “media” and “digital media” are used interchangeably herein to refer broadly and inclusively to digital photographs, or digital photos, and digital video.
  • image is used herein to refer broadly and inclusively to a digital photograph depicting an image of a scene and items within that scene, including, but not limited to, one or more persons, one or more landmarks, and/or one or more objects.
  • image(s) may refer to one or more frames from at least a portion of a digital video.
  • the terms “photograph/photo,” “video,” “media,” and “image” are used herein to refer to digital photos and digital video whether or not the terms are modified by the term "digital.”
  • media sharing site is used herein to refer broadly and inclusively to any web site, service, framework, or protocol adapted to share digital media, including photos and videos, between various users. Such a web site or service may also include social networking sites with the added capability to share media between members of the site.
  • image capture device and “image capturing device” are used interchangeably herein to refer broadly and inclusively to any device adapted to capture digital media, including photos and videos. Examples of such devices include, but are not limited to, digital cameras, mobile devices with an integrated digital camera. Furthermore, it is assumed herein that images are captured using such a device by manually pressing, selecting, or clicking a button or key that opens a shutter device for image exposure purposes. However, it should be noted the term “shutter” is used herein to also refer broadly and inclusively to any type of button or key on the image capture device that is used to capture the image (i.e., by invoking the shutter device).
  • FIG. 1 is a diagram illustrating a system 100 in which embodiments described herein can be implemented.
  • System 100 includes client devices 1 10 and 1 lOA-C, a client application 1 12, device input 114, local memory 116, a browser 1 15, a media viewer 118, media 120, notifications 130, a network 140, servers 150, 160, and 170, a media sharing service 152, and a database 180.
  • Client devices 110, 110A, HOB, and 1 IOC communicate with one or more servers
  • Client device 110 is communicatively coupled to network 140 through a communications interface.
  • Client device 1 10 can be any type of computing device having one or more processors and a communications infrastructure capable of receiving and transmitting data over a network.
  • Client device 110 also includes device input 114.
  • Device input 1 14 may be any kind of user input device coupled to client device 110 including, but not limited to, a mouse, QWERTY keyboard, touch-screen, microphone, or a T9 keyboard.
  • Client device 110 can include, but is not limited to, a mobile phone, a personal digital assistant (PDA), a computer, a cluster of computers, a set-top box, or other similar type of device capable of processing instructions and receiving and transmitting data to and from humans and other computing devices.
  • PDA personal digital assistant
  • Client device 110 can include, but is not limited to, a mobile phone, a personal digital assistant (PDA), a computer, a cluster of computers, a set-top box, or other similar type of device capable of processing instructions and receiving and transmitting data to and from humans and other computing devices.
  • PDA personal digital assistant
  • Server(s) 150 similarly, can be any type of computing device capable of serving data to client device 110.
  • Server(s) 150 execute media sharing service 152.
  • media sharing service 152 is shown with respect to server 150, media sharing service 152 may be implemented on any server.
  • the functionality of media sharing service 152 may be implemented on a single server, such as, for example, server 150, or across multiple servers, such as, for example, servers 150, 160, and 170, in a distributed or clustered server environment.
  • server(s) 150 are communicatively coupled to database 180.
  • Database 180 may be any type of data storage known to those of skill in the art.
  • the data storage may be a database management system, such as an ORACLE database or other databases known to those skilled in the art.
  • Database 180 may store any type of media and any corresponding media data accessible by server(s) 150. Although only database 180 is shown, more databases may be used as necessary.
  • local memory 1 16 is used to store information accessible by client device 110.
  • information stored in local memory 116 may include, but is not limited to, one or more digital media files, contact information for one or more users, or any other type of information in a digital format.
  • Local memory 1 16 may be any type of recording medium coupled to an integrated circuit that controls access to the recording medium.
  • the recording medium can be, for example and without limitation, a semiconductor memory, a hard disk, or other similar type of memory or storage device.
  • local memory 1 16 may be integrated within client device 1 10 or may be a stand-alone device communicatively coupled to client device 1 10 via a direct connection.
  • local memory 116 may include an internal memory device of client device 110, a compact flash card, a secure digital (SD) flash memory card, or other similar type of memory device.
  • SD secure digital
  • Network 140 can be any network or combination of networks that can carry data communication.
  • Such network 140 can include, but is not limited to, a wired (e.g., Ethernet) or a wireless (e.g., Wi-Fi and 3G) network.
  • network 140 can include, but is not limited to, a local area network, medium area network, and/or wide area network such as the Internet.
  • Network 140 can support protocols and technology including, but not limited to, Internet or World Wide Web protocols and/or services.
  • Intermediate network routers, gateways, or servers may be provided between components of system 100 depending upon a particular application or environment.
  • client devices 1 10 and 1 lOA-C execute client application 1 12.
  • client devices 110 and 1 lOA-C execute media viewer 118.
  • the operation of client application 112 and media viewer 118 are described in further detail below.
  • Client application 112 and media viewer 118 may be implemented on any type of computing device.
  • Such computing device can include, but is not limited to, a personal computer, mobile device such as a mobile phone, workstation, embedded system, game console, television, set-top box, or any other computing device.
  • a computing device can include, but is not limited to, a device having a processor and memory for executing and storing instructions.
  • Software may include one or more applications and an operating system.
  • Hardware can include, but is not limited to, a processor, memory and graphical user interface display.
  • the computing device may also have multiple processors and multiple shared or separate memory components.
  • the computing device may be a clustered computing environment or server farm.
  • client device 110 via client application
  • media viewer 118 may send or receive media data 120 to or from media sharing service 152 on server(s) 150.
  • Media data 120 includes one or more media files.
  • the media files may be photos, video, or a combination of both.
  • the media files may include media content information and metadata corresponding to the media to be sent or retrieved.
  • Client application 112 and media viewer 118 may present a visual representation of the retrieved media on a display of client device 1 10.
  • Such a display can be any type of display for viewing digital photos and/or video or can be any type of rendering device adapted to view digital photos and/or video.
  • media viewer 118 can be a standalone application, or it can be executed within a browser 115, such as, for example, Google Chrome or Microsoft Internet Explorer.
  • Media viewer 118 for example, can be executed as a script within browser 115, as a plug-in within browser 1 15, or as a program, which executes within a browser plug-in, such as, for example, the Adobe (Macromedia) Flash plug-in.
  • client application 1 12 and/or media viewer 118 are integrated with media sharing service 152.
  • client device 110 is also configured to receive notifications
  • notifications 130 include an access link to a location on the web where the media to be shared is stored.
  • the access link may include a location to a web site in the form of a web location address such as a uniform resource locator (URL).
  • Notifications 130 may be sent from media sharing service 152 to client device 110 using any of a number of different protocols and methods.
  • notifications 130 may be sent from media sharing service 152 via electronic mail or Short Message Service (SMS).
  • SMS Short Message Service
  • Notifications 130 may be received at client device 110 by client application 1 12, media viewer 118, or any other application or utility adapted to receive such notifications, such as, for example, an electronic mail client or SMS application.
  • FIG. 2 is a diagram illustrating an exemplary embodiment of client application
  • Client application 112 includes image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250.
  • client application 1 12 uses user interface module 240 to display an option to a user at client device 110 to capture a digital image.
  • client application 112 uses image capture module 210 to capture the digital photo or video.
  • image capture module 210 can be coupled to an image capture device (not shown), such as, for example, a digital camera integrated with client device 110.
  • user interface module 240 can be coupled to a user input device, such as, for example, a touch screen or input button at client device 1 10 (e.g., device input 1 14).
  • client device 1 10 e.g., device input 1 14
  • Face detection module 220 can be configured to analyze media after it is captured by image capture module 210. In an embodiment, face detection module 220 can also analyze media previously captured and stored at client device 1 10. Such stored media may have been captured using the image capturing device at 110 (e.g., by image capture module 210 or another application executed at client device 110) or may have been captured using a separate image capturing device not coupled to client device 110 and later transferred to local memory 116. Face detection module 220 can be configured to analyze one or more images, or images specified by a user, to detect faces within the image(s). For example, if a user transfers an album of digital photos to local memory 1 16, face detection module 220 can analyze each digital photo in that album to detect faces.
  • face detection module 220 can make a digital copy of an area encompassing the detected face, for example, a rectangular area encompassing the detected face, to produce a facial image or facial model corresponding to the detected face.
  • the facial image can then be stored in local memory 116.
  • the facial image can be stored in a facial image database (not shown), which is accessible by client application 1 12 via a network (e.g., network 140).
  • face detection module 220 can use stored facial images to aid in detecting faces in subsequently analyzed images.
  • face detection module 220 may be used in face detection module 220 to detect faces in images.
  • examples of such techniques include, but are not limited to, elastic bunch graph matching as described in U.S. Patent No. 6,222,939, using neural networks on "gabor jets" as described in U.S. Patent No. 6,917,703, and face detection using boosted primitive features as described in U.S. Patent No. 7,099,510.
  • the automatic face detection of face detection module 220 may not detect all faces in an image. Therefore, in some embodiments, the user may trigger face detection module 220 specifically to process a specified image. For example, face detection module 220 may not detect one or more faces in an image. In this case, in an embodiment, face detection module 220 provides the capability for the user to manually assist the face detection process. For example, user interface module 210 may present a graphical user interface to draw a bounding area, or a bounding box, around each face that the user wants detected.
  • the same facial detection technique may be used in the automatic face detection as well as the manually-assisted face detection with slight modifications. For example, when manually assisted, the face detection software may simply attach a greater weight to facial landmark features identified within the defined area.
  • user interface module 240 may display one or more user input fields, which the user can use to provide additional descriptive data to identify the person corresponding to the detected face. For example, the user can provide a name with which to tag the detected facial image. The tag can later be used to identify the person in other images.
  • the descriptive data may also include, but is not limited to, contact information for the identified person.
  • Metadata insertion module 230 can be configured to associate or annotate the image with the detected face information (e.g., facial images produced by face detection module 220) in addition to any user-provided information including, but not limited to, tag name(s) for the identified person(s), contact information for each identified person(s), and/or image caption or description information.
  • face information e.g., facial images produced by face detection module 220
  • tag name(s) for the identified person(s) e.g., contact information for each identified person(s)
  • image caption or description information e.g., image caption or description information
  • face detection module 220 may use stored facial images to identify the detected face(s).
  • the facial images may be stored in local memory 116 or in a facial database accessible by client application 1 12 over network 140.
  • a facial database can be any kind of database adapted to store facial images in addition to metadata, including name and/or contact information of the person corresponding to each facial image.
  • the stored facial image can also include metadata of its own, including identification information for the identity of the person corresponding to the facial image.
  • the identification information may include a name and contact information.
  • the user would no longer be required to provide identification information for the detected face.
  • metadata insertion module 230 can associate detected face information and the corresponding identification information without further user intervention.
  • face detection module 220 may need to be configured with additional face recognition functionality in order to match the detected faces with stored facial images or facial models. Such face recognition functionality would operate similarly to that of face recognition module 332 of media sharing service 152 of FIG. 3, described below.
  • metadata insertion module 230 may also associate with the image(s) other metadata including, but not limited to, a time when the image(s) was taken and a location where the image(s) was taken.
  • client device 110 may include a global positioning satellite (GPS) receiver and metadata insertion module 230 may be configured to associate with the image(s) a location where the image(s) was taken in addition to any other information.
  • GPS global positioning satellite
  • the location of an image may include latitude and longitude coordinates corresponding to a geographic location where the image was captured.
  • image transfer module 250 transfers one or more images from client device 110 to media sharing service 152 of server(s) 150, shown in FIG. 1, over network 140.
  • the transferred image(s) includes metadata information associated with the image(s) by metadata insertion module 230.
  • Image transfer module 250 is configured to transfer the image(s) via a communications interface of client device 1 10.
  • the image(s) may be transferred by image transfer module 250 using any number of well-known methods for transferring digital files between client device 110 and media sharing service 152 over network 140.
  • Embodiments of image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250 can be implemented in software, firmware, hardware, or any combination thereof.
  • Embodiments of image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250, or portions thereof, can also be implemented as computer-readable code executed on one or more computing devices capable of carrying out the functionality described herein. Examples of such computing devices include, but are not limited to, a computer, workstation, embedded system, networked device, mobile device, or other type of processor or computer system capable of carrying out the functionality described herein.
  • image capture module 210 face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250 shown to be within client application 1 12, represent functionality in implementing embodiments of the present disclosure.
  • One skilled in the art will understand that, more or fewer modules than shown in client application 112 may be implemented in software to achieve the functionality of the present disclosure.
  • FIG. 3 is a diagram illustrating an embodiment of an exemplary system 300 in which media sharing service 152 may be implemented.
  • System 300 includes a client device 310, a media database 320, media sharing service 152 of FIG. 1, an album database 350, an event database 360, and a social graph database 370.
  • Media sharing service 152 includes various component modules including a media input module 330 and a media sharing module 340.
  • Media input module 330 includes a face recognition module 332, a landmark recognition module 334, an object recognition module 336, and a metadata extractor module 338.
  • Media database 320 may store any type of media data such as photograph or video data.
  • the images may, for example, be photographs taken from a digital camera.
  • the images may be encoded in JPEG, TIFF, or other similar format for digital image files.
  • Each image may have metadata associated with the image.
  • an image may have an exchangeable image file format (EXIF) header that stores information such as a time when the photograph of the image was taken, a location where the photo was taken, and information about the image capturing device, such as, for example, a digital camera, that captured the image, such as make, model, focal length and zoom.
  • the time the image was taken may correspond to the time in which the image was exposed by the image capturing device.
  • a video includes a sequence of frames, and each frame includes an image. The video may also be captured using an image capturing device able to capture video, such as, for example, a digital camera.
  • media database 320 may be coupled to a media sharing site (not shown), such as Picasa.
  • a user may upload the media from the media sharing site to media database 320.
  • the user may use browser 115 at client device 110 to navigate to the media sharing site and upload images to media database 320 via a user interface provided by the media sharing site.
  • the user may also be able to retrieve images from media database 320.
  • the user may have a choice to either download images onto client 110 for storage in local memory 1 16 or view the images using media viewer 118, which may also be coupled to the media sharing site.
  • Media data 301 is retrieved from media database 320 by media input module
  • Media input module 330 may retrieve media data 301 from media database 320 using, for example, an SQL select statement. Alternatively, media input module 330 could access media database 320 using a web service. Media database 320 may have one or more intermediate servers that may push media data 301 to media input module 330.
  • media data 301 may include one or more image files.
  • the image files may be photographs ⁇ frames from one or more videos, or a combination of both.
  • the image files may include image content and metadata, such as, for example, metadata information added by metadata insertion module 230 of client application 112, illustrated in FIG. 2.
  • Media input module 330 may also receive media data 120 over network 140 from one or more of client device 110 via communication channel 302, client device 1 10A via communication channel 304, and/or client device 310 via communication channel 303. Although only client device 110, client device 11 OA, and client device 310 are shown, additional client devices may be used as necessary.
  • Client device 310 may include any image capturing device with the capability to send captured images to server(s) 150, including media sharing service 152, over network 140.
  • client device 310 may be a standalone digital camera including, but not limited to, digital camera with an EYE-FI SD card, which provides the capability to store images and directly upload stored images to a media sharing site.
  • media input module 330 Upon receiving media data 120 and/or retrieving media data 301, media input module 330 sends media data 120 and/or media data 301 to face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338.
  • Face recognition module 332 interprets the content of media data 120 and/or media data 301 (hereinafter collectively referred to as "media data 120/301 ”) by performing automatic face recognition to recognize one or more faces.
  • the automatic face recognition of face recognition module 332 may function in two stages: a face detection stage and a face recognition stage. However, face recognition module 332 may be able to skip the face detection stage for media data 120/301 if face detection information is already included with media data 120/301. For example, the image may have been sent by client application 112 of client device 110, which already performs face detection and includes the face detection information with the image file.
  • the face detection stage of face recognition module 332 includes automatically detecting faces in images of media data 120/301. Such automatic detection may be based on, for example, general facial characteristics. Face recognition module 332 analyzes the images to detect faces within the images. When one or more faces are detected, face recognition module 332 may generate face detection information corresponding to each detected face including, for example, a bounded region encompassing the detected face within the image. In an embodiment, face recognition module 332 may enable a user to manually assist face detection, for example, through client application 112 and/or media viewer 1 18. In such an embodiment, the operation of the face detection stage is similar to the manual or user assisted operation of face detection module 220 of FIG. 2, described above.
  • the face recognition stage of face recognition module 332 includes identifying the detected faces.
  • the operation of face recognition module 332 may include making comparisons of detected faces against one or more of facial images that have been previously recognized.
  • the previously recognized faces may be stored in one or more facial image databases (not shown) accessible by face recognition module 332.
  • face recognition module 332 A person skilled in the relevant art given this description would appreciate that any one of several methods for face detection and recognition may be used. One example of such a method is described in Lui and Chen, "Video-based Face Recognition Using Adaptive Hidden Markov Models", 2001, CVPR.
  • Landmark recognition module 334 detects portions of images of media data
  • Landmark recognition module 334 may, for example, use visual clustering to recognize landmarks.
  • Object recognition module 336 interprets images of media data 120/301 to recognize objects within a scene represented by the images.
  • media data 120/301 may include an image of a scene, and object recognition module 336 may recognize an object in that image.
  • object recognition module 336 may recognize an object in one or more frames of a video.
  • Object recognition module 336 may be any type of object recognition module as known to those skilled in the art.
  • the operation of object recognition module 336 like face recognition module 332, may include two steps. First, a portion of an image including an object is detected. Second, the portion of the image is put through a function, such as a classifier function, that identifies the object.
  • object recognition module 336 may include additional subcomponents, including other recognition modules, configured to detect different types of objects.
  • object recognition module 120 may use hidden Markov models to select and match particular objects to an object in a set of known objects.
  • object recognition module 120 may track an object across one or more frames and then recognize the object based on the tracked frames.
  • media input module 330 determines media content data 306.
  • Media content data 306 may include, for example, a collection of media and meta-information of faces, landmarks, and/or objects corresponding to the content of the collection of media.
  • media input module 330 may extract metadata directly from media data 120/301 using metadata extractor module 338, according to an embodiment.
  • Metadata extractor module 338 may, for example, extract metadata included with media data 120/301.
  • Media data 120/301 may be, for example, a collection of media files, and each media file may include metadata, as described above.
  • a media file may be a photographic image file, such as a JPEG or TIFF.
  • the photographic image file may include an EXIF header with data about the image.
  • An EXIF header may, for example, include data such as when the photo was taken.
  • client device 310 may include a location sensor, such as a GPS sensor.
  • Image files generated by client device 310 may include a location where each photo was taken in their EXIF headers.
  • the EXIF header may have latitude and longitude values corresponding to where the picture was taken. In this way.
  • metadata extractor module 338 reads metadata from media data 120/301 to be included with media content data 306.
  • Embodiments of face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338 can be implemented in software, firmware, hardware, or any combination thereof. Embodiments of face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338, or portions thereof, can also be implemented to run on any type of processing device including, but not limited to, a computer, workstation, embedded system, networked device, mobile device, or other type of processor or computer system capable of carrying out the functionality described herein.
  • media sharing module 340 automatically groups the collection of media from different users and shares the grouped media between the users based on the content of the media and the associations between the users. For example, media input module 330 may receive or acquire different images, perhaps whole albums of images, where each image and/or album is associated with a different user.
  • the users themselves may be associated with each other, for example, as members of the same social network or social graph in which the users are linked or associated with each other via sharing preferences designated, for example, on a social networking site.
  • each user may have member profile information stored at the social networking site.
  • each user's profile may have a sharing preference that specifies the media sharing or access rights and privileges the user provides to other users.
  • the sharing preference may be used to identify other users with whom the user chooses to share media. For example, the sharing preference of a first user may identify a second user, where the first and second users are associated with each other.
  • users associated with each other provide media sharing privileges to one another, in which each user is allowed access to images associated with the other user.
  • users associated with each other may identify one another via their sharing preferences.
  • a person skilled in the relevant art given this description would recognize any number of known methods for associating sharing preferences with a user and for associating different users with each other. a. Album Segmentation
  • Media sharing module 340 automatically interprets media content data 306 to group images associated with each individual user into one or more albums for the user. Media sharing module 340 then automatically interprets media content data 306 to group albums corresponding to different users into one or more event groups, where the event group includes media associated with the different users. Media sharing module 340 then automatically shares, without user intervention, the event group(s) between the different users based on their social graph or association with each other. In an embodiment, media sharing module 340 also sends notifications of the available event group(s) to the users.
  • Media sharing module 340 includes an album segmentation module 342, an event clustering module 344, a sharing manager 346, and a notification manager 348.
  • media sharing module 340 is communicatively coupled to each of album database 350, event database 360, and social graph database 370 via communication lines 307, 308, and 309 respectively.
  • Album segmentation module 342 segments the collection of media from media input module 330 by grouping the collection of media into one or more albums based on the media content data information included in media content data 306.
  • Album segmentation module 342 determines the media content data corresponding to each image of the collection of media using media content data 306. Based on the determined media content data of each image, album segmentation module 342 segments the collection of media into one or more albums.
  • media content data 306 may include the time and location (e.g., in
  • album segmentation module 342 Based on the determined time and location of each image of the collection, album segmentation module 342 would segment the collection or group of images into one or more albums in which each album contains images having substantially similar time and location information. To improve the accuracy of the segmentation operation and the correlation of content between different images in a segmented album, album segmentation module 342 segments the collection of media based on as much information it can derive from media content data 306. For example, album segmentation module 342 may use face recognition information, landmark recognition information, object recognition information, metadata, or any combination thereof to segment the collection of images into an album(s).
  • album segmentation module 342 may search album database
  • album segmentation module 342 may find an existing album in album database 350 containing images having substantially similar time and location information as the image(s) from media input module 330. In this example, album segmentation module 342 would add the image(s) to the existing album. If no existing album is found that matches the search criteria (e.g., images with similar media content data), album segmentation module 342 may create one or more new albums. In an embodiment, album segmentation module 342 may use album database 350 to store the new album(s). Album segmenting module 342 associates each album with the user associated with the group of images. b. Event Clustering and Sharing
  • Event clustering module 344 clusters the albums, segmented by album segmenting module 342, by grouping the albums into one or more event groups based on the media content data information included in media content data 306 and sharing preferences associated with two or more users.
  • the clustering operation of event clustering module 344 is similar to the segmenting operation of album segmenting module 342, except that even clustering module 344 groups albums, where different albums are associated with different users.
  • different users may be associated with each other via sharing preferences that identify one another. Also as discussed above, such preferences are used to determine which users have privileges to access media associated with a particular user.
  • Event clustering module 344 uses sharing manager 346 to determine sharing preferences and associations between different users.
  • sharing manager 346 is communicatively coupled with social graph database 370.
  • Social graph database 370 may store any type of association between two or more users who have a social relationship with each other. Such association may include sharing preferences of the users, where the sharing preferences specify access rights or privileges each user has with the other.
  • Embodiments of sharing manager 346 and social graph database 370 may be integrated, for example, with one or more social networking sites, photo sharing sites, or other similar types of sites that enable associations or social connections between different users.
  • sharing manager 346 retrieves stored associations between two or more users, including the users' sharing preferences, from social graph database 370. The retrieved information regarding the users in combination with media content data 306 is used by event clustering module 344 to cluster albums into one or more event groups. Once the event group(s) is clustered by event clustering module 344, sharing manager 346 associates the event group(s) with the users and provides the users with access to the event group(s) based on the association of the users with each other and each user's individual sharing preference. In an embodiment, event database 360 may be used to store the association of users with event groups.
  • a first album of images captured at a particular time and location, corresponding to a social event may be associated with a first user.
  • a second album of images captured at the same time and location, i.e., event may be associated with a second user.
  • clustering module 344 may use sharing manager 346 to determine which the associations and sharing preferences of the users. If sharing manager 346 identifies an association between the first and second users and each user's sharing preference provides sharing privileges to the other, event clustering module 344 may, for example, cluster the first and second albums into an event group of images captured at the same time and location. The event group in this example would contain images associated with both users.
  • clustering module 344 may store the event group in event database 360. Sharing manager 346 may then provide the first and second users with access to the event group.
  • notification manager 348 is configured to automatically send notifications (e.g., notifications 130 of FIG. 1) to one or more users of the event group.
  • the notification includes an access link to the event group.
  • the access link may be web-based location address in the form of a uniform resource locator (URL) address, which users can select to be automatically directed to the event group.
  • URL uniform resource locator
  • the images of the event group may be accessible, for example, via client application 112, media viewer 118, or similar type of application the user can use to view media.
  • event clustering module 344 may search event database 360 for existing event groups to add a newly clustered event group based on substantially similar content data. Event clustering module 344 may add the clustered event group to a matching event group if found in event database 360. Alternatively, event clustering module 344 may create a new event group in event database 360 for the clustered event group if a matching event group is not found in event database 360. c. Real-time Event Sharing
  • sharing manager 346 may automatically enable real-time access and sharing to an event group based on the content information of media content data 306. For example, sharing manager 346 may use time and location metadata determined from media content data 306 in combination with social graph information from social graph database 370 to enable real-time access and sharing to an event group based on the time, location, and social graph information.
  • Event clustering module 344 may, for example, automatically generate an event group for the event based on the content of media captured during the event by the first and second users.
  • Media content data 306 may include, for example, the time and location of when and where the images were captured.
  • sharing manager 346 may determine that the first and second users are associated with each other and have matching sharing preferences (e.g., the first user allows media sharing privileges for the second user and vice versa).
  • sharing manager 346 would determine both users are at the same event and consequently, begin to automatically associate the first and second users with the event group and provide the users access to the event group.
  • Notification manager 348 may, for example, send notifications, including an access link to the event group, to the first and second users.
  • the first and second users may receive the notifications on, for example, their respective mobile devices.
  • the first and second users would then be able to view the images of the event group using, for example, their respective mobile devices (e.g., in client application 112 or media viewer 118 of FIG. 1). This enables the first and second users to automatically and efficiently share media between each other during the event.
  • Embodiments of album segmentation module 342, event clustering module 344, sharing manager 346, and notification manager 348 can be implemented in software, firmware, hardware, or any combination thereof. Embodiments of album segmentation module 342, event clustering module 344, sharing manager 346, and notification manager 348, or portions thereof, can also be implemented to run on any type of processing device including, but not limited to, a computer, workstation, embedded system, networked device, mobile device, or other type of processor or computer system capable of carrying out the functionality described herein.
  • Album database 350, event database 360, and social graph database 370 may be any type of data storage known to those of skill in the art.
  • the data storage may be a database management system, such as an ORACLE database or other databases known to those skilled in the art.
  • Album database 350 and event database 360 may store any type of media such as images or video (e.g., organized into albums or event groups respectively) in addition to meta-information, including metadata and other content information, corresponding to the images or video.
  • media sharing service 152 is shown with respect to server(s) 150, it should be noted that embodiments of media sharing service 152 and its components (media input module 330 and media sharing module 340), or portions thereof, can be implemented on a single server, such as, for example, server 150, or across multiple servers, such as, for example, servers 150, 160, and 170, in a distributed or clustered server environment. Furthermore, subcomponents of media input module 330 (face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338), or portions thereof, can be implemented on a single server or across multiple servers. Similarly, subcomponents of media sharing module 340 (album segmentation module 342, event clustering module 344, sharing manager 346, and notification manager 348), ox portions thereof, can be implemented on a single server or across multiple servers. III.
  • FIGS. 4 A and 4B are process flowcharts of a method 400 for automatically sharing media between users.
  • Method 400 includes steps 402, 404, 406, 408, 410, 412. 414, 416, 418, 420, 422, 424, and 426.
  • Benefits of method 400 include, but are not limited to, a faster, more efficient, and automated way for users to share media between one another.
  • method 400 alleviates the burden for users of having to manually group images into albums, add descriptors to the album (e.g., album titles), and share the albums with other users.
  • method 400 may he performed, for example, by server(s) 150 via media sharing service 152.
  • Method 400 begins in step 402 of FIG. 4A and proceeds to step 404, which includes receiving a first collection of Images associated with a first user.
  • Step 404 may be performed, for example, by media Input module 330.
  • the first collection of images may be received directly from the first user via the first user's client device, such as, for example, client device 110.
  • the first collection may be stored for later retrieval in one or more media databases, such as, for example, media database 320.
  • the first collection of images may have been previously uploaded by the first user via, for example, a photo sharing site to which media database 320 may be coupled, as described above.
  • the images of the first collection may be digital photos, frames from a digital video, or any combination thereof.
  • Step 406 includes determining a first content data for each image in the first collection.
  • Step 406 may be performed, for example, by face recognition module 332, landmark recognition module 334, object recognition module 336, media extractor module 338, or any combination thereof.
  • the first content data may include information comprising recognized faces, landmarks, and/or objects within the first collection of images.
  • the first content data may additionally include metadata extracted from the first collection including, but not limited to, the time and. location of when and where the images were captured.
  • Step 408 includes segmenting the first collection into a first set of one or more albums.
  • Step 408 may he performed, for example, by album segmentation module 342 of media sharing module 340.
  • the first collection is segmented based on the determined first content data in step 406.
  • Steps 410, 412, and 414 of method 400 are similar to above-described steps 404,
  • steps 410, 412, and 414 correspond to a second collection of images associated with a second user.
  • a second collection of images associated with the second user is received.
  • the second collection may be received directly from second user or accessed from a media database, such as, for example, media database 320.
  • Step 410 may also be performed, for example by media input module 330.
  • a second content data for each image in the second collection is determined.
  • Step 412 may be performed, for example, by face recognition module 332, landmark recognition module 334, object recognition module 336, media extractor module 338, or any combination thereof.
  • the second collection is segmented into a second set of one or more albums based on the second content data.
  • Step 414 may be performed, for example, by album segmentation module 342.
  • the first and second sets of one or more albums are associated with the first and second users, respectively.
  • the first and second users may also be associated with each other.
  • the first and second users may have first and second sharing preferences, respectively.
  • the sharing preference of each user identifies the media sharing rights and privileges the user provides to the other user.
  • the first user may have a sharing preference that allows sharing media with the second user by providing the second user access rights to media associated with the first user.
  • the second user may also have a similar sharing preference corresponding to the first user.
  • step 416 the first and second sets are clustered into an event group according to the first and second content data and sharing preferences of the first and second users. Step 416 may be performed, for example, by event clustering module 344 in combination with sharing manager 346.
  • step 418 includes providing the first and second users with access to the event group.
  • the first and second users may also be associated with the event group, according to an embodiment.
  • event group and any associations with first and second users may be stored, for example, by event clustering module 344 in event database 360 via communication line 308, as illustrated in FIG. 3.
  • Step 418 may be performed, for example, by sharing manager 346.
  • method 400 may also include an additional step (not shown), which includes sending a notification of the event group to the first and second users.
  • the notification may include an access link to the event group, as described above. This optional step may be performed, for example, by notification manager 348.
  • step 420 of FIG. 4B includes receiving one or more new images representing scenes from a particular event, to which the event group corresponds.
  • the event group created in step 416 may include images that were captured by the first and second users during a particular event.
  • the first and/or second users may send new images also captured from the event.
  • the new images may be sent by the first and/or second users from, for example, their mobile devices during the event or may be uploaded to, for example, a media sharing site after the event.
  • step 420 includes receiving the new images directly from one or both of the users.
  • step 420 includes accessing the uploaded images from a media database coupled to or integrated with the media sharing site.
  • the media database may be, for example, media database 320 of FIG. 3.
  • a first set of new images from the event may be received directly from the first user and a second set of new images from the event may have been uploaded by the second user to a media sharing site.
  • step 420 includes receiving new images directly and accessing new images from the media database. It should be noted that either user may choose to send images directly or upload images to a media sharing site. Step 420 may be performed, for example, by media input module 330 of FIG. 3.
  • step 422 may be performed, for example, by event clustering module 344.
  • step 424 may be performed, for example, by sharing manager 346.
  • method 400 may include an additional step (not shown) of sending the first and second users a notification of the updated event group. This step may be performed, for example, by notification manager 348. If no new images are received or accessed, method 400 concludes at step 426.
  • steps 420, 422 and 424 enable automatic media sharing between the first and second users via the click of a shutter.
  • the new image(s) received in step 420 may be from a user, who captured the image using an application (e.g., client application 1 12) executing on a computing device with an integrated digital camera (e.g., client device 110 of FIG. 3) or a standalone image capturing device, such as, for example, a digital camera with an EYE-FI card (e.g., client device 310 of FIG. 3).
  • an application e.g., client application 1 12
  • a computing device with an integrated digital camera e.g., client device 110 of FIG. 3
  • a standalone image capturing device such as, for example, a digital camera with an EYE-FI card (e.g., client device 310 of FIG. 3).
  • One advantage of method 400 is that it enables automatic sharing of media between users (in step 424) without requiring users to manually label and group images and collections of images. This leads to a faster, easier, and more efficient user experience for sharing media, which benefits the user who captures the media, by making it easier to share media. Furthermore, other users associated with the user are also benefited as it increases the likelihood that media captured by the user will be shared.
  • FIG. 5 is a flowchart of an embodiment of an exemplary method 500 for sending media using a client application.
  • client application 112 of FIG. 2 and system 300 of FIG. 3 will be used to facilitate the description of method 500.
  • method 500 will be described in the context of a mobile device (e.g., client device 1 10 of FIG. 1) with an integrated image capturing device, such as, for example, a digital camera.
  • an integrated image capturing device such as, for example, a digital camera.
  • method 500 can be integrated within other client applications that can be executed on any type of computing device having a camera or other image capturing device.
  • Method 500 includes steps 502, 504, 506, 508, 510, 512, 514, and 516.
  • step 500 begins in step 502 and proceeds to step 504, which involves capturing an image representing a scene with one or persons.
  • the image may be a digital photograph or one or more video frames of a digital video.
  • Step 504 may be performed, for example, by image capture module 210 (e.g., when a user clicks a shutter).
  • image capture module 210 e.g., when a user clicks a shutter.
  • method 500 can also use images already captured and stored in local memory (e.g., local memory 1 16 of client device 110).
  • step 506 the face of each person in the image is detected as described above.
  • Step 506 may be performed by face detection module 220, described above.
  • Method 500 then proceeds to step 508, which includes obtaining identification information for the face(s) detected.
  • obtaining identification information in step 508 includes enabling a user to identify the face(s) detected in the image.
  • the user may identify the face(s) by entering identification information for the person corresponding to the face.
  • identification information may include, but is not limited to, a name and/or contact information (e.g., an email address) of the person being identified.
  • the captured image may be displayed on a display coupled to the computing device (e.g., client device 110 of FIG. 1) executing the client application (e.g., client application 112).
  • the detected face(s) in the image may be shown on the display with a virtual box drawn around the face to demarcate the face(s).
  • the user may enter the name and contact information using a user input device, such as, for example, a touch screen or keyboard (e.g., device input 1 14).
  • This embodiment of step 508 may be performed, for example, by user interface module 240, described above.
  • obtaining identification infonnation in step 508 includes retrieving a stored facial image that matches each detected face from, for example, local memory (e.g., in local memory 116) accessible by client application 1 12, as described above.
  • the stored facial image may be retrieved in step 508 from a remote location such as a facial image database (not shown), which can be accessible, for example, by client application 112 over network 140.
  • the stored facial image can also include metadata of its own, including identification information for the identity of the person corresponding to the facial image.
  • the identification information may include a name and contact information.
  • step 508 would no longer require the user to provide the identification information for the detected face.
  • step 508 may be performed, for example, by face detection module 220 in combination with a face recognition module, such as, for example, face recognition module 332 of media sharing service 152, described above.
  • step 510 involves associating detected face information and identification information (e.g., name and contact information) with the image.
  • identification information e.g., name and contact information
  • additional metadata may be associated with the image including, but not limited to, a time when the image was captured and a location where the image was captured. For example, the location information may only be available if the device executing the client application includes a GPS receiver. Steps 510 and 512 may be performed, for example, by metadata insertion module 230.
  • step 514 which involves sending the image, including the metadata information, to a media sharing service, such as, for example, media sharing service 152 of FIGS. 1 and 3.
  • the sent image may be received, for example, by media input module 330 of media sharing service 152, shown in FIG. 3.
  • Step 514 may be performed, for example, by image transfer module 250.
  • Method 500 concludes in step 516 once the image has been sent.
  • method 500 particularly in combination with method 400, is that it enables users to automatically share media in a fast and easy way with minimal steps.
  • Media can be shared by a user simply by clicking a shutter (in step 504).
  • FIG. 6 is a flowchart of an embodiment of an exemplary method 600 for grouping images into albums.
  • Method 600 includes steps 602, 604, 606, 608, 610, 612, 614, and 616.
  • Method 600 starts in step 602 and proceeds to step 604, which includes receiving an image associated with a user.
  • Step 604 may be performed, for example, by media input module 330 of FIG. 3.
  • Step 606 includes determining content data for the image.
  • the image content data may include, but is not limited to, face recognition information, landmark recognition information, metadata information (e.g., time and location information), and any other types of image content information.
  • Step 606 may be performed, for example, by the subcomponents of media input module 330, including face recognition module 332, landmark recognition module 334, object recognition module 336, metadata extractor module 338, or any combination thereof.
  • Method 600 proceeds to step 608, which includes searching the user's existing albums, if any, for a matching album based on the image content data.
  • An existing album may be considered to be a match if the existing album contains images with substantially similar content data as the received image.
  • searching may be used to efficiently search for a matching album.
  • An example of one such approach includes creating a local index, in a database used to store user albums (e.g., album database 350 of FIG. 3), corresponding to one of the dimensions of the image content data. For example, an index corresponding to the album's end timestamp may be created.
  • Such a timestamp index can be used to scan the range from the image timestamp (i.e., the time when the image was captured), minus some predetermined threshold value, to the end of a table in a database.
  • the candidate albums produced from the scan could then be filtered by the remaining dimensions of the image content data, such as, for example, location information.
  • the advantage of this example approach is reducing the number of albums to search.
  • step 608 if a matching album is found in step 608, method 600 proceeds to step 610, in which the image is added to the matching album. Alternatively, if a matching album is not found in step 608, method 600 proceeds to step 612, in which a new album is created for the image. Steps 608, 610, 612, and 614 may be performed, for example, by album segmentation module 342 of media sharing module 340, shown in FIG. 3. After steps 610 or 612, method 600 concludes at step 614.
  • FIG. 7 is a flowchart of an embodiment of an exemplary method 600 for grouping albums associated with two or more users into event groups.
  • Method 700 includes steps 702, 704, 706, 708, 710, 712, 714, and 716.
  • Method 700 starts in step 702 and proceeds to step 704, which includes receiving two or more albums, where each album is associated with a different user.
  • Step 704 may be performed, for example, by media input module 330 of FIG. 3.
  • step 706 includes determining album content data for each album.
  • the album content data includes content information corresponding to the images within a given album.
  • Such album content data may include, but is not limited to, face recognition information, landmark recognition information, metadata information (e.g., time and location information), and any other types of album content information.
  • Step 706 may be performed, for example, by the subcomponents of media input module 330, including face recognition module 332, landmark recognition module 334, object recognition module 336, metadata extractor module 338, or any combination thereof.
  • Method 700 proceeds to step 708, which includes searching existing event groups, if any, associated with the user for a matching album based on the album content data.
  • an existing event group may be considered a match for the album if the existing event group contains albums with substantially similar content data as the received albums.
  • method 700 may utilize any one of a number approaches for searching may be used to efficiently search for a matching event group.
  • one approach for method 700 includes creating a local index, in a database used to store event groups (e.g., event database 360 of FIG. 3).
  • step 708 If a matching event group is found in step 708, method 700 proceeds to step 710, in which the albums are added to the matching event group. Alternatively, if a matching event group is not found in step 708, method 700 proceeds to step 712, in which a new event group is created for the albums. Steps 708, 710, 712, and 714 may be performed, for example, by event clustering module 344 of media sharing module 340, shown in FIG. 3. After steps 710 or 712, method 700 concludes at step 714.
  • method 700 may also include one or more additional steps (not shown), which involve querying a user for a suggested event group.
  • method 700 may suggest one or more event groups, for example, by displaying a list of event groups, in which to include the user's one or more albums. The list may be displayed, for example, at a media sharing site accessed by the user.
  • method 700 may proceed to inserting the one or more albums associated with the user into the user-selected event group.
  • the additional steps involving querying the user and receiving the user's selection may be performed, for example, by sharing manager 346 of FIG. 3.
  • the steps involving adding the albums to the selected event group may be performed, for example, by event clustering module 344.
  • Figure 8 illustrates an example computer system 800 in which embodiments of the present disclosure, or portions thereof, may by implemented as computer-readable code.
  • system 300 of FIG. 3 can be implemented in computer system 800 using hardware, software, firmware, tangible computer readable media having instructions stored thereon, or a combination thereof and may be implemented in one or more computer systems or other processing systems.
  • Hardware, software, or any combination of such may embody any of the modules and components in Figures 1-7.
  • programmable logic may execute on a commercially available processing platform or a special purpose device.
  • programmable logic may execute on a commercially available processing platform or a special purpose device.
  • One of ordinary skill in the art may appreciate that embodiments of the disclosed subject matter can be practiced with various computer system configurations, including multi-core multiprocessor systems, minicomputers, mainframe computers, computers linked or clustered with distributed functions, as well as pervasive or miniature computers that may be embedded into virtually any device.
  • processor devices may be used to implement the above described embodiments.
  • a processor device may be a single processor, a plurality of processors, or combinations thereof Processor devices may have one or more processor "cores.”
  • Processor device 804 may be a special purpose or a general purpose processor device. As will be appreciated by persons skilled in the relevant art, processor device 804 may also be a single processor in a multi-core/multiprocessor system, such system operating alone, or in a cluster of computing devices operating in a cluster or server farm. Processor device 804 is connected to a communication infrastructure 806, for example, a bus, message queue, network, or multi-core message-passing scheme.
  • Computer system 800 also includes a main memory 808, for example, random access memory (RAM), and may also include a secondary memory 810.
  • Secondary memory 810 may include, for example, a hard disk drive 812, removable storage drive 814.
  • Removable storage drive 814 may comprise a floppy disk drive, a magnetic tape drive, an optical disk drive, a flash memory, or the like.
  • the removable storage drive 814 reads from and/or writes to a removable storage unit 818 in a well known manner.
  • Removable storage unit 818 may comprise a floppy disk, magnetic tape, optical disk, etc. which is read by and written to by removable storage drive 814.
  • removable storage unit 818 includes a computer usable storage medium having stored therein computer software and/or data.
  • secondary memory 810 may include other similar means for allowing computer programs or other instructions to be loaded into computer system 800.
  • Such means may include, for example, a removable storage unit 822 and an interface 820.
  • Examples of such means may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 822 and interfaces 820 which allow software and data to be transferred from the removable storage unit 822 to computer system 800.
  • Computer system 800 may also include a communications interface 824.
  • Communications interface 824 allows software and data to be transferred between computer system 800 and external devices.
  • Communications interface 824 may include a modem, a network interface (such as an Ethernet card), a communications port, a PCMCIA slot and card, or the like.
  • Software and data transferred via communications interface 824 may be in the form of signals, which may be electronic, electromagnetic, optical, or other signals capable of being received by communications interface 824. These signals may be provided to communications interface 824 via a communications path 826.
  • Communications path 826 carries signals and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link or other communications channels.
  • computer program medium and “computer usable medium” are used to generally refer to media such as removable storage unit 818, removable storage unit 822, and a hard disk installed in hard disk drive 812.
  • Computer program medium and computer usable medium may also refer to memories, such as main memory 808 and secondary memory 810, which may be memory semiconductors (e.g. DRAMs, etc.).
  • Computer programs are stored in main memory 808 and/or secondary memory 810. Computer programs may also be received via communications interface 824. Such computer programs, when executed, enable computer system 800 to implement the present disclosure as discussed herein. In particular, the computer programs, when executed, enable processor device 804 to implement the processes of the present disclosure, such as the stages in the methods illustrated by flowcharts 400, 600, and 700 of FIGS. 4A-B, 6, and 7, respectively, discussed above. Accordingly, such computer programs represent controllers of the computer system 800. Where an embodiment of the present disclosure is implemented using software, the software may be stored in a computer program product and loaded into computer system 800 using removable storage drive 814, interface 820, hard disk drive 812, or communications interface 824.
  • Embodiments of the disclosure also may be directed to computer program products comprising software stored on any computer useable medium. Such software, when executed in one or more data processing device, causes a data processing device(s) to operate as described herein.
  • Embodiments of the disclosure employ any computer useable or readable medium. Examples of computer useable mediums include, but are not limited to, primary storage devices (e.g., any type of random access memory), secondary storage devices (e.g., hard drives, floppy disks, CD ROMS, ZIP disks, tapes, magnetic storage devices, and optical storage devices, MEMS, nanotechnological storage device, etc.), and communication mediums (e.g., wired and wireless communications networks, local area networks, wide area networks, intranets, etc.).
  • primary storage devices e.g., any type of random access memory
  • secondary storage devices e.g., hard drives, floppy disks, CD ROMS, ZIP disks, tapes, magnetic storage devices, and optical storage devices, MEMS, nanotechnological

Abstract

A computer-implemented method for automatically sharing media between users is provided. Collections of images are received from different users, where each collection is associated with a particular user and the users may be associated with each other. The collections are grouped into one or more albums based on the content of the images in the collection, where each album is associated with a particular user. The albums from the different users are grouped into one or more event groups based on the content of the albums. The event groups are then shared automatically, without user intervention, between the different users based on their associations with each other and their individual sharing preferences.

Description

AUTOMATIC MEDIA SHARING VIA SHUTTER CLICK
TECHNICAL FIELD
[0001] This disclosure relates generally to the field of digital media, including photos and video, and more particularly to the sharing of digital media between users.
BACKGROUND
[0002] Advancements in digital image capturing technology now allow users to quickly and conveniently capture digital media, including photos and video. In addition, innovations such as the integration of digital cameras in mobile devices, inexpensive storage for digital media, and network connectivity through the Internet allow users to capture digital media from any location and share it with other users.
[0003] The sharing of digital media typically involves a user uploading media to a media sharing web site such as, for example, Picasa and Picasa Web Albums, using a browser or other application running on the user's computing device. The media is stored at a remote web server operated by the web site and later accessed by other users, with whom the user has chosen to share the media. However, as the amount of digital media and digital media collections grows, searching for particular images to share with certain users becomes cumbersome.
BRIEF SUMMARY
[0004] Embodiments relate to a computer-implemented method for automatically sharing media. In one embodiment, a first collection of images and a second collection of images associated with a first user and a second user, respectively, are received. The first collection of images contains first content data and the second collection of images contains second content data. In addition, the first and second users are associated with each other. Next, the first and second collections are automatically grouped, without user intervention, into an event group according to the first and second content data. The first and second users are then automatically provided, without user intervention, access to the event group. The event group may be automatically updated with one or more new images associated with at least one of the first and second users, and the first and second users may be automatically provided access to the updated event group.
[0005] In another embodiment, a system for automatically sharing media includes at least one memory, a media input module, and a media sharing module. The media input module and the media sharing module are located in the at least one memory. The media input module is configured to receive a first collection of images associated with a first user and a second collection of images associated with a second user, where the first collection contains first content data and the second collection contains second content data. In addition, the first and second users are associated with each other. The media sharing module is configured to automatically group, without user intervention, the first and second collections into an event group according to the first and second content data. The media sharing module is further configured to automatically provide, without user intervention, the first and second users access to the event group. The event group may be automatically updated by the media sharing module with one or more new images associated with at least one of the first and second users, and the first and second users may be automatically provided access to the updated event group.
[0006] Embodiments may be implemented using hardware, firmware, software, or a combination thereof and may be implemented in one or more computer systems or other processing systems.
[0007] Further embodiments, features, and advantages, as well as the structure and operation of the various embodiments, are described in detail below with reference to the accompanying drawings. It is noted that the present disclosure is not limited to the specific embodiments described herein. Such embodiments are presented herein for illustrative purposes only. Additional embodiments will be apparent to persons skilled in the relevant art(s) based on the information contained herein.
BRIEF DESCRIPTION OF THE DRAWINGS/FIGURES
[0008] Embodiments are described, by way of example only, with reference to the accompanying drawings. In the drawings, like reference numbers may indicate identical or functionally similar elements. The drawing in which an element first appears is typically indicated by the leftmost digit or digits in the corresponding reference number. Further, the accompanying drawings, which are incorporated herein and form part of the specification, illustrate the embodiments of the present disclosure and, together with the description, further serve to explain the principles of the disclosure and to enable a person skilled in the relevant art(s) to make and use embodiments thereof.
[0009] FIG. 1 is a diagram of an exemplary system in which embodiments may be implemented.
[0010] FIG. 2 is a diagram of an example of a client application in accordance with an embodiment.
[0011] FIG. 3 is a diagram of an example of a system in which a media sharing service may be implemented in accordance with an embodiment.
[0012] FIG. 4 A is a flowchart of an example of a method for automatically sharing media between users in accordance with an embodiment.
[0013] FIG. 4B is a flowchart of an example of a method for updating an event group with one or more new images in accordance with an embodiment.
[0014] FIG. 5 is a flowchart of an example of a method for capturing and sending media using a client application in accordance with an embodiment.
[0015] FIG. 6 is a flowchart of an example of a method for grouping images into albums in accordance with an embodiment.
[0016] FIG. 7 is a flowchart of an example of a method for grouping albums into event groups in accordance with an embodiment.
[0017] FIG. 8 is a diagram of an example of a computer system in which embodiments can be implemented.
DETAILED DESCRIPTION
Table of Contents
I. Overview
II. System
A. Client Application
B. Media Sharing Service
1. Face Recognition
2. Landmark and Object/Scene Recognition
3. Metadata Extraction
4. Image Grouping a. Album Segmentation
b. Event Clustering and Sharing
c. Real-time Event Sharing
III. Method
A. Automatic Media Sharing Between Users
B. Client Application
C. Album Segmentation
D. Event Clustering
IV. Example Computer System Implementation
V. Conclusion
I. Overview
[0018] To facilitate the searching and sharing of images, users can organize digital media collections into different folders by album name or by date. Users can also associate tags or tag words with an image or group of images. Tags include one or more keywords that describe the content of the image. However, organization schemes involving user- provided tags do not scale well for large image collections from diverse sources. For example, users may fail to consistently and/or accurately tag all available images, and there may be differences in tags provided by different users for the same image. Furthermore, significant user input is required to tag a large number of images and consequently, users are unlikely to tag all of the available images. To share a group of images, each user must manually organize, tag, and upload a group of images to a media sharing web site. Moreover, this is particularly difficult for mobile phone users for whom data entry is cumbersome or for users who do not have the time to organize and enter descriptive data for media they wish to share.
[0019] In addition, media sharing sites generally do not provide the capability to automatically group images from multiple users. For example, a user may wish to share images taken at an event with other attendees of the event. Similarly, other attendees may wish to share their images from the event with the user. Although two or more users may be able to create a collaborative album or image collection that contains images from multiple users, the creation and update of such an album or image collection is still a manual process for the users. [0020] Embodiments relate to automatically sharing media between users. Embodiments automatically group, without user intervention, digital media, including photos and video, associated with a user into one or more albums based on the content of the media objects. Furthermore, embodiments automatically group, without user intervention, albums from multiple users into one or more event groups based on the content of the albums. The automatically generated event group(s) may then be shared between multiple users depending on the users' associations with each other and their individual sharing preferences. Embodiments also enable the event group(s) to be updated with new images and automatically share the update event group(s) between the users.
[0021] For example, a first user and a second user may belong to a social network in which each user allows the other access to each other's digital media collection, including photos and videos. The first and second users may capture photos from a particular event they both attend. Each user may store event photos along with other unrelated photos. Embodiments automatically determine the content of the photos associated with each user, group the photos corresponding to the event into an event group, and share the event group, including any new event photos, between the users. Embodiments may use a number of different techniques including, but not limited to, face recognition, landmark recognition, and scene or object recognition to determine the content of media. Embodiments may also extract metadata from media to determine its content.
[0022] While the present disclosure is described herein with reference to illustrative embodiments for particular applications, it should be understood that embodiments are not limited thereto. Other embodiments are possible, and modifications can be made to the embodiments within the spirit and scope of the teachings herein and additional fields in which the embodiments would be of significant utility. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the relevant art to effect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
[0023] It would also be apparent to one of skill in the relevant art that the embodiments, as described herein, can be implemented in many different embodiments of software, hardware, firmware, and/or the entities illustrated in the figures. Any actual software code with the specialized control of hardware to implement embodiments is not limiting of the detailed description. Thus, the operational behavior of embodiments will be described with the understanding that modifications and variations of the embodiments are possible, given the level of detail presented herein.
[0024] In the detailed description herein, references to "one embodiment," "an embodiment," "an example embodiment," etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
[0025] The terms "media" and "digital media" are used interchangeably herein to refer broadly and inclusively to digital photographs, or digital photos, and digital video. The term "image" is used herein to refer broadly and inclusively to a digital photograph depicting an image of a scene and items within that scene, including, but not limited to, one or more persons, one or more landmarks, and/or one or more objects. In addition, the term "image(s)" may refer to one or more frames from at least a portion of a digital video. Furthermore, the terms "photograph/photo," "video," "media," and "image" are used herein to refer to digital photos and digital video whether or not the terms are modified by the term "digital."
[0026] The term "media sharing site" is used herein to refer broadly and inclusively to any web site, service, framework, or protocol adapted to share digital media, including photos and videos, between various users. Such a web site or service may also include social networking sites with the added capability to share media between members of the site.
[0027] The terms "image capture device" and "image capturing device" are used interchangeably herein to refer broadly and inclusively to any device adapted to capture digital media, including photos and videos. Examples of such devices include, but are not limited to, digital cameras, mobile devices with an integrated digital camera. Furthermore, it is assumed herein that images are captured using such a device by manually pressing, selecting, or clicking a button or key that opens a shutter device for image exposure purposes. However, it should be noted the term "shutter" is used herein to also refer broadly and inclusively to any type of button or key on the image capture device that is used to capture the image (i.e., by invoking the shutter device).
77. System
[0028] FIG. 1 is a diagram illustrating a system 100 in which embodiments described herein can be implemented. System 100 includes client devices 1 10 and 1 lOA-C, a client application 1 12, device input 114, local memory 116, a browser 1 15, a media viewer 118, media 120, notifications 130, a network 140, servers 150, 160, and 170, a media sharing service 152, and a database 180.
[0029] Client devices 110, 110A, HOB, and 1 IOC communicate with one or more servers
150, 160, and 170, for example, across network 140. Although only servers 150, 160, and 170 (hereinafter collectively referred to as "server(s) 150") are shown, more servers may be used as necessary. Similarly, although only client devices 110 and 1 lOA-C are shown, more client devices may be used as necessary. Client device 110 is communicatively coupled to network 140 through a communications interface. Client device 1 10 can be any type of computing device having one or more processors and a communications infrastructure capable of receiving and transmitting data over a network. Client device 110 also includes device input 114. Device input 1 14 may be any kind of user input device coupled to client device 110 including, but not limited to, a mouse, QWERTY keyboard, touch-screen, microphone, or a T9 keyboard. Client device 110 can include, but is not limited to, a mobile phone, a personal digital assistant (PDA), a computer, a cluster of computers, a set-top box, or other similar type of device capable of processing instructions and receiving and transmitting data to and from humans and other computing devices.
[0030] Server(s) 150 similarly, can be any type of computing device capable of serving data to client device 110. Server(s) 150 execute media sharing service 152. Although media sharing service 152 is shown with respect to server 150, media sharing service 152 may be implemented on any server. Furthermore, the functionality of media sharing service 152 may be implemented on a single server, such as, for example, server 150, or across multiple servers, such as, for example, servers 150, 160, and 170, in a distributed or clustered server environment. [0031] In an embodiment, server(s) 150 are communicatively coupled to database 180.
Database 180 may be any type of data storage known to those of skill in the art. In an example, the data storage may be a database management system, such as an ORACLE database or other databases known to those skilled in the art. Database 180 may store any type of media and any corresponding media data accessible by server(s) 150. Although only database 180 is shown, more databases may be used as necessary.
[0032] In an embodiment, local memory 1 16 is used to store information accessible by client device 110. For example, information stored in local memory 116 may include, but is not limited to, one or more digital media files, contact information for one or more users, or any other type of information in a digital format. Local memory 1 16 may be any type of recording medium coupled to an integrated circuit that controls access to the recording medium. The recording medium can be, for example and without limitation, a semiconductor memory, a hard disk, or other similar type of memory or storage device. Moreover, local memory 1 16 may be integrated within client device 1 10 or may be a stand-alone device communicatively coupled to client device 1 10 via a direct connection. For example, local memory 116 may include an internal memory device of client device 110, a compact flash card, a secure digital (SD) flash memory card, or other similar type of memory device.
[0033] Network 140 can be any network or combination of networks that can carry data communication. Such network 140 can include, but is not limited to, a wired (e.g., Ethernet) or a wireless (e.g., Wi-Fi and 3G) network. In addition, network 140 can include, but is not limited to, a local area network, medium area network, and/or wide area network such as the Internet. Network 140 can support protocols and technology including, but not limited to, Internet or World Wide Web protocols and/or services. Intermediate network routers, gateways, or servers may be provided between components of system 100 depending upon a particular application or environment.
[0034] In an embodiment, client devices 1 10 and 1 lOA-C execute client application 1 12.
In a further embodiment, client devices 110 and 1 lOA-C execute media viewer 118. The operation of client application 112 and media viewer 118 are described in further detail below. Client application 112 and media viewer 118 may be implemented on any type of computing device. Such computing device can include, but is not limited to, a personal computer, mobile device such as a mobile phone, workstation, embedded system, game console, television, set-top box, or any other computing device. Further, a computing device can include, but is not limited to, a device having a processor and memory for executing and storing instructions. Software may include one or more applications and an operating system. Hardware can include, but is not limited to, a processor, memory and graphical user interface display. The computing device may also have multiple processors and multiple shared or separate memory components. For example, the computing device may be a clustered computing environment or server farm.
[0035] in an embodiment, as illustrated in FIG. 1, client device 110, via client application
112, media viewer 118, or any combination thereof, may send or receive media data 120 to or from media sharing service 152 on server(s) 150. Media data 120 includes one or more media files. The media files may be photos, video, or a combination of both. In addition, the media files may include media content information and metadata corresponding to the media to be sent or retrieved. Client application 112 and media viewer 118 may present a visual representation of the retrieved media on a display of client device 1 10. Such a display can be any type of display for viewing digital photos and/or video or can be any type of rendering device adapted to view digital photos and/or video.
[0036] In an embodiment, media viewer 118 can be a standalone application, or it can be executed within a browser 115, such as, for example, Google Chrome or Microsoft Internet Explorer. Media viewer 118, for example, can be executed as a script within browser 115, as a plug-in within browser 1 15, or as a program, which executes within a browser plug-in, such as, for example, the Adobe (Macromedia) Flash plug-in. In an embodiment, client application 1 12 and/or media viewer 118 are integrated with media sharing service 152.
[0037] In an embodiment, client device 110 is also configured to receive notifications
130 from media sharing service 152 over network 140. In an embodiment, notifications 130 include an access link to a location on the web where the media to be shared is stored. For example, the access link may include a location to a web site in the form of a web location address such as a uniform resource locator (URL). Notifications 130 may be sent from media sharing service 152 to client device 110 using any of a number of different protocols and methods. For example, notifications 130 may be sent from media sharing service 152 via electronic mail or Short Message Service (SMS). Notifications 130 may be received at client device 110 by client application 1 12, media viewer 118, or any other application or utility adapted to receive such notifications, such as, for example, an electronic mail client or SMS application.
A. Client Application
[0038] FIG. 2 is a diagram illustrating an exemplary embodiment of client application
112 of client device 110 of FIG. 1. Client application 112 includes image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250. Each of the components of client application 1 12, including image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250, may be communicatively coupled to one another.
[0039] In operation, client application 1 12 uses user interface module 240 to display an option to a user at client device 110 to capture a digital image. Upon the user's selection of the option, client application 112 uses image capture module 210 to capture the digital photo or video. To capture the image, image capture module 210 can be coupled to an image capture device (not shown), such as, for example, a digital camera integrated with client device 110. In addition, user interface module 240 can be coupled to a user input device, such as, for example, a touch screen or input button at client device 1 10 (e.g., device input 1 14). Once the photo or video is captured, it can be stored by image capture module 210 at client device 1 10, for example, in local memory 116.
[0040] Face detection module 220 can be configured to analyze media after it is captured by image capture module 210. In an embodiment, face detection module 220 can also analyze media previously captured and stored at client device 1 10. Such stored media may have been captured using the image capturing device at 110 (e.g., by image capture module 210 or another application executed at client device 110) or may have been captured using a separate image capturing device not coupled to client device 110 and later transferred to local memory 116. Face detection module 220 can be configured to analyze one or more images, or images specified by a user, to detect faces within the image(s). For example, if a user transfers an album of digital photos to local memory 1 16, face detection module 220 can analyze each digital photo in that album to detect faces. [00 1] When a face is detected, face detection module 220 can make a digital copy of an area encompassing the detected face, for example, a rectangular area encompassing the detected face, to produce a facial image or facial model corresponding to the detected face. The facial image can then be stored in local memory 116. Alternatively, the facial image can be stored in a facial image database (not shown), which is accessible by client application 1 12 via a network (e.g., network 140). In an embodiment, face detection module 220 can use stored facial images to aid in detecting faces in subsequently analyzed images.
[0042] A person skilled in the relevant art given this description would appreciate that any one of several well-known techniques may be used in face detection module 220 to detect faces in images. Examples of such techniques include, but are not limited to, elastic bunch graph matching as described in U.S. Patent No. 6,222,939, using neural networks on "gabor jets" as described in U.S. Patent No. 6,917,703, and face detection using boosted primitive features as described in U.S. Patent No. 7,099,510.
[0043] In some cases, the automatic face detection of face detection module 220 may not detect all faces in an image. Therefore, in some embodiments, the user may trigger face detection module 220 specifically to process a specified image. For example, face detection module 220 may not detect one or more faces in an image. In this case, in an embodiment, face detection module 220 provides the capability for the user to manually assist the face detection process. For example, user interface module 210 may present a graphical user interface to draw a bounding area, or a bounding box, around each face that the user wants detected. One skilled in the relevant art given this description would understand that the same facial detection technique may be used in the automatic face detection as well as the manually-assisted face detection with slight modifications. For example, when manually assisted, the face detection software may simply attach a greater weight to facial landmark features identified within the defined area.
[0044] In an embodiment, once the faces are detected using face detection module 220, user interface module 240 may display one or more user input fields, which the user can use to provide additional descriptive data to identify the person corresponding to the detected face. For example, the user can provide a name with which to tag the detected facial image. The tag can later be used to identify the person in other images. The descriptive data may also include, but is not limited to, contact information for the identified person. Upon user entry of additional information corresponding to the detected facial image(s), metadata insertion module 230 can be configured to associate or annotate the image with the detected face information (e.g., facial images produced by face detection module 220) in addition to any user-provided information including, but not limited to, tag name(s) for the identified person(s), contact information for each identified person(s), and/or image caption or description information.
[0045] In an embodiment, face detection module 220 may use stored facial images to identify the detected face(s). As described above, the facial images may be stored in local memory 116 or in a facial database accessible by client application 1 12 over network 140. Such a facial database can be any kind of database adapted to store facial images in addition to metadata, including name and/or contact information of the person corresponding to each facial image. The stored facial image can also include metadata of its own, including identification information for the identity of the person corresponding to the facial image. For example, the identification information may include a name and contact information.
[0046] Thus, in this embodiment, the user would no longer be required to provide identification information for the detected face. The advantage of this embodiment is that metadata insertion module 230 can associate detected face information and the corresponding identification information without further user intervention. However, face detection module 220 may need to be configured with additional face recognition functionality in order to match the detected faces with stored facial images or facial models. Such face recognition functionality would operate similarly to that of face recognition module 332 of media sharing service 152 of FIG. 3, described below.
[0047] In an embodiment, metadata insertion module 230 may also associate with the image(s) other metadata including, but not limited to, a time when the image(s) was taken and a location where the image(s) was taken. For example, client device 110 may include a global positioning satellite (GPS) receiver and metadata insertion module 230 may be configured to associate with the image(s) a location where the image(s) was taken in addition to any other information. A person skilled in the relevant art given this description would recognize that any number of well-known information formats might be used for the metadata. For example, the location of an image may include latitude and longitude coordinates corresponding to a geographic location where the image was captured.
[0048] In an embodiment, image transfer module 250 transfers one or more images from client device 110 to media sharing service 152 of server(s) 150, shown in FIG. 1, over network 140. The transferred image(s) includes metadata information associated with the image(s) by metadata insertion module 230. Image transfer module 250 is configured to transfer the image(s) via a communications interface of client device 1 10. The image(s) may be transferred by image transfer module 250 using any number of well-known methods for transferring digital files between client device 110 and media sharing service 152 over network 140.
[0049] Embodiments of image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250 can be implemented in software, firmware, hardware, or any combination thereof. Embodiments of image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250, or portions thereof, can also be implemented as computer-readable code executed on one or more computing devices capable of carrying out the functionality described herein. Examples of such computing devices include, but are not limited to, a computer, workstation, embedded system, networked device, mobile device, or other type of processor or computer system capable of carrying out the functionality described herein.
[0050] In addition, image capture module 210, face detection module 220, metadata insertion module 230, user interface module 240, and image transfer module 250 shown to be within client application 1 12, represent functionality in implementing embodiments of the present disclosure. One skilled in the art will understand that, more or fewer modules than shown in client application 112 may be implemented in software to achieve the functionality of the present disclosure.
B. Media Sharing Service
[0051] FIG. 3 is a diagram illustrating an embodiment of an exemplary system 300 in which media sharing service 152 may be implemented. System 300 includes a client device 310, a media database 320, media sharing service 152 of FIG. 1, an album database 350, an event database 360, and a social graph database 370. Media sharing service 152 includes various component modules including a media input module 330 and a media sharing module 340. Media input module 330 includes a face recognition module 332, a landmark recognition module 334, an object recognition module 336, and a metadata extractor module 338.
[0052] Media database 320 may store any type of media data such as photograph or video data. The images may, for example, be photographs taken from a digital camera. The images may be encoded in JPEG, TIFF, or other similar format for digital image files. Each image may have metadata associated with the image. For example, an image may have an exchangeable image file format (EXIF) header that stores information such as a time when the photograph of the image was taken, a location where the photo was taken, and information about the image capturing device, such as, for example, a digital camera, that captured the image, such as make, model, focal length and zoom. The time the image was taken may correspond to the time in which the image was exposed by the image capturing device. A video includes a sequence of frames, and each frame includes an image. The video may also be captured using an image capturing device able to capture video, such as, for example, a digital camera.
[0053] In an example, media database 320 may be coupled to a media sharing site (not shown), such as Picasa. A user may upload the media from the media sharing site to media database 320. For example, referring back to FIG. 1, the user may use browser 115 at client device 110 to navigate to the media sharing site and upload images to media database 320 via a user interface provided by the media sharing site. In a further example, the user may also be able to retrieve images from media database 320. For example, the user may have a choice to either download images onto client 110 for storage in local memory 1 16 or view the images using media viewer 118, which may also be coupled to the media sharing site.
[0054] Media data 301 is retrieved from media database 320 by media input module
330. Media input module 330 may retrieve media data 301 from media database 320 using, for example, an SQL select statement. Alternatively, media input module 330 could access media database 320 using a web service. Media database 320 may have one or more intermediate servers that may push media data 301 to media input module 330. Like media data 120, described above, media data 301 may include one or more image files. The image files may be photographs^ frames from one or more videos, or a combination of both. The image files may include image content and metadata, such as, for example, metadata information added by metadata insertion module 230 of client application 112, illustrated in FIG. 2.
[0055] Media input module 330 may also receive media data 120 over network 140 from one or more of client device 110 via communication channel 302, client device 1 10A via communication channel 304, and/or client device 310 via communication channel 303. Although only client device 110, client device 11 OA, and client device 310 are shown, additional client devices may be used as necessary. Client device 310 may include any image capturing device with the capability to send captured images to server(s) 150, including media sharing service 152, over network 140. For example, client device 310 may be a standalone digital camera including, but not limited to, digital camera with an EYE-FI SD card, which provides the capability to store images and directly upload stored images to a media sharing site.
[0056] Upon receiving media data 120 and/or retrieving media data 301, media input module 330 sends media data 120 and/or media data 301 to face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338.
1. Face Recognition
[0057] Face recognition module 332 interprets the content of media data 120 and/or media data 301 (hereinafter collectively referred to as "media data 120/301 ") by performing automatic face recognition to recognize one or more faces. The automatic face recognition of face recognition module 332 may function in two stages: a face detection stage and a face recognition stage. However, face recognition module 332 may be able to skip the face detection stage for media data 120/301 if face detection information is already included with media data 120/301. For example, the image may have been sent by client application 112 of client device 110, which already performs face detection and includes the face detection information with the image file. Since not all images include face detection information, face recognition module 332 must determine whether an image file it receives includes such information and based on the determination, perform face detection as necessary. [0058] The face detection stage of face recognition module 332 includes automatically detecting faces in images of media data 120/301. Such automatic detection may be based on, for example, general facial characteristics. Face recognition module 332 analyzes the images to detect faces within the images. When one or more faces are detected, face recognition module 332 may generate face detection information corresponding to each detected face including, for example, a bounded region encompassing the detected face within the image. In an embodiment, face recognition module 332 may enable a user to manually assist face detection, for example, through client application 112 and/or media viewer 1 18. In such an embodiment, the operation of the face detection stage is similar to the manual or user assisted operation of face detection module 220 of FIG. 2, described above.
[0059] The face recognition stage of face recognition module 332 includes identifying the detected faces. The operation of face recognition module 332 may include making comparisons of detected faces against one or more of facial images that have been previously recognized. For example, the previously recognized faces may be stored in one or more facial image databases (not shown) accessible by face recognition module 332. A person skilled in the relevant art given this description would appreciate that any one of several methods for face detection and recognition may be used. One example of such a method is described in Lui and Chen, "Video-based Face Recognition Using Adaptive Hidden Markov Models", 2001, CVPR.
2. Landmark and Object/Scene Recognition
[0060] Landmark recognition module 334 detects portions of images of media data
120/301 that have a landmark and identifies the landmark. One example of landmark recognition module 334 is described in commonly owned U.S. Patent Application No. 12/119,359 entitled "Automatic Discovery of Popular Landmarks," incorporated by reference herein in its entirety. Landmark recognition module 334 may, for example, use visual clustering to recognize landmarks.
[0061] Object recognition module 336 interprets images of media data 120/301 to recognize objects within a scene represented by the images. For example, media data 120/301 may include an image of a scene, and object recognition module 336 may recognize an object in that image. In another example, object recognition module 336 may recognize an object in one or more frames of a video. Object recognition module 336 may be any type of object recognition module as known to those skilled in the art. In general, the operation of object recognition module 336, like face recognition module 332, may include two steps. First, a portion of an image including an object is detected. Second, the portion of the image is put through a function, such as a classifier function, that identifies the object. A person skilled in the relevant art given this description would recognize that object recognition module 336 may include additional subcomponents, including other recognition modules, configured to detect different types of objects.
[0062] In some embodiments, object recognition module 120 may use hidden Markov models to select and match particular objects to an object in a set of known objects. In the case where media data 104 is a video, object recognition module 120 may track an object across one or more frames and then recognize the object based on the tracked frames.
[0063] By recognizing faces using face recognition module 332, landmarks using landmark recognition module 334, and objects using object recognition module 336, media input module 330 determines media content data 306. Media content data 306 may include, for example, a collection of media and meta-information of faces, landmarks, and/or objects corresponding to the content of the collection of media. In addition to using the content of media data 120/301 to determine media content data 306, media input module 330 may extract metadata directly from media data 120/301 using metadata extractor module 338, according to an embodiment.
3. Metadata Extraction
[0064] Metadata extractor module 338 may, for example, extract metadata included with media data 120/301. Media data 120/301 may be, for example, a collection of media files, and each media file may include metadata, as described above. In an embodiment, a media file may be a photographic image file, such as a JPEG or TIFF. The photographic image file may include an EXIF header with data about the image. An EXIF header may, for example, include data such as when the photo was taken. For example, client device 310 may include a location sensor, such as a GPS sensor. Image files generated by client device 310 may include a location where each photo was taken in their EXIF headers. For example, the EXIF header may have latitude and longitude values corresponding to where the picture was taken. In this way. metadata extractor module 338 reads metadata from media data 120/301 to be included with media content data 306.
[0065] Embodiments of face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338 can be implemented in software, firmware, hardware, or any combination thereof. Embodiments of face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338, or portions thereof, can also be implemented to run on any type of processing device including, but not limited to, a computer, workstation, embedded system, networked device, mobile device, or other type of processor or computer system capable of carrying out the functionality described herein.
4. Image Grouping
[0066] Using media content data 306, media sharing module 340 automatically groups the collection of media from different users and shares the grouped media between the users based on the content of the media and the associations between the users. For example, media input module 330 may receive or acquire different images, perhaps whole albums of images, where each image and/or album is associated with a different user. The users themselves may be associated with each other, for example, as members of the same social network or social graph in which the users are linked or associated with each other via sharing preferences designated, for example, on a social networking site. In an example, each user may have member profile information stored at the social networking site. In addition, each user's profile may have a sharing preference that specifies the media sharing or access rights and privileges the user provides to other users. The sharing preference may be used to identify other users with whom the user chooses to share media. For example, the sharing preference of a first user may identify a second user, where the first and second users are associated with each other. In general, users associated with each other provide media sharing privileges to one another, in which each user is allowed access to images associated with the other user. Thus, users associated with each other may identify one another via their sharing preferences. A person skilled in the relevant art given this description would recognize any number of known methods for associating sharing preferences with a user and for associating different users with each other. a. Album Segmentation
[0067] Media sharing module 340 automatically interprets media content data 306 to group images associated with each individual user into one or more albums for the user. Media sharing module 340 then automatically interprets media content data 306 to group albums corresponding to different users into one or more event groups, where the event group includes media associated with the different users. Media sharing module 340 then automatically shares, without user intervention, the event group(s) between the different users based on their social graph or association with each other. In an embodiment, media sharing module 340 also sends notifications of the available event group(s) to the users.
[0068J Media sharing module 340 includes an album segmentation module 342, an event clustering module 344, a sharing manager 346, and a notification manager 348. In an embodiment, media sharing module 340 is communicatively coupled to each of album database 350, event database 360, and social graph database 370 via communication lines 307, 308, and 309 respectively.
[0069] Album segmentation module 342 segments the collection of media from media input module 330 by grouping the collection of media into one or more albums based on the media content data information included in media content data 306. Album segmentation module 342 determines the media content data corresponding to each image of the collection of media using media content data 306. Based on the determined media content data of each image, album segmentation module 342 segments the collection of media into one or more albums.
[0070] For example, media content data 306 may include the time and location (e.g., in
GPS coordinates) of when and where images of the collection of media were captured. Based on the determined time and location of each image of the collection, album segmentation module 342 would segment the collection or group of images into one or more albums in which each album contains images having substantially similar time and location information. To improve the accuracy of the segmentation operation and the correlation of content between different images in a segmented album, album segmentation module 342 segments the collection of media based on as much information it can derive from media content data 306. For example, album segmentation module 342 may use face recognition information, landmark recognition information, object recognition information, metadata, or any combination thereof to segment the collection of images into an album(s).
0O71J In an embodiment, album segmentation module 342 may search album database
350 for existing albums containing images with similar media content data as a particular image or group of images received from media input module 330. Using the previous example described above, album segmentation module 342 may find an existing album in album database 350 containing images having substantially similar time and location information as the image(s) from media input module 330. In this example, album segmentation module 342 would add the image(s) to the existing album. If no existing album is found that matches the search criteria (e.g., images with similar media content data), album segmentation module 342 may create one or more new albums. In an embodiment, album segmentation module 342 may use album database 350 to store the new album(s). Album segmenting module 342 associates each album with the user associated with the group of images. b. Event Clustering and Sharing
[0072] Event clustering module 344 clusters the albums, segmented by album segmenting module 342, by grouping the albums into one or more event groups based on the media content data information included in media content data 306 and sharing preferences associated with two or more users. The clustering operation of event clustering module 344 is similar to the segmenting operation of album segmenting module 342, except that even clustering module 344 groups albums, where different albums are associated with different users. As discussed above, different users may be associated with each other via sharing preferences that identify one another. Also as discussed above, such preferences are used to determine which users have privileges to access media associated with a particular user.
[0073] Event clustering module 344 uses sharing manager 346 to determine sharing preferences and associations between different users. In an embodiment, sharing manager 346 is communicatively coupled with social graph database 370. Social graph database 370 may store any type of association between two or more users who have a social relationship with each other. Such association may include sharing preferences of the users, where the sharing preferences specify access rights or privileges each user has with the other. Embodiments of sharing manager 346 and social graph database 370 may be integrated, for example, with one or more social networking sites, photo sharing sites, or other similar types of sites that enable associations or social connections between different users.
[0074| In an embodiment, sharing manager 346 retrieves stored associations between two or more users, including the users' sharing preferences, from social graph database 370. The retrieved information regarding the users in combination with media content data 306 is used by event clustering module 344 to cluster albums into one or more event groups. Once the event group(s) is clustered by event clustering module 344, sharing manager 346 associates the event group(s) with the users and provides the users with access to the event group(s) based on the association of the users with each other and each user's individual sharing preference. In an embodiment, event database 360 may be used to store the association of users with event groups.
[0075] For example, a first album of images captured at a particular time and location, corresponding to a social event, may be associated with a first user. A second album of images captured at the same time and location, i.e., event, may be associated with a second user. In addition, there may be other albums of images, also captured at the event, associated with other users. In this example, even clustering module 344 may use sharing manager 346 to determine which the associations and sharing preferences of the users. If sharing manager 346 identifies an association between the first and second users and each user's sharing preference provides sharing privileges to the other, event clustering module 344 may, for example, cluster the first and second albums into an event group of images captured at the same time and location. The event group in this example would contain images associated with both users. Once the event group is created by clustering module 344, clustering module 344 may store the event group in event database 360. Sharing manager 346 may then provide the first and second users with access to the event group.
[0076] In an embodiment, notification manager 348 is configured to automatically send notifications (e.g., notifications 130 of FIG. 1) to one or more users of the event group. In an embodiment, the notification includes an access link to the event group. For example, the access link may be web-based location address in the form of a uniform resource locator (URL) address, which users can select to be automatically directed to the event group. Referring back to FIG. 1, the images of the event group may be accessible, for example, via client application 112, media viewer 118, or similar type of application the user can use to view media.
[0077] In an embodiment, event clustering module 344 may search event database 360 for existing event groups to add a newly clustered event group based on substantially similar content data. Event clustering module 344 may add the clustered event group to a matching event group if found in event database 360. Alternatively, event clustering module 344 may create a new event group in event database 360 for the clustered event group if a matching event group is not found in event database 360. c. Real-time Event Sharing
0078] In ten embodiment, sharing manager 346 may automatically enable real-time access and sharing to an event group based on the content information of media content data 306. For example, sharing manager 346 may use time and location metadata determined from media content data 306 in combination with social graph information from social graph database 370 to enable real-time access and sharing to an event group based on the time, location, and social graph information.
[0079] To illustrate an example of real-time sharing via sharing manager 346, assume images of an event are captured by a first user and a second user during the event. Event clustering module 344 may, for example, automatically generate an event group for the event based on the content of media captured during the event by the first and second users. Media content data 306 may include, for example, the time and location of when and where the images were captured. In this example, sharing manager 346 may determine that the first and second users are associated with each other and have matching sharing preferences (e.g., the first user allows media sharing privileges for the second user and vice versa). Based on the time and location information, sharing manager 346 would determine both users are at the same event and consequently, begin to automatically associate the first and second users with the event group and provide the users access to the event group. Notification manager 348 may, for example, send notifications, including an access link to the event group, to the first and second users. The first and second users may receive the notifications on, for example, their respective mobile devices. The first and second users would then be able to view the images of the event group using, for example, their respective mobile devices (e.g., in client application 112 or media viewer 118 of FIG. 1). This enables the first and second users to automatically and efficiently share media between each other during the event.
[0080] Embodiments of album segmentation module 342, event clustering module 344, sharing manager 346, and notification manager 348 can be implemented in software, firmware, hardware, or any combination thereof. Embodiments of album segmentation module 342, event clustering module 344, sharing manager 346, and notification manager 348, or portions thereof, can also be implemented to run on any type of processing device including, but not limited to, a computer, workstation, embedded system, networked device, mobile device, or other type of processor or computer system capable of carrying out the functionality described herein.
[0081] Album database 350, event database 360, and social graph database 370 may be any type of data storage known to those of skill in the art. In an example, the data storage may be a database management system, such as an ORACLE database or other databases known to those skilled in the art. Album database 350 and event database 360 may store any type of media such as images or video (e.g., organized into albums or event groups respectively) in addition to meta-information, including metadata and other content information, corresponding to the images or video.
[0082] Referring back to FIG. 1, although media sharing service 152 is shown with respect to server(s) 150, it should be noted that embodiments of media sharing service 152 and its components (media input module 330 and media sharing module 340), or portions thereof, can be implemented on a single server, such as, for example, server 150, or across multiple servers, such as, for example, servers 150, 160, and 170, in a distributed or clustered server environment. Furthermore, subcomponents of media input module 330 (face recognition module 332, landmark recognition module 334, object recognition module 336, and metadata extractor module 338), or portions thereof, can be implemented on a single server or across multiple servers. Similarly, subcomponents of media sharing module 340 (album segmentation module 342, event clustering module 344, sharing manager 346, and notification manager 348), ox portions thereof, can be implemented on a single server or across multiple servers. III. Method
A. Automatic Media Sharing Between Users [0083] FIGS. 4 A and 4B are process flowcharts of a method 400 for automatically sharing media between users. Method 400 includes steps 402, 404, 406, 408, 410, 412. 414, 416, 418, 420, 422, 424, and 426. Benefits of method 400 include, but are not limited to, a faster, more efficient, and automated way for users to share media between one another. Moreover, method 400 alleviates the burden for users of having to manually group images into albums, add descriptors to the album (e.g., album titles), and share the albums with other users.
[0084] For ease of explanation, system 100 of FIG. 1 and system 300 of FIG. 3, as described above, will be used to describe method 400, but is not intended to be limited thereto. Referring back to FIG. 3, method 400 may he performed, for example, by server(s) 150 via media sharing service 152. Method 400 begins in step 402 of FIG. 4A and proceeds to step 404, which includes receiving a first collection of Images associated with a first user. Step 404 may be performed, for example, by media Input module 330. In an embodiment, the first collection of images may be received directly from the first user via the first user's client device, such as, for example, client device 110. In another embodiment, the first collection may be stored for later retrieval in one or more media databases, such as, for example, media database 320. For example, the first collection of images may have been previously uploaded by the first user via, for example, a photo sharing site to which media database 320 may be coupled, as described above. Also, as described above, the images of the first collection may be digital photos, frames from a digital video, or any combination thereof.
[0085] Method 400 proceeds to step 406, which includes determining a first content data for each image in the first collection. Step 406 may be performed, for example, by face recognition module 332, landmark recognition module 334, object recognition module 336, media extractor module 338, or any combination thereof. As described above, the first content data may include information comprising recognized faces, landmarks, and/or objects within the first collection of images. Also as described above, the first content data may additionally include metadata extracted from the first collection including, but not limited to, the time and. location of when and where the images were captured.
[0086] Method 400 then proceeds to step 408, which includes segmenting the first collection into a first set of one or more albums. Step 408 may he performed, for example, by album segmentation module 342 of media sharing module 340. As described above, the first collection is segmented based on the determined first content data in step 406.
[0087] Steps 410, 412, and 414 of method 400 are similar to above-described steps 404,
406, and 408, respectively. However, steps 410, 412, and 414 correspond to a second collection of images associated with a second user. Thus, in step 410, a second collection of images associated with the second user is received. Like the first collection of images in step 404, the second collection may be received directly from second user or accessed from a media database, such as, for example, media database 320. Step 410 may also be performed, for example by media input module 330. In step 412, a second content data for each image in the second collection is determined. Step 412 may be performed, for example, by face recognition module 332, landmark recognition module 334, object recognition module 336, media extractor module 338, or any combination thereof. In step 414, the second collection is segmented into a second set of one or more albums based on the second content data. Step 414 may be performed, for example, by album segmentation module 342.
[0088] In an embodiment, the first and second sets of one or more albums are associated with the first and second users, respectively. As described above, the first and second users may also be associated with each other. In addition, the first and second users may have first and second sharing preferences, respectively. The sharing preference of each user identifies the media sharing rights and privileges the user provides to the other user. For example, the first user may have a sharing preference that allows sharing media with the second user by providing the second user access rights to media associated with the first user. The second user may also have a similar sharing preference corresponding to the first user.
[0089] Once the first and second collections are segmented into respective first and second sets of one or more albums, method 400 proceeds to step 416. In step 416, the first and second sets are clustered into an event group according to the first and second content data and sharing preferences of the first and second users. Step 416 may be performed, for example, by event clustering module 344 in combination with sharing manager 346. [0090] After the event group is created in step 416, method 400 proceeds to step 418, which includes providing the first and second users with access to the event group. Although not shown in method 400, the first and second users may also be associated with the event group, according to an embodiment. In addition, the event group and any associations with first and second users may be stored, for example, by event clustering module 344 in event database 360 via communication line 308, as illustrated in FIG. 3. Step 418 may be performed, for example, by sharing manager 346. In an embodiment, method 400 may also include an additional step (not shown), which includes sending a notification of the event group to the first and second users. The notification may include an access link to the event group, as described above. This optional step may be performed, for example, by notification manager 348.
[0091] Next, method 400 proceeds to step 420 of FIG. 4B, which includes receiving one or more new images representing scenes from a particular event, to which the event group corresponds. For example, the event group created in step 416 may include images that were captured by the first and second users during a particular event. After the event group is created, the first and/or second users may send new images also captured from the event. The new images may be sent by the first and/or second users from, for example, their mobile devices during the event or may be uploaded to, for example, a media sharing site after the event. In the former scenario, step 420 includes receiving the new images directly from one or both of the users. However, in the latter scenario, step 420 includes accessing the uploaded images from a media database coupled to or integrated with the media sharing site. The media database may be, for example, media database 320 of FIG. 3.
[0092] In a further scenario, a first set of new images from the event may be received directly from the first user and a second set of new images from the event may have been uploaded by the second user to a media sharing site. In this scenario, step 420 includes receiving new images directly and accessing new images from the media database. It should be noted that either user may choose to send images directly or upload images to a media sharing site. Step 420 may be performed, for example, by media input module 330 of FIG. 3.
[0093] If new images are received or accessed, method 400 proceeds to step 422, which includes updating the event group with the received or accessed new images, and to step 424, which includes providing the first and second users access to the updated event group. Providing the first and second users access to the updated event group enables sharing the event group between the first and second users. It should be noted that both first and second users are provided access to the event group regardless of whether the new images themselves were originally sent or uploaded by only one of the users. Step 422 may be performed, for example, by event clustering module 344. Step 424 may be performed, for example, by sharing manager 346. In an embodiment, method 400 may include an additional step (not shown) of sending the first and second users a notification of the updated event group. This step may be performed, for example, by notification manager 348. If no new images are received or accessed, method 400 concludes at step 426.
[0094] In an embodiment, steps 420, 422 and 424 enable automatic media sharing between the first and second users via the click of a shutter. For example, the new image(s) received in step 420 may be from a user, who captured the image using an application (e.g., client application 1 12) executing on a computing device with an integrated digital camera (e.g., client device 110 of FIG. 3) or a standalone image capturing device, such as, for example, a digital camera with an EYE-FI card (e.g., client device 310 of FIG. 3). Once the image(s) is received, the event group is automatically updated, without user intervention, with new image(s) in step 422, and the updated event group is automatically shared, without user intervention, between the users in step 424.
[0095] One advantage of method 400 is that it enables automatic sharing of media between users (in step 424) without requiring users to manually label and group images and collections of images. This leads to a faster, easier, and more efficient user experience for sharing media, which benefits the user who captures the media, by making it easier to share media. Furthermore, other users associated with the user are also benefited as it increases the likelihood that media captured by the user will be shared.
B. Client Application
[0096] FIG. 5 is a flowchart of an embodiment of an exemplary method 500 for sending media using a client application. For ease of explanation client application 112 of FIG. 2 and system 300 of FIG. 3 will be used to facilitate the description of method 500. Further, for ease of explanation, method 500 will be described in the context of a mobile device (e.g., client device 1 10 of FIG. 1) with an integrated image capturing device, such as, for example, a digital camera. However, based on the description herein, a person of ordinary skill in the relevant art will recognize that method 500 can be integrated within other client applications that can be executed on any type of computing device having a camera or other image capturing device.
[0097] Method 500 includes steps 502, 504, 506, 508, 510, 512, 514, and 516. Method
500 begins in step 502 and proceeds to step 504, which involves capturing an image representing a scene with one or persons. The image may be a digital photograph or one or more video frames of a digital video. Step 504 may be performed, for example, by image capture module 210 (e.g., when a user clicks a shutter). In addition to images captured by image capture module 210, method 500 can also use images already captured and stored in local memory (e.g., local memory 1 16 of client device 110). In step 506, the face of each person in the image is detected as described above. Step 506 may be performed by face detection module 220, described above. Method 500 then proceeds to step 508, which includes obtaining identification information for the face(s) detected.
|0098| In one embodiment, obtaining identification information in step 508 includes enabling a user to identify the face(s) detected in the image. The user may identify the face(s) by entering identification information for the person corresponding to the face. Such identification information may include, but is not limited to, a name and/or contact information (e.g., an email address) of the person being identified. For example, the captured image may be displayed on a display coupled to the computing device (e.g., client device 110 of FIG. 1) executing the client application (e.g., client application 112). In addition, the detected face(s) in the image may be shown on the display with a virtual box drawn around the face to demarcate the face(s). The user may enter the name and contact information using a user input device, such as, for example, a touch screen or keyboard (e.g., device input 1 14). This embodiment of step 508 may be performed, for example, by user interface module 240, described above.
[0099] In another embodiment, obtaining identification infonnation in step 508 includes retrieving a stored facial image that matches each detected face from, for example, local memory (e.g., in local memory 116) accessible by client application 1 12, as described above. In another example, the stored facial image may be retrieved in step 508 from a remote location such as a facial image database (not shown), which can be accessible, for example, by client application 112 over network 140. The stored facial image can also include metadata of its own, including identification information for the identity of the person corresponding to the facial image. For example, the identification information may include a name and contact information. Thus, in this embodiment, step 508 would no longer require the user to provide the identification information for the detected face. The advantage of this embodiment is allowing method 500 to proceed without further user intervention. This embodiment of step 508 may be performed, for example, by face detection module 220 in combination with a face recognition module, such as, for example, face recognition module 332 of media sharing service 152, described above.
[00100] Once the detected faces have been identified, method 500 proceeds to step 510, which involves associating detected face information and identification information (e.g., name and contact information) with the image. Such information may be associated with the image as metadata. In optional step 512, additional metadata may be associated with the image including, but not limited to, a time when the image was captured and a location where the image was captured. For example, the location information may only be available if the device executing the client application includes a GPS receiver. Steps 510 and 512 may be performed, for example, by metadata insertion module 230.
[00101] After the metadata information is associated with the captured image, method 500 proceeds to step 514, which involves sending the image, including the metadata information, to a media sharing service, such as, for example, media sharing service 152 of FIGS. 1 and 3. The sent image may be received, for example, by media input module 330 of media sharing service 152, shown in FIG. 3. Step 514 may be performed, for example, by image transfer module 250. Method 500 concludes in step 516 once the image has been sent.
[00102] One advantage of method 500, particularly in combination with method 400, is that it enables users to automatically share media in a fast and easy way with minimal steps. Media can be shared by a user simply by clicking a shutter (in step 504).
C. Album Segmentation
[00103] FIG. 6 is a flowchart of an embodiment of an exemplary method 600 for grouping images into albums. Method 600 includes steps 602, 604, 606, 608, 610, 612, 614, and 616. Method 600 starts in step 602 and proceeds to step 604, which includes receiving an image associated with a user. Step 604 may be performed, for example, by media input module 330 of FIG. 3. Upon receipt of the image, method 600 proceeds to step 606, which includes determining content data for the image. The image content data may include, but is not limited to, face recognition information, landmark recognition information, metadata information (e.g., time and location information), and any other types of image content information. Step 606 may be performed, for example, by the subcomponents of media input module 330, including face recognition module 332, landmark recognition module 334, object recognition module 336, metadata extractor module 338, or any combination thereof.
[00104] Method 600 proceeds to step 608, which includes searching the user's existing albums, if any, for a matching album based on the image content data. An existing album may be considered to be a match if the existing album contains images with substantially similar content data as the received image. A person skilled in the relevant art given this description would appreciate that any one of a number approaches for searching may be used to efficiently search for a matching album. An example of one such approach includes creating a local index, in a database used to store user albums (e.g., album database 350 of FIG. 3), corresponding to one of the dimensions of the image content data. For example, an index corresponding to the album's end timestamp may be created. Such a timestamp index can be used to scan the range from the image timestamp (i.e., the time when the image was captured), minus some predetermined threshold value, to the end of a table in a database. The candidate albums produced from the scan could then be filtered by the remaining dimensions of the image content data, such as, for example, location information. The advantage of this example approach is reducing the number of albums to search.
[00105] if a matching album is found in step 608, method 600 proceeds to step 610, in which the image is added to the matching album. Alternatively, if a matching album is not found in step 608, method 600 proceeds to step 612, in which a new album is created for the image. Steps 608, 610, 612, and 614 may be performed, for example, by album segmentation module 342 of media sharing module 340, shown in FIG. 3. After steps 610 or 612, method 600 concludes at step 614.
D. Event Clustering [00106] FIG. 7 is a flowchart of an embodiment of an exemplary method 600 for grouping albums associated with two or more users into event groups. Method 700 includes steps 702, 704, 706, 708, 710, 712, 714, and 716. Method 700 starts in step 702 and proceeds to step 704, which includes receiving two or more albums, where each album is associated with a different user. Step 704 may be performed, for example, by media input module 330 of FIG. 3. Upon receipt of the albums, method 700 proceeds to step 706, which includes determining album content data for each album. The album content data includes content information corresponding to the images within a given album. Such album content data may include, but is not limited to, face recognition information, landmark recognition information, metadata information (e.g., time and location information), and any other types of album content information. Step 706 may be performed, for example, by the subcomponents of media input module 330, including face recognition module 332, landmark recognition module 334, object recognition module 336, metadata extractor module 338, or any combination thereof.
[00107] Method 700 proceeds to step 708, which includes searching existing event groups, if any, associated with the user for a matching album based on the album content data. Like method 600, an existing event group may be considered a match for the album if the existing event group contains albums with substantially similar content data as the received albums. Also like method 600, a person skilled in the relevant art given this description would appreciate that method 700 may utilize any one of a number approaches for searching may be used to efficiently search for a matching event group. For example, like the example in method 600, one approach for method 700 includes creating a local index, in a database used to store event groups (e.g., event database 360 of FIG. 3).
[00108] If a matching event group is found in step 708, method 700 proceeds to step 710, in which the albums are added to the matching event group. Alternatively, if a matching event group is not found in step 708, method 700 proceeds to step 712, in which a new event group is created for the albums. Steps 708, 710, 712, and 714 may be performed, for example, by event clustering module 344 of media sharing module 340, shown in FIG. 3. After steps 710 or 712, method 700 concludes at step 714.
[00109] In an embodiment, method 700 may also include one or more additional steps (not shown), which involve querying a user for a suggested event group. In this embodiment, method 700 may suggest one or more event groups, for example, by displaying a list of event groups, in which to include the user's one or more albums. The list may be displayed, for example, at a media sharing site accessed by the user. Once the user selects an event group, method 700 may proceed to inserting the one or more albums associated with the user into the user-selected event group. The additional steps involving querying the user and receiving the user's selection may be performed, for example, by sharing manager 346 of FIG. 3. The steps involving adding the albums to the selected event group may be performed, for example, by event clustering module 344.
IV Example Computer System Implementation
[00110] Aspects of the present disclosure shown in Figures 1-7, or any part(s) or function(s) thereof, may be implemented using hardware, software modules, firmware, tangible computer readable media having instructions stored thereon, or a combination thereof and may be implemented in one or more computer systems or other processing systems.
[00111] Figure 8 illustrates an example computer system 800 in which embodiments of the present disclosure, or portions thereof, may by implemented as computer-readable code. For example, system 300 of FIG. 3, can be implemented in computer system 800 using hardware, software, firmware, tangible computer readable media having instructions stored thereon, or a combination thereof and may be implemented in one or more computer systems or other processing systems. Hardware, software, or any combination of such may embody any of the modules and components in Figures 1-7.
[00112] If programmable logic is used, such logic may execute on a commercially available processing platform or a special purpose device. One of ordinary skill in the art may appreciate that embodiments of the disclosed subject matter can be practiced with various computer system configurations, including multi-core multiprocessor systems, minicomputers, mainframe computers, computers linked or clustered with distributed functions, as well as pervasive or miniature computers that may be embedded into virtually any device.
[00113] For instance, at least one processor device and a memory may be used to implement the above described embodiments. A processor device may be a single processor, a plurality of processors, or combinations thereof Processor devices may have one or more processor "cores."
[00114] Various embodiments of the disclosure are described in terms of this example computer system 800. After reading this description, it will become apparent to a person skilled in the relevant art how to implement embodiments of the present disclosure using other computer systems and/or computer architectures. Although operations may be described as a sequential process, some of the operations may in fact be performed in parallel, concurrently, and/or in a distributed environment, and with program code stored locally or remotely for access by single or multi-processor machines. In addition, in some embodiments the order of operations may be rearranged without departing from the spirit of the disclosed subject matter.
[00115] Processor device 804 may be a special purpose or a general purpose processor device. As will be appreciated by persons skilled in the relevant art, processor device 804 may also be a single processor in a multi-core/multiprocessor system, such system operating alone, or in a cluster of computing devices operating in a cluster or server farm. Processor device 804 is connected to a communication infrastructure 806, for example, a bus, message queue, network, or multi-core message-passing scheme.
[00116| Computer system 800 also includes a main memory 808, for example, random access memory (RAM), and may also include a secondary memory 810. Secondary memory 810 may include, for example, a hard disk drive 812, removable storage drive 814. Removable storage drive 814 may comprise a floppy disk drive, a magnetic tape drive, an optical disk drive, a flash memory, or the like. The removable storage drive 814 reads from and/or writes to a removable storage unit 818 in a well known manner. Removable storage unit 818 may comprise a floppy disk, magnetic tape, optical disk, etc. which is read by and written to by removable storage drive 814. As will be appreciated by persons skilled in the relevant art, removable storage unit 818 includes a computer usable storage medium having stored therein computer software and/or data.
[ΘΘ117] In alternative implementations, secondary memory 810 may include other similar means for allowing computer programs or other instructions to be loaded into computer system 800. Such means may include, for example, a removable storage unit 822 and an interface 820. Examples of such means may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 822 and interfaces 820 which allow software and data to be transferred from the removable storage unit 822 to computer system 800.
[00118] Computer system 800 may also include a communications interface 824.
Communications interface 824 allows software and data to be transferred between computer system 800 and external devices. Communications interface 824 may include a modem, a network interface (such as an Ethernet card), a communications port, a PCMCIA slot and card, or the like. Software and data transferred via communications interface 824 may be in the form of signals, which may be electronic, electromagnetic, optical, or other signals capable of being received by communications interface 824. These signals may be provided to communications interface 824 via a communications path 826. Communications path 826 carries signals and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link or other communications channels.
[00119] In this document, the terms "computer program medium" and "computer usable medium" are used to generally refer to media such as removable storage unit 818, removable storage unit 822, and a hard disk installed in hard disk drive 812. Computer program medium and computer usable medium may also refer to memories, such as main memory 808 and secondary memory 810, which may be memory semiconductors (e.g. DRAMs, etc.).
[00120] Computer programs (also called computer control logic) are stored in main memory 808 and/or secondary memory 810. Computer programs may also be received via communications interface 824. Such computer programs, when executed, enable computer system 800 to implement the present disclosure as discussed herein. In particular, the computer programs, when executed, enable processor device 804 to implement the processes of the present disclosure, such as the stages in the methods illustrated by flowcharts 400, 600, and 700 of FIGS. 4A-B, 6, and 7, respectively, discussed above. Accordingly, such computer programs represent controllers of the computer system 800. Where an embodiment of the present disclosure is implemented using software, the software may be stored in a computer program product and loaded into computer system 800 using removable storage drive 814, interface 820, hard disk drive 812, or communications interface 824. [00121] Embodiments of the disclosure also may be directed to computer program products comprising software stored on any computer useable medium. Such software, when executed in one or more data processing device, causes a data processing device(s) to operate as described herein. Embodiments of the disclosure employ any computer useable or readable medium. Examples of computer useable mediums include, but are not limited to, primary storage devices (e.g., any type of random access memory), secondary storage devices (e.g., hard drives, floppy disks, CD ROMS, ZIP disks, tapes, magnetic storage devices, and optical storage devices, MEMS, nanotechnological storage device, etc.), and communication mediums (e.g., wired and wireless communications networks, local area networks, wide area networks, intranets, etc.).
V. Conclusion
[00122] It is to be appreciated that the Detailed Description section, and not the Summary and Abstract sections, is intended to be used to interpret the claims. The Summary and Abstract sections may set forth one or more but not all exemplary embodiments of the present disclosure as contemplated by the inventor(s), and thus, are not intended to limit the present disclosure and the appended claims in any way.
[00123] The present disclosure has been described above with the aid of functional building blocks illustrating the implementation of specified functions and relationships thereof. The boundaries of these functional building blocks have been arbitrarily defined herein for the convenience of the description. Alternate boundaries can be defined so long as the specified functions and relationships thereof are appropriately performed.
[00124] The foregoing description of the specific embodiments will so fully reveal the general nature of the disclosure that others can, by applying knowledge within the skill of the art, readily modify and/or adapt for various applications such specific embodiments, without undue ex perimentation, without departing from the general concept of the present disclosure. Therefore, such adaptations and modifications are intended to be within the meaning and range of equivalents of the disclosed embodiments, based on the teaching and guidance presented herein. It is to be understood that the phraseology or terminology herein is for the purpose of description and not of limitation, such that the terminology or phraseology of the present specification is to be interpreted by the skilled artisan in light of the teachings and guidance. The breadth and scope of the present disclosure should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.

Claims

WHAT IS CLAIMED IS:
1. A computer-implemented method for automatically sharing media between users, comprising:
receiving on at least one computing device a first collection of images associated with a first user, the first collection having first content data;
receiving on the at least one computing device a second collection of images associated with a second user, the second collection having second content data, wherein the first and second users are associated with each other;
grouping the first and second collections into an event group according to the first and second content data based on the association of the first and second users; and
providing the first and second users access to the event group.
2. The method of claim 1, further comprising:
receiving one or more additional images associated with one of the first collection of images or the second collection of images; and
updating the event group to include one or more additional images associated with at least one of the first and second users, and the first and second users may be automatically provided access to the updated event group.
3. The method of claim 2, wherein the one or more additional images are received in response to a click of an image shutter device.
4. The method of claim 1, further comprising providing a third user, associated with at least one of the first and second users, access to the event group, in response to determining at least one of the first and second content data includes an identity of a face corresponding to the third user.
5. The method of claim 1 , wherein grouping the first and second collections into an event group comprises:
segmenting the first collection associated with the first user into a first set of one or more albums according to the first content data, wherein the first user has a first sharing preference; segmenting the second collection associated with the second user into a second set of one or more albums according to the second content data, wherein the second user has a second sharing preference; and
clustering the first and second sets of albums into the event group based on the first and second content data and the first and second sharing preferences of the respective first and second users, wherein the first and second sharing preferences at least partially match.
6. The method of claim 1, wherein the providing the first and second users access to the event group comprises sending a notification, with an access link to the event group, to the first and second users.
7. The method of claim 1, wherein images of the first collection are frames from at least a portion of a first video, and wherein images of the second collection are frames from at least a portion of a second video.
8. The method of claim 1, further comprising:
determining the first content data for images in the first collection; and
determining the second content data for images in the second collection.
9. The method of claim 8, wherein determining the first content data comprises recognizing a first face in images of the first collection, the first content data including an identity of the first face, and
wherein determining the second content data comprises recognizing a second face in images of the second collection, the second content data including an identity of the second face.
10. The method of claim 9, wherein recognizing the first face comprises obtaining, from the first user, the first identity of the first face,
wherein recognizing the second face comprises obtaining, from the second user, the second identity of the second face,
wherein the first identity of the first face corresponds to the second user, and
wherein the second identity of the second face corresponds to the first user.
11. The method of claim 8, wherein determining the first content data comprises recognizing a first landmark in images of the first collection, the first content data corresponding to the first landmark, and
wherein determining the second content data comprises recognizing a second landmark in images of the second collection, the second content data corresponding to the second landmark.
12. The method of claim 8, wherein determining the first content data comprises recognizing a first object in images of the first collection, the first content data corresponding to the first object, and
wherein determining the second content data comprises recognizing a second object in images of the second collection, the second content data corresponding to the first object,
13. The method of claim 8, wherein determining the first content data comprises extracting first metadata from images of the first collection, the first content data corresponding to the first metadata, and
wherein determining the second content data comprises extracting second metadata from images of the second collection, the second content data corresponding to the second metadata.
14. The method of claim 13, wherein extracting the first metadata comprises extracting a first time when images of the first collection were exposed, and extracting the second metadata comprises extracting a second time when images of the second collection were exposed.
15. The method of claim 13, wherein extracting the first metadata comprises extracting a first location where images of the first collection were exposed, and extracting the second metadata comprises extracting a second location where images of the second collection were exposed.
16. A system for automatically sharing media between users, comprising:
one or more processors;
a media input module configured to receive a first collection of images associated with a first user and a second collection of images associated with a second user, the first collection having first content data and the second collection having second content data, wherein the first and second users are associated with each other; and a media sharing module to group the first and second collections into an event group according to the first and second content data based on the association of the first and second users, and to provide the first and second users access to the event group,
wherein the media input module and the media sharing module are implemented using the one or more processors.
17. The system of claim 16, wherein the media input module is further configured to receive one or more additional images associated with one of the first collection of images or the second collection of images, the media sharing module is further configured to update the event group to include one or more additional images associated with at least one of the first and second users, and the first and second users may be automatically provided access to the updated event group.
18. The system of claim 17, wherein the one or more additional images are received in response to a click of an image shutter device.
19. The system of claim 16, wherein the media sharing module is further configured to provide a third user, associated with at least one of the first and second users, access to the event group, in response to determining at least one of the first and second content data includes an identity of a face corresponding to the third user.
20. The system of claim 16, wherein the media sharing module comprises:
an album segmentation module configured to automatically segment the first collection associated with the first user into a first set of one or more albums according to the first content data, the first user having a first sharing preference, and to segment the second collection associated with the second user into a second set of one or more albums according to the second content data, the second user having a second sharing preference; and
an event clustering module configured to cluster the first and second sets of albums into an event group based on the first and second content data and the first and second sharing preferences of the respective first and second users, wherein the first and second sharing preferences at least partially match.
21. The system of claim 16, wherein the media sharing module comprises: a notification manager configured to send a notification, with an access link to the event group, to the first and second users.
22. The system of claim 16, wherein images of the first collection are frames from at least a ponion of a first video, and wherein images of the second collection are frames from at least a portion of a second video.
23. The system of claim 16, wherein the media input module is further configured to determine the first content data for images in the first collection, and to determine the second content data for images in the second collection.
24. The system of claim 23, wherein the media input module comprises:
a face recognition module configured to recognize a first face in images of the first collection, the first content data including an identity of the first face, and to recognize a second face in images of the second collection, the second content data including an identity of the second face.
25. The system of claim 24, wherein the face recognition module is configured to obtain, from the first user, the first identity of the first face, the first identity of the first face corresponding to the second user, and to obtain, from the second user, the second identity of the second face, the second identity of the second face corresponding to the first user.
26. The system of claim 23, wherein the media input module comprises:
a landmark recognition module configured to recognize a first landmark in images of the first collection, the first content data corresponding to the first landmark, and to recognize a second landmark in images of the second collection, the second content data corresponding to the second landmark.
27. The system of claim 23, wherein the media input module comprises:
an object recognition module to recognize a first object in images of the first collection, the first content data corresponding to the first object, and to recognize a second object in images of the second collection., the second content data corresponding to the second object.
28. The system of claim 23, wherein the media input module comprises:
a metadata extractor to extract first metadata from images of the first collection, the first content data corresponding to the first metadata, and to extract second metadata from images of the second collection, the second content data corresponding to the second metadata.
29. The system of claim 28, wherein the first metadata comprises a first time when the images of the first collecti on were exposed, and wherein the second metadata comprises a second time when images of the second collection were exposed.
30. The system of claim 28, wherein the first metadata comprises a first location where images of the first collection were exposed, and wherein the second metadata comprises a second location where images of the second collection were exposed.
EP11741726.1A 2010-07-27 2011-07-27 Automatic media sharing via shutter click Ceased EP2599016A1 (en)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US36816610P 2010-07-27 2010-07-27
US13/188,879 US8270684B2 (en) 2010-07-27 2011-07-22 Automatic media sharing via shutter click
PCT/US2011/045532 WO2012015919A1 (en) 2010-07-27 2011-07-27 Automatic media sharing via shutter click

Publications (1)

Publication Number Publication Date
EP2599016A1 true EP2599016A1 (en) 2013-06-05

Family

ID=44630017

Family Applications (1)

Application Number Title Priority Date Filing Date
EP11741726.1A Ceased EP2599016A1 (en) 2010-07-27 2011-07-27 Automatic media sharing via shutter click

Country Status (6)

Country Link
US (4) US8270684B2 (en)
EP (1) EP2599016A1 (en)
JP (1) JP5801395B2 (en)
KR (1) KR101810578B1 (en)
CN (1) CN103119595B (en)
WO (1) WO2012015919A1 (en)

Families Citing this family (135)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9319357B2 (en) 2009-01-15 2016-04-19 Social Communications Company Context based virtual area creation
US10786736B2 (en) 2010-05-11 2020-09-29 Sony Interactive Entertainment LLC Placement of user information in a game space
JP5740972B2 (en) * 2010-09-30 2015-07-01 ソニー株式会社 Information processing apparatus and information processing method
US8977767B2 (en) * 2010-10-20 2015-03-10 Qualcomm Incorporated Methods and apparatuses for affecting programming of content for transmission over a multicast network
TWI435597B (en) * 2010-10-20 2014-04-21 Altek Corp Photo information display method combined with face recognition and electronic device with camera function thereof
US20120213404A1 (en) 2011-02-18 2012-08-23 Google Inc. Automatic event recognition and cross-user photo clustering
JP2013003630A (en) * 2011-06-13 2013-01-07 Sony Corp Information processing device, information processing method, program, and information processing system
JP5995520B2 (en) * 2011-06-14 2016-09-21 キヤノン株式会社 Image processing support system, information processing apparatus, and image processing shadow support method
US8831294B2 (en) * 2011-06-17 2014-09-09 Microsoft Corporation Broadcast identifier enhanced facial recognition of images
US9049176B2 (en) 2011-06-22 2015-06-02 Dropbox, Inc. File sharing via link generation
US9342817B2 (en) * 2011-07-07 2016-05-17 Sony Interactive Entertainment LLC Auto-creating groups for sharing photos
US8773437B1 (en) 2011-07-12 2014-07-08 Relationship Science LLC Weighting paths in a social graph based on time
US9015856B2 (en) * 2011-08-08 2015-04-21 Facebook, Inc. Mobile-device user authentication
US10089327B2 (en) * 2011-08-18 2018-10-02 Qualcomm Incorporated Smart camera for sharing pictures automatically
US8831360B2 (en) 2011-10-21 2014-09-09 Intellectual Ventures Fund 83 Llc Making image-based product from digital image collection
US10169339B2 (en) * 2011-10-31 2019-01-01 Elwha Llc Context-sensitive query enrichment
US9349147B2 (en) * 2011-11-01 2016-05-24 Google Inc. Displaying content items related to a social network group on a map
US9280545B2 (en) * 2011-11-09 2016-03-08 Microsoft Technology Licensing, Llc Generating and updating event-based playback experiences
US9116555B2 (en) 2011-11-23 2015-08-25 Sony Computer Entertainment America Llc Gaming controller
US10486064B2 (en) 2011-11-23 2019-11-26 Sony Interactive Entertainment America Llc Sharing buffered gameplay in response to an input request
US8672765B2 (en) * 2012-03-13 2014-03-18 Sony Computer Entertainment America Llc System and method for capturing and sharing console gaming data
US10960300B2 (en) 2011-11-23 2021-03-30 Sony Interactive Entertainment LLC Sharing user-initiated recorded gameplay with buffered gameplay
US10525347B2 (en) 2012-03-13 2020-01-07 Sony Interactive Entertainment America Llc System and method for capturing and sharing console gaming data
US20130244790A1 (en) 2012-03-13 2013-09-19 Sony Computer Entertainment America Llc System and method for capturing and sharing console gaming data
EP2792157B1 (en) * 2011-12-12 2020-06-03 Samsung Electronics Co., Ltd. Method and apparatus for experiencing a multimedia service
US20140380387A1 (en) * 2011-12-12 2014-12-25 Samsung Electronics Co., Ltd. System, apparatus and method for utilizing a multimedia service
US8364817B1 (en) * 2012-02-09 2013-01-29 Gramboo Inc. Method and system for managing a data item
US8917943B2 (en) * 2012-05-11 2014-12-23 Intellectual Ventures Fund 83 Llc Determining image-based product from digital image collection
US9374399B1 (en) * 2012-05-22 2016-06-21 Google Inc. Social group suggestions within a social network
WO2013188682A1 (en) * 2012-06-13 2013-12-19 Google Inc Sharing information with other users
US8798401B1 (en) * 2012-06-15 2014-08-05 Shutterfly, Inc. Image sharing with facial recognition models
US8861804B1 (en) * 2012-06-15 2014-10-14 Shutterfly, Inc. Assisted photo-tagging with facial recognition models
US9665773B2 (en) 2012-06-25 2017-05-30 Google Inc. Searching for events by attendants
US9584834B1 (en) 2012-06-25 2017-02-28 Google Inc. Video broadcasting with geolocation
US9391792B2 (en) 2012-06-27 2016-07-12 Google Inc. System and method for event content stream
KR102048618B1 (en) * 2012-06-27 2019-11-25 구글 엘엘씨 System and method for determining appropriate content for an event content stream
US9104704B2 (en) 2012-07-16 2015-08-11 Htc Corporation Imaging systems and related methods
US20140025755A1 (en) * 2012-07-20 2014-01-23 Google Inc. Inferring events based on mob source video
US9460205B2 (en) 2012-07-20 2016-10-04 Google Inc. Crowdsourced video collaboration
FR2993686A1 (en) * 2012-07-23 2014-01-24 France Telecom Method for generating multi-media document e.g. video, relative to multi-media event such as festival, involves combining multimedia contents to geolocation point according to time-stamping data of certain multimedia contents
JP5692181B2 (en) 2012-07-26 2015-04-01 カシオ計算機株式会社 Network service system, wrist terminal, display method, and program
US9075954B2 (en) 2012-08-29 2015-07-07 Dropbox, Inc. Requesting modification rights to a linked file set
JP5175404B1 (en) * 2012-09-20 2013-04-03 株式会社 ディー・エヌ・エー Server apparatus, method, and system
US10115084B2 (en) 2012-10-10 2018-10-30 Artashes Valeryevich Ikonomov Electronic payment system
US9361626B2 (en) * 2012-10-16 2016-06-07 Google Inc. Social gathering-based group sharing
US9418370B2 (en) 2012-10-23 2016-08-16 Google Inc. Obtaining event reviews
JP5977147B2 (en) * 2012-11-05 2016-08-24 株式会社ソニー・インタラクティブエンタテインメント Information processing apparatus and input device
EP2919198B1 (en) * 2012-11-09 2018-11-14 Sony Corporation Image processing device, image processing method, and program
US9330301B1 (en) 2012-11-21 2016-05-03 Ozog Media, LLC System, method, and computer program product for performing processing based on object recognition
US9336435B1 (en) 2012-11-21 2016-05-10 Ozog Media, LLC System, method, and computer program product for performing processing based on object recognition
US9286456B2 (en) * 2012-11-27 2016-03-15 At&T Intellectual Property I, Lp Method and apparatus for managing multiple media services
EP2929703B1 (en) * 2012-12-07 2019-09-18 T-Data Systems (S) Pte Ltd A memory card and a method for allowing access to digital files stored on the memory card
US20140160148A1 (en) * 2012-12-10 2014-06-12 Andrew J. Barkett Context-Based Image Customization
US9104687B2 (en) 2012-12-20 2015-08-11 Dropbox, Inc. System and method for preventing duplicate uploads of modified photos in a synchronized content management system
US8838681B2 (en) 2012-12-21 2014-09-16 Dropbox, Inc. Systems and methods for adding digital content to content management service accounts
CN103902551B (en) * 2012-12-25 2017-11-17 华为技术有限公司 Information processing method, device and control device
US9424280B2 (en) * 2012-12-28 2016-08-23 Animoto Inc. Organizing media items based on metadata similarities
CN105210048B (en) * 2013-01-15 2019-07-19 盖帝图像(美国)有限公司 Content identification method based on social media
US10133754B2 (en) * 2013-02-10 2018-11-20 Qualcomm Incorporated Peer-to-peer picture sharing using custom based rules for minimal power consumption and better user experience
US20140250175A1 (en) * 2013-03-01 2014-09-04 Robert M. Baldwin Prompted Sharing of Photos
US20140258850A1 (en) * 2013-03-11 2014-09-11 Mathew R. Carey Systems and Methods for Managing the Display of Images
US9823813B2 (en) 2013-03-15 2017-11-21 Salesforce.Com, Inc. Apparatus and methods for performing an action on a database record
US20140280329A1 (en) 2013-03-15 2014-09-18 Salesforce.Com, Inc. Systems and methods for cross-referencing feed items
WO2014179810A1 (en) 2013-05-03 2014-11-06 Digimarc Corporation Watermarking and signal recogniton for managing and sharing captured content, metadata discovery and related arrangements
US9843623B2 (en) 2013-05-28 2017-12-12 Qualcomm Incorporated Systems and methods for selecting media items
US10243899B2 (en) 2013-05-30 2019-03-26 Dropbox, Inc. Content-item relationship messaging system
DE102013009958A1 (en) * 2013-06-14 2014-12-18 Sogidia AG A social networking system and method of exercising it using a computing device that correlates to a user profile
CN104243517B (en) * 2013-06-14 2018-12-11 腾讯科技(深圳)有限公司 Content share method and device between different terminals
US9313399B2 (en) * 2013-06-14 2016-04-12 Qualcomm Incorporated System and method for identifying people in an image
WO2015017865A1 (en) * 2013-08-02 2015-02-05 Shoto, Inc. Discovery and sharing of photos between devices
US9910865B2 (en) 2013-08-05 2018-03-06 Nvidia Corporation Method for capturing the moment of the photo capture
WO2015026263A1 (en) * 2013-08-20 2015-02-26 Ikonomov Artashes Valeryevich Server for storing images and/or video files
US9405964B1 (en) 2013-09-09 2016-08-02 Amazon Technologies, Inc. Processes for generating content sharing recommendations based on image content analysis
US9531823B1 (en) 2013-09-09 2016-12-27 Amazon Technologies, Inc. Processes for generating content sharing recommendations based on user feedback data
US9338242B1 (en) 2013-09-09 2016-05-10 Amazon Technologies, Inc. Processes for generating content sharing recommendations
CN105659286B (en) * 2013-09-18 2021-09-28 英特尔公司 Automated image cropping and sharing
US20150085146A1 (en) * 2013-09-23 2015-03-26 Nvidia Corporation Method and system for storing contact information in an image using a mobile device
US9628986B2 (en) 2013-11-11 2017-04-18 At&T Intellectual Property I, L.P. Method and apparatus for providing directional participant based image and video sharing
CN103686375B (en) * 2013-11-19 2017-02-22 乐视致新电子科技(天津)有限公司 Video sharing method and device
KR101791518B1 (en) 2014-01-23 2017-10-30 삼성전자주식회사 Method and apparatus for verifying user
US10673922B2 (en) * 2014-02-19 2020-06-02 RealCloud Imaging Inc. Cloud based 2D dental imaging system with HTML web browser acquisition
US10540541B2 (en) * 2014-05-27 2020-01-21 International Business Machines Corporation Cognitive image detection and recognition
JP6277570B2 (en) * 2014-06-12 2018-02-14 本田技研工業株式会社 Captured image exchange system, imaging apparatus, and captured image exchange method
US20160050704A1 (en) * 2014-08-12 2016-02-18 Lyve Minds, Inc. Image linking and sharing
US10943111B2 (en) * 2014-09-29 2021-03-09 Sony Interactive Entertainment Inc. Method and apparatus for recognition and matching of objects depicted in images
US9405774B2 (en) * 2014-10-17 2016-08-02 Verizon Patent And Licensing Inc. Automated image organization techniques
US9544307B2 (en) * 2014-10-29 2017-01-10 Salesforce.Com, Inc. Providing a security mechanism on a mobile device
US20160125062A1 (en) * 2014-10-30 2016-05-05 Futurewei Technologies, Inc. Multi-scale timeling photograph album management with incremental spectral photograph clustering
CN105760408B (en) * 2014-12-19 2020-04-28 华为终端有限公司 Picture sharing method and device and terminal equipment
US9781228B2 (en) * 2014-12-23 2017-10-03 Palo Alto Research Center Incorporated Computer-implemented system and method for providing contextual media tagging for selective media exposure
US11048855B2 (en) 2015-02-11 2021-06-29 Google Llc Methods, systems, and media for modifying the presentation of contextually relevant documents in browser windows of a browsing application
US11392580B2 (en) 2015-02-11 2022-07-19 Google Llc Methods, systems, and media for recommending computerized services based on an animate object in the user's environment
US9769564B2 (en) 2015-02-11 2017-09-19 Google Inc. Methods, systems, and media for ambient background noise modification based on mood and/or behavior information
US10284537B2 (en) * 2015-02-11 2019-05-07 Google Llc Methods, systems, and media for presenting information related to an event based on metadata
US9767305B2 (en) * 2015-03-13 2017-09-19 Facebook, Inc. Systems and methods for sharing media content with recognized social connections
CN104852967B (en) 2015-04-21 2018-03-27 小米科技有限责任公司 Image sharing method and device
US10778855B2 (en) 2015-06-19 2020-09-15 Line Corporation System and method for creating contents by collaborating between users
KR20160149959A (en) * 2015-06-19 2016-12-28 라인 가부시키가이샤 System and method for creating contents by collaborating between users
US10462524B2 (en) * 2015-06-23 2019-10-29 Facebook, Inc. Streaming media presentation system
US9917870B2 (en) 2015-06-23 2018-03-13 Facebook, Inc. Streaming media presentation system
CA3029973C (en) 2015-07-15 2022-04-12 15 Seconds of Fame, Inc. Apparatus and methods for facial recognition and video analytics to identify individuals in contextual video streams
CN105069075B (en) * 2015-07-31 2018-02-23 小米科技有限责任公司 Photo be shared method and apparatus
US10416850B1 (en) * 2015-08-06 2019-09-17 Western Digital Technologies, Inc. Sharing groups for capturing digital media
US20170060892A1 (en) * 2015-09-01 2017-03-02 Dropbox, Inc. Search-based shareable collections
US10863003B2 (en) 2015-09-10 2020-12-08 Elliot Berookhim Methods, devices, and systems for determining a subset for autonomous sharing of digital media
CN107710197B (en) 2015-09-28 2021-08-17 谷歌有限责任公司 Sharing images and image albums over a communication network
CN105187560A (en) * 2015-09-29 2015-12-23 北京奇艺世纪科技有限公司 Cloud server-based data pushing method and device
US9875511B1 (en) * 2015-09-30 2018-01-23 Sipree, Inc. Method and system for desktop-invoked image or video capture
CN108369652A (en) 2015-10-21 2018-08-03 15秒誉股份有限公司 The method and apparatus that erroneous judgement in being applied for face recognition minimizes
US10083720B2 (en) * 2015-11-06 2018-09-25 Aupera Technologies, Inc. Method and system for video data stream storage
US20170134595A1 (en) * 2015-11-11 2017-05-11 Vivint, Inc. Automated image album
US20170150197A1 (en) * 2015-11-20 2017-05-25 Nady International Limited Multimedia content sharing and distribution
JP6674798B2 (en) * 2016-03-07 2020-04-01 富士フイルム株式会社 Image processing apparatus, image processing method, program, and recording medium
US10459970B2 (en) * 2016-06-07 2019-10-29 Baidu Usa Llc Method and system for evaluating and ranking images with content based on similarity scores in response to a search query
US20190207946A1 (en) * 2016-12-20 2019-07-04 Google Inc. Conditional provision of access by interactive assistant modules
US10200560B2 (en) * 2017-01-13 2019-02-05 Adobe Inc. Automated sharing of digital images
US10740388B2 (en) 2017-01-24 2020-08-11 Microsoft Technology Licensing, Llc Linked capture session for automatic image sharing
US10127227B1 (en) 2017-05-15 2018-11-13 Google Llc Providing access to user-controlled resources by automated assistants
US11436417B2 (en) 2017-05-15 2022-09-06 Google Llc Providing access to user-controlled resources by automated assistants
US10432728B2 (en) 2017-05-17 2019-10-01 Google Llc Automatic image sharing with designated users over a communication network
US20180341878A1 (en) * 2017-05-26 2018-11-29 Get Attached, Inc. Using artificial intelligence and machine learning to automatically share desired digital media
US10706265B2 (en) * 2017-07-28 2020-07-07 Qualcomm Incorporated Scanning a real-time media stream to detect one or more faces that are prevalent among a set of media files stored on a user equipment
US10885315B2 (en) 2018-03-19 2021-01-05 Rovi Guides, Inc. Systems and methods for alerting a user to published undesirable images depicting the user
US10375432B1 (en) 2018-06-05 2019-08-06 Rovi Guides, Inc. Systems and methods for seamlessly connecting devices based on relationships between the users of the respective devices
EP3937030A1 (en) 2018-08-07 2022-01-12 Google LLC Assembling and evaluating automated assistant responses for privacy concerns
US10936856B2 (en) 2018-08-31 2021-03-02 15 Seconds of Fame, Inc. Methods and apparatus for reducing false positives in facial recognition
US10917372B2 (en) 2018-09-21 2021-02-09 Blackberry Limited Method and system for integration of shared photo albums with messaging applications
US20200213510A1 (en) * 2018-12-30 2020-07-02 Luke Trevitt System and method to capture and customize relevant image and further allows user to share the relevant image over a network
US11010596B2 (en) 2019-03-07 2021-05-18 15 Seconds of Fame, Inc. Apparatus and methods for facial recognition systems to identify proximity-based connections
CN110399520A (en) * 2019-07-30 2019-11-01 腾讯音乐娱乐科技(深圳)有限公司 Obtain the methods, devices and systems of singer informations
US11409788B2 (en) * 2019-09-05 2022-08-09 Albums Sas Method for clustering at least two timestamped photographs
US10963588B1 (en) 2019-10-30 2021-03-30 International Business Machines Corporation Analyzing recordings for data to be protected and identifying recipients and alerts
US11341351B2 (en) 2020-01-03 2022-05-24 15 Seconds of Fame, Inc. Methods and apparatus for facial recognition on a user device
US11539647B1 (en) * 2020-06-17 2022-12-27 Meta Platforms, Inc. Message thread media gallery
CN112015986B (en) * 2020-08-26 2024-01-26 北京奇艺世纪科技有限公司 Data pushing method, device, electronic equipment and computer readable storage medium

Family Cites Families (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6222939B1 (en) 1996-06-25 2001-04-24 Eyematic Interfaces, Inc. Labeled bunch graphs for image analysis
US7099510B2 (en) 2000-11-29 2006-08-29 Hewlett-Packard Development Company, L.P. Method and system for object detection in digital images
US6917703B1 (en) 2001-02-28 2005-07-12 Nevengineering, Inc. Method and apparatus for image analysis of a gabor-wavelet transformed image using a neural network
US7890871B2 (en) * 2004-08-26 2011-02-15 Redlands Technology, Llc System and method for dynamically generating, maintaining, and growing an online social network
KR100641791B1 (en) 2006-02-14 2006-11-02 (주)올라웍스 Tagging Method and System for Digital Data
JP2007249821A (en) * 2006-03-17 2007-09-27 Nec Corp Content sharing system
US7668405B2 (en) * 2006-04-07 2010-02-23 Eastman Kodak Company Forming connections between image collections
WO2007122726A1 (en) * 2006-04-21 2007-11-01 Mitsubishi Denki Kabushiki Kaisha Authenticating server device, terminal device, authenticating system and authenticating method
US7916976B1 (en) * 2006-10-05 2011-03-29 Kedikian Roland H Facial based image organization and retrieval method
JP4829762B2 (en) * 2006-12-06 2011-12-07 キヤノン株式会社 Information processing apparatus, control method therefor, and program
US9665597B2 (en) 2006-12-05 2017-05-30 Qualcomm Incorporated Method and system for processing images using time and location filters
US9122645B1 (en) * 2006-12-20 2015-09-01 Qurio Holdings, Inc. Method and system for tagging within virtual groups
US8788529B2 (en) * 2007-02-26 2014-07-22 Microsoft Corp. Information sharing between images
JP5164398B2 (en) * 2007-03-08 2013-03-21 キヤノン株式会社 Information processing apparatus and control method thereof
US8732161B2 (en) 2007-04-27 2014-05-20 The Regents Of The University Of California Event based organization and access of digital photos
US20090199093A1 (en) 2007-09-04 2009-08-06 Tridib Chakravarty Image Capture And Sharing System and Method
US8385950B1 (en) * 2007-11-09 2013-02-26 Google Inc. Capturing and automatically uploading media content
JP5045413B2 (en) * 2007-12-13 2012-10-10 日本電気株式会社 Photo output system
JP2009259238A (en) * 2008-03-26 2009-11-05 Fujifilm Corp Storage device for image sharing and image sharing system and method
JP5080524B2 (en) 2008-03-26 2012-11-21 富士フイルム株式会社 Storage device for image sharing, image sharing and method
JP2011516966A (en) * 2008-04-02 2011-05-26 グーグル インコーポレイテッド Method and apparatus for incorporating automatic face recognition in a digital image collection
US8224899B2 (en) * 2008-04-17 2012-07-17 Eloy Technology, Llc Method and system for aggregating media collections between participants of a sharing network
US8676001B2 (en) 2008-05-12 2014-03-18 Google Inc. Automatic discovery of popular landmarks
US20100056188A1 (en) 2008-08-29 2010-03-04 Motorola, Inc. Method and Apparatus for Processing a Digital Image to Select Message Recipients in a Communication Device
WO2010028169A2 (en) 2008-09-05 2010-03-11 Fotonauts, Inc. Reverse tagging of images in system for managing and sharing digital images
US8571331B2 (en) * 2009-11-30 2013-10-29 Xerox Corporation Content based image selection for automatic photo album generation

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
None *
See also references of WO2012015919A1 *

Also Published As

Publication number Publication date
US20120314917A1 (en) 2012-12-13
JP2013541060A (en) 2013-11-07
KR101810578B1 (en) 2018-01-25
JP5801395B2 (en) 2015-10-28
US20120027256A1 (en) 2012-02-02
US8270684B2 (en) 2012-09-18
US8634603B2 (en) 2014-01-21
CN103119595A (en) 2013-05-22
KR20130102549A (en) 2013-09-17
US20140304269A1 (en) 2014-10-09
WO2012015919A1 (en) 2012-02-02
CN103119595B (en) 2016-10-05
US8194940B1 (en) 2012-06-05

Similar Documents

Publication Publication Date Title
US8194940B1 (en) Automatic media sharing via shutter click
US10303756B2 (en) Creating a narrative description of media content and applications thereof
US9378408B2 (en) Assisted photo-tagging with facial recognition models
US9904723B2 (en) Event based metadata synthesis
KR101417548B1 (en) Method and system for generating and labeling events in photo collections
US20180365489A1 (en) Automatically organizing images
US9665773B2 (en) Searching for events by attendants
EP2402867A1 (en) A computer-implemented method, a computer program product and a computer system for image processing
WO2012064532A1 (en) Aligning and summarizing different photo streams
CN113010703B (en) Information recommendation method and device, electronic equipment and storage medium
US20120114307A1 (en) Aligning and annotating different photo streams
KR101782590B1 (en) Method for Providing and Recommending Related Tag Using Image Analysis
US20180189602A1 (en) Method of and system for determining and selecting media representing event diversity
US20160078033A1 (en) Physical Visual ID as Means to Tie Disparate Media Collections

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

17P Request for examination filed

Effective date: 20130226

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

DAX Request for extension of the european patent (deleted)
17Q First examination report despatched

Effective date: 20150123

17Q First examination report despatched

Effective date: 20150528

RIN1 Information on inventor provided before grant (corrected)

Inventor name: NOSHADI, HYDUKE

Inventor name: HAN, SIMON

Inventor name: TSANG, EVAN

Inventor name: KIYOHARA, KEITH, SHOJI

Inventor name: CHEN, PING, HSIN

Inventor name: AXE, BRIAN

Inventor name: DELAYE, DARREN

Inventor name: KANITKAR, KEDAR

Inventor name: SMILAK, KEVIN

Inventor name: BENJAMIN, HENRY

RAP1 Party data changed (applicant data changed or rights of an application transferred)

Owner name: GOOGLE LLC

REG Reference to a national code

Ref country code: DE

Ref legal event code: R003

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION HAS BEEN REFUSED

18R Application refused

Effective date: 20171213

P01 Opt-out of the competence of the unified patent court (upc) registered

Effective date: 20230519