Systems and methods for automated local story generation and curation

Information

  • Patent Grant
  • 11392633
  • Patent Number
    11,392,633
  • Date Filed
    Friday, December 22, 2017
    6 years ago
  • Date Issued
    Tuesday, July 19, 2022
    a year ago
  • CPC
    • G06F16/48
    • G06F16/29
    • G06F16/40
    • G06F16/435
    • G06F16/437
    • G06F16/487
    • G06F16/489
    • G06F16/9537
    • G06F40/10
    • G06F40/189
  • Field of Search
    • CPC
    • G06F17/21
    • G06F17/25
    • G06F17/27
    • G06F17/30017
    • G06F17/30029
    • G06F17/30035
    • G06F17/30041
    • G06F17/30044
    • G06F17/30241
    • G06F17/3087
    • G06F16/29
    • G06F16/40
    • G06F16/435
    • G06F16/437
    • G06F16/48
    • G06F16/487
    • G06F16/489
    • G06F16/9537
    • G06F40/10
    • G06F40/189
    • G06F16/483
    • G06F16/9535
  • International Classifications
    • G06F16/48
    • G06F16/9537
    • G06F16/29
    • G06F16/40
    • G06F16/435
    • G06F16/487
    • G06F40/10
    • G06F40/189
    • Disclaimer
      This patent is subject to a terminal disclaimer.
Abstract
Systems and methods for automated local story generation and curation are described. In one example embodiment, a server computer receives content from client devices, and processes the content to identify content characteristics. Stories are then generated based on the characteristics of the received content, and the stories are communicated to client devices. In certain embodiments, selection at a client device of an individual piece of content within a story may further be used by the system to provide the client device with a sub-story that includes pieces of content sharing content characteristics with the characteristics of the selected image or video.
Description
BACKGROUND

News stories have traditionally been presented to consumers in a heavily controlled and curated format. Early formats for news presentation included newspapers and magazines. Later formats included broadcast radio and television news. Traditional news sources are typically heavily associated with corporations or well-known persons that gather and present the news stories. In the modern Internet era, many such news sources have fragmented, but core aspects of news gathering and presentation often remain associated with professional journalists gathering and sharing information in a way that is tied to an individual identity. While such practices have been able to support some news structures with valuable analysis, the process for generating stories where select professionals filter information and generate stories is time consuming and introduces significant delay between an event occurring and presentation of information to a news consumer.


Systems and methods described herein relate to automated local story generation, curation, and presentation from received content.





BRIEF DESCRIPTION OF THE DRAWINGS

Various ones of the appended drawings merely illustrate example embodiments of the present disclosure and should not be considered as limiting its scope.



FIG. 1 is a block diagram illustrating a networked system, according to some example embodiments.



FIG. 2A illustrates aspects of server system operation receiving content for different geographic areas, in accordance with certain example embodiments.



FIG. 2B illustrates aspects of server system operation sending different stories to different geographic areas, in accordance with certain example embodiments.



FIG. 2C illustrates aspects of content origin areas and associated story visibility areas according to some embodiments.



FIG. 2D illustrates aspects of content origin areas and associated story visibility areas according to some embodiments.



FIG. 3A illustrates aspects of story generation, according to some example embodiments.



FIG. 3B illustrates aspects of story generation, according to some example embodiments.



FIG. 3C illustrates aspects of story generation, according to some example embodiments.



FIG. 4 is a flowchart illustrating aspects of a method, according to some example embodiments.



FIG. 5 illustrates aspects of a server system for automated local story generation and curation, according to some example embodiments.



FIG. 6 is a flowchart illustrating aspects of a method, according to some example embodiments.



FIG. 7 is a block diagram illustrating an example of a software architecture that may be installed on a machine, according to some example embodiments.



FIG. 8 illustrates an example user interface for a client device operating an application, according to some example embodiments.



FIG. 9 illustrates a diagrammatic representation of a machine in the form of a computer system within which a set of instructions may be executed for causing the machine to perform any one or more of the methodologies discussed herein, according to an example embodiment.





DETAILED DESCRIPTION

Systems and methods described herein relate to automated local story generation, curation, and presentation. Various embodiments described herein automatically generate stories from content received from different client devices such as smartphones. The stories are generated based on system trends and the characteristics of the received content. Story use trends may then be used to adjust how widely the story is available for viewing by system users.


“Content”, as described herein, refers to one or more images, video clips, or multimedia clips captured by an electronic device, as well as any associated metadata descriptions. This includes metadata generated by an electronic device capturing an image or video, as well as metadata that may be associated later by other devices. A “piece of content” refers to an individual image or video clip captured by a client device. Content captured by such a client device may be sent individually via a network to other client devices as part of a social sharing network. A “content message” as referred to herein refers to the communication of content between one or more users via the system. Content may also be sent from a client device to a server system to be shared generally with other system users. Embodiments described herein relate to methods of grouping such public content from different sources into stories.


A “story” as described herein is a set of content. A story may be generated from pieces of content that are related in a variety of different ways, as is described in more detail throughout this document. For example, a “global” story is a story that is available to all of the users in a system. A “main” story is a story that is initially sent to an individual user based on a system's initial story generation process. A main story acts as an initial filter group of similar pieces of content that may be of interest to a user. A “sub-story” is a story that is sent to a user based on a selection of an image from a previous story. A sub-story includes pieces of content that share image characteristics with the selected image of the previous story.


An example system can operate by receiving pieces of content from smartphones or other client devices located all over the world. When content is received by the system, it is analyzed to determine location, time, and content details. Content details can be determined by machine vision analysis of content to identify objects and other details relating to the content. Image and video quality metrics can also be, generated based on an automatic analysis. A set of content characteristics is then associated with the content based on the system analysis.


This example system then generates stories based on identified trends and the content characteristics for content in the system. The different stories are sent to different groups of client devices. Stories generated by a system may include a set of images and/or video clips selected based on: (1) whether the pieces of content were generated within a certain proximity of each other or within a local area (e.g. within a particular geofence); (2) how recent the content is; (3) image quality metrics; and (4) shared content characteristics (e.g. content characteristics identified by machine vision such as cats, automobiles, sports, or other such content). Stories generated by the system are then assigned to one or more user segments. Users may be assigned to one or more user segments in a variety of ways. Some user segments may be based on user location, while other user segments may be based on user interest, such as an interest in sporting events, music, weather, pets, or any other such user or system identified interest areas. In various embodiments, this user segment for a story may be adjusted over time based on system trends associated with the content characteristics used to generate a story (e.g. a spike in activity from a baseline or average for a location, content category, or other characteristic indicating a newsworthy event). Similarly, such trends may be used to generate new stories having content associated with a system trend. A device will then receive access to stories that are associated with the device's user segment (e.g. a device's location or an interest group associated with the device's account). In certain embodiments, this results in a user receiving stories focused on high-quality recent pieces of content that are generated close to a user. Stories that are older or generated from content taken further away from a user's current location may be provided to a user based on identified system trends. Various different metrics or different combinations of metrics may be used to select the stories available for presentation on a particular client device.


In some example embodiments, content is received by a system and processed using machine vision to identify content characteristics. Rather than stories being generated automatically, a story tool (e.g. computing device or software tool) may be used by a system operator to select content for inclusion in a story. The story may then be made available to an initial user segment. Based on system feedback as described herein, the system may then adjust which user segments may view the system operator generated story by automatically making the story available to a greater number of client devices if system feedback identifies trends associated with the story based on viewing, screenshotting, and other metrics.


When a user accesses a story on the user's client device, the user can view the content as part of the story and select an individual piece of content from a story. When a piece of content is selected from the story, this selection is communicated to the system. The system then provides the device with a sub-story based on the content characteristics of the selected piece of content. This process can continue with the user selecting another piece of content from the sub-story, with a resulting subsequent sub-story being sent to the user's client device. A provided user interface allows a user to navigate back to any earlier viewed story, and to continue viewing additional pieces of content from the earlier story. At any point another piece of content can be selected, resulting in an additional sub-story associated with characteristics of the newly selected content.


In certain embodiments, anonymous information about story viewing, selection of pieces of content within an individual story, and screenshotting of content on a client device is fed back to the system to influence the system trends that impact how stories are assigned to user segments. This feedback mechanism can also be integrated with the system trends associated with incoming pieces of content mentioned above to influence the selection of pieces of content for future story generation (e.g. when a story is generated or not generated). In certain embodiments, the system trends may be used to adjust assigned user segments for a story based on geographic tiers. In one such embodiment, a global tier is the top tier of the system, encompassing the entire world. Below the global tier is a country tier, with the country tier divided into a geographic area for each country participating in the system. Below the country tier is the state tier, then a city tier, then a local tier, etc. When a story is generated by such a system, it is automatically assigned to a user segment for a local geographic area associated with the location where the content was generated. In other words, the story is initially available only to devices within the area where the pieces of content were generated. Based on the system trends, a story can be assigned or “moved up” the tiers to a higher tier area, so that the story is visible beyond the local geographic area where the content for the story were generated. At the highest global tier, a story may be visible to all devices in a system, or may be visible to the broadest user segment possible for a particular story. As a system identifies increasing interest in a story, the story is pushed up to higher and higher geographic tiers. As the system identifies decreasing interest in the category, the story will similarly be pushed down to lower geographic tiers.


Certain embodiments of such a system may periodically assess newly received content to determine which pieces of content best represent certain system categories associated with a story. As new content messages associated with a story are received by the system, they may be added to a story, or used to update or replace some previously received pieces of content in a story.


In a system that operates with geographic tiers, the number and type of stories for different users in different geographic areas can have a different mix of stories presented for selection in a user interface of an application operating on a device. One set of stories made available to a first client device in a first local area could include all local stories. Another set of stories available in a different local area could include eight local stories, four city stories, one state story, no country stories, and two global stories. In certain embodiments this mix of geographic representation in the stories available on a single device change over time and for different user segments in different local areas based on the particular characteristics of the pieces of content available to a system. Other embodiments may not use fixed geographic tiers, but may assign an area to a story based on content characteristics or metadata associated with content in a story. For example, in certain embodiments a set of content for a story may all occur within a 10 meter radius, and the system may determine that the story will only be of interest to users that are very close to this location. Rather than making the story available to all users within a larger geographic area, the system may automatically assign an area to the story, and may make the story available only to users in the area that was generated and assigned for that story.


As a particular example of a system using geographic tiers, in one embodiment a sports arena may be assigned its own local geographic area or geofence. During a basketball game at the arena, users capturing content inside the arena have the option of sending content messages to the system for public use in stories. The system analyzes the pieces of content received and generates one or more stories for the system users inside the arena. The system may, for example, simply generate one story for the local geographic area that includes a mix of pictures and videos of the game and of fans attending the game.


If the game is particularly exciting the system may identify a trend. For example if the game is a playoff game that is tied with 10 seconds left, the system may see a spike in content messages sent from inside the arena for use in public stories. Based on this spike, a story from the arena is temporarily assigned a larger area (or higher tier), e.g., to state or national level visibility area, such that distant users within the new visibility area are provided, access to the story from the arena. If interest in the game and the associated story remains high after the ending of the game, this story may remain at the higher tier, geographic visibility level based on viewing rates, screenshotting rates, or other system feedback received from client devices.


These metrics may be generated in different ways as a user navigates the system to view content within different stories. For example, if a user has access to the story from the arena, and the story includes a picture or video of a game-winning play from the arena, the user may select this content. The system then generates a sub-story for the user based on the characteristics of this content. For example, the generated sub-story may include pictures or videos showing gameplay highlights. If a user selects content from this sub-story showing a player dunking, a second sub-story may be generated and sent to this user showing pictures or videos of this player generally as well as other content showing dunks with other players. Selecting a piece of content from the second sub-story including the same player may result in a third sub-story that includes only content featuring the selected player. Selecting a second sub-story picture or video showing a different player dunking may result in an alternate third sub-story with content showing dunk highlights from the entire basketball season. Any screenshots of pictures or videos taken by the user, along with viewing time, percentage of pictures or video in a particular story viewed, or other such metrics can be sent to the system as feedback to establish baseline values for these metrics and to identify trends and influence a current user segment assignment for related stories as well as system operations for the generation of future stories.



FIG. 1 is a block diagram illustrating a networked system 100 according to some example embodiments. System 100 includes client device 110, client device 120, server system 150, and network 140 that is used to convey communications between client devices 110 and 120 and the server system 150. Client devices 110 and 120 may be any smartphone, tablet, phablet, laptop computer, network-enabled camera, or any other such network enabled device. Client devices 110, 120 may include a camera device for capturing content, or may be coupled to a separate camera device that is used to capture the content prior to sending to other client device 110, 120 for storage. Some embodiments may therefore include a wearable devices such as a pendant with an integrated camera that is coupled to a client device 110, 120. Other embodiments may include other associated devices with an integrated camera that may be wearable such as a watch, eyeglasses, clothing such as a hat or jacket with integrated electronics, a clip-on electronic device, or any other such devices that may communicate or be integrated with a client device 110, 120. Client devices 110 and 120 are connected to server system 150 via network 140. The network 140 may include any combination of wired and wireless connections. This may include cellular access networks, access point interfaces to the internet, or any other such networks 140 or network elements. For example, client device 110 may interface with network 140 using a Long Term Evolution (LTE) cellular network to communicate with server system 150, while client device 120 may use a Wi-Fi access point to interface with network 140 and communicate with server system 150. Server system 150 may be one or more computing devices as part of a service or network computing system. In certain embodiments, particularly embodiments with large numbers of client devices 110, 120 interfacing with a server system 150 from widely different locations all over the globe, server system 150 may be a distributed network 140 of server computers that are similarly widely distributed, and which communicate with each other via network 140. In some embodiments, client devices 110 and 120, as well as and any elements of server system 150 and network 140, may be implemented using elements of software architecture 702 or machine 900 described in FIGS. 7 and 9.


Networked system 100 then may be used in communication of content messages from client devices 110, 120 to a system 150, and communication of stories from the system 150 to the client devices 110, 120. As shown in FIG. 1, client device 110 communicates content message 112 to server system 150, and client device 110 receives stories 114 from server system 150. In addition to this functionality used for the embodiments described herein, client device 110 may additionally receive private pieces of content and communications from other users, and may convey a personal story to server system 150, with the personal story including images and or video from content messages 112 generated by client device 110 or another device coupled to client device 110. Similarly, client device 120 sends content messages 122 and receives stories 124, and may additionally perform other actions.



FIG. 2A illustrates aspects of server system 250 receiving content messages from different geographic areas in accordance with certain example embodiments. FIG. 2B illustrates aspects of server system 250 sending different stories to different geographic areas in accordance with certain example embodiments, FIGS. 2C and 2D illustrate how different stories may be assigned different visibility areas. In contrast to FIG. 1 that shows two client devices 110 and 120. FIGS. 2A-D show an abstract of the client side of a system where thousands or millions of client devices 110, 120 in different areas may be interacting with a server system 250.


Instead of individual client devices 110, 120, FIGS. 2A and 2B show a simple user segment representation with two local geographic areas 204 and 206, which are the lowest tier areas in this example. State geographic area 202 is one tier above local geographic areas 204 and 206, and state geographic area 202 encompasses these two local areas. This is a simplified representation for example purposes. Other embodiments may include many more tiers, and large numbers of adjacent lowest tier local geographic areas. As described above, one embodiment may include a local tier, a city tier, a regional tier, a state tier, a national tier, and a top level global tier. A lowest level local tier may be made up of local geographic areas of widely varying size and shape. A single local geographic area may be a public park, multiple city blocks, a university campus, a sports area, a shopping mall, a beach, a single building, or any such local area. In certain embodiments, geofences are used to define local areas. Such geofences may be tracked by aspects of a network system 100 including location systems within client devices such as client devices 110 and 120, network based location systems as part of network 140, separate location systems such as global positioning systems (GPS), or any combination of these or other location systems.


In other embodiments, rather than considering set geofences or groups of users, a system may generate stories for each client device individually. In such an embodiment, whenever a user navigates to a stories interface within an application operating on a client device, the client device communicates a current location to the server system 250. The location of the device or other device provided information at that time can be used to generate a list of stories for the device.


In the illustrated example of FIG. 2A, the client devices within first local geographic area 204 are grouped together and communicate 1000 content messages 260 to server system 250 in a first time period. The content associated with these content messages is shown as SF1 through SF1000. During the same time period, 10000 content messages 262 containing individual clips or images are sent to server system 250 by client devices within the second local geographic area 206, illustrated as content LA1 through LA10000. This volume of content is sufficient to overwhelm an individual user. Therefore, server system 250 operates as a curator to filter the content messages and provide a select set of the pictures and videos from the content messages as one or more stories.


In various embodiments, this curation function may be fulfilled by a server system 250 in different ways. At a high level, one example embodiment segments users by local area. Stories for a client device 110, 120 are generated from the most recent content messages that were generated in the client device's current local area. Such local content messages for a story can further be filtered based on image quality and image content. Image content may be used to prevent excess content duplication, to provide a variety of different content, to provide content identified as newsworthy (e.g. images associated with famous people), or based on any other such content filtering selections. Image content may also be analyzed to identify content duplication, and to avoid placing extremely similar content (e.g. videos of the same event from similar angles) in a single story. Additionally, the server system 250 can analyze trends associated with incoming content messages from other local areas to generate stories based on the trends identified by the system. Additional details related to server curation and story generation are discussed below with respect to FIG. 6.



FIG. 2B then illustrates a first story set 292 being made available to all client devices within the first local geographic area 204. Similarly, second story set 294 includes stories visible to all client devices within the second local geographic area 206. Second story set 294 is shown as including three stories, with all three stories generated from content messages originating in the second local geographic area 206. These stories of the second story set include LA stories 291-293. First story set 292 is shown as including two stories generated from content messages originating within local geographic area 204, SF story 281 and SF story 282. First story set 292 also includes a story generated from content messages originating within local geographic area 206, LA story 291. As described above, LA story 291 may be identified by server system 250 analyzing system trends, where a larger than normal number of story views, screenshots, incoming additional content messages, or other system trends identify LA story 291 as a story to be made visible to a larger user segment.



FIG. 2C illustrates an example embodiment of how another story can be generated by server system 250 and made available to different user segments over time. As illustrated by FIG. 2C, content messages are received from content origin area 260 and are used to generate first story 261. At an initial time T1 when story 261 is first made available to system devices, the story is only visible to devices within T1 story visibility area 262, which is essentially the same area as the content origin area 260 where the content messages originated. Over time, the server system 250 identifies feedback baseline values that are used to establish system trends that deviate from baseline values and thus indicate interest in certain content. The server system 250 continuously expands the visibility area associated with the first story 261 based on such trends. At a second time T2, the story is visible in a regional area, shown as T2 story visibility area 264. At time T3, the first story 261 is visible at a state level, shown as T3 story visibility area 266. At time T4, the story 261 is visible to all devices at a country level, shown as T4 story visibility area 268. For example, such a story expansion over time may occur if a music festival with popular bands is taking place in content origin area 260, with a spike in content messages from that area occurring during the festival. Analysis by server system 250 identifies the spike in content messages, and automatically generates a story with pictures and video identified by machine vision as being content from the festival. The story is initially only visible in the local area, but is frequently viewed and screenshotted, and so is promoted to a regional/city story. The festival story is similarly popular as a regional story, and is promoted again to be a state story, and then promoted again to be a national story, so that anyone in the United States is able to view the story. After a certain amount of time, the story may be removed from the system and replaced with other stories. In some embodiments, this may occur with system trends determining that the story is less popular, and moving the story back down through the tiers until it is back to being a local story. In other embodiments, the story may simply be removed from the system after a certain period of time has passed.


By contrast, FIG. 2D illustrates aspects of an embodiment for stories where the user segment does not change over time. FIG. 2D shows that the content origin area 260 is also the local area where content messages originate for a second story 271. System baseline values and trends determine, however, that an insufficient level of interest is generated and thus the second story 271 is not promoted to a larger area. As a result, for times T1 through T4, the visibility area for second story 271 remains the same area. For example, if a water main breaks, resulting in a sudden spike of content messages from a flooded area near the break, the system may analyze the spike of related incoming content messages and automatically generate a story associated with the water main break. If the story does not generate sufficient interest to be promoted, the visibility area will remain the local area around where the content is captured, and only local viewers will have access to view the second story 271. This story will then eventually be replaced by other stories, and will be removed from the system.


Third story 275 accepts content from the entire national area as content origin area 274 and maintains this national area as T1-T4 third story visibility area 276. For example, on a national holiday such as the 4th of July in the United States, all content messages received in content origin area 274 may be processed using machine vision to identify fireworks images or other holiday images. Such a story may be triggered by a calendar event or a system setting matched to the holiday, or such a story may be generated in response to the system identifying a trend or a set of content messages meeting certain thresholds for generation of a national story. These content messages may automatically be used to generate third story 275, and third story 277 is visible from the entire national area during the holiday.


As mentioned above, the stories available to a device vary over time, and different sets of stories are available to different devices. In the example embodiment of FIGS. 2C and 2D, at time T1, devices outside T1 story visibility area 262 are able to view third story 277, but not first story 261 or second story 271, while devices inside area 262 are able to view all three of these stories. This changes over time, and at time T4, all users can view first story 261 and third story 271, but only users within area 262 are still able to view all three of these stories. Additionally, other stories may be provided to different devices, such that some additional stories may be available to users in other local geographies that are not available in T1 story visibility area 262. Similarly, story sets 292 and 294 are each illustrated as including three stories. In various embodiments, the story set available to a device at a particular time may include any number of stories. In certain embodiments, a maximum number of stories may be enforced by a server system 250, while in other embodiments, any number of stories meeting system thresholds for story generation and presentation may be offered to a user at any given time.



FIG. 3A illustrates an embodiment of a user interface for a client device 300. Client device 300 shows user selectable interface areas 301 for each story in first story set 292, including SF story 281, SF story 282, and LA story 291. Additional stories interface areas may be provided by scrolling up and down. Each interface area may provide basic details or sample images associated with each story. In certain embodiments a story or part of a story may be provided to client device 300 prior to a selection of an interface area 301. In other embodiments, images of a story are communicated from a server system such as server system 250 following selection of a particular interface area 301.



FIG. 3C illustrates one embodiment of an interface for viewing stories and sub-stories such as the stories shown in FIG. 3B. In FIG. 3C, when a story or sub-story is received for viewing on device 300, an individual piece of content is displayed within content viewing area 397. In the embodiment of FIG. 3C, a user has navigated to content LA 84 (either image or video) of second sub-story 320. Input areas are visible for a return to previously navigated stories. As shown, input 398 is available to switch to LA story 291, and input 399 is available to switch to first sub-story 310. If either input 398 or 399 is selected, the first picture or video of the selected story will be displayed within content viewing area 397. The viewer may then view some or all of the pieces of content within a story, and may either navigate to a new sub-story by selecting the picture or video displayed in content viewing area 397, or may return to a previous story. In further embodiments, a user may navigate between various stories and sub-stories using other user interface inputs. For example, a user in a sub-story may swipe up on content displayed on a device to return to a previously viewed story in some embodiments. Similarly, if a user has previously navigated back to a previously viewed story by swiping up, some embodiments may enable a swipe down user input to navigate to a sub-story. Other embodiments may use drop-down menus or menu lists of recently viewed stories that are accessed by a physical button on a client device to enable navigation between multiple different stories and sub-stories.



FIG. 3B then illustrates aspects of story generation according to some example embodiments. After a story is selected by a user interface action with an interface area 301, a story is displayed on client device 300. A user may then view various stories and sub stories. FIG. 3B shows LA story 291, which may be selected from the interface area 301 of FIG. 3A. Following such a selection, pieces of content from LA story 291 may be viewed. As illustrated, LA story 291 includes images or videos from content messages including content LA 7, LA 55, and LA 986-989. As an image from content LA 55 is displayed on a screen of device 300, the user may select the image from content LA 55. This selection is communicated from client device 300 to a server system, and the server system responds with first sub-story 310. First sub-story 310 includes videos or images from content LA 50-LA 57 having characteristics similar to one or more characteristics of content LA 55. After viewing some or all images of first sub-story 310 in an interface similar to the interface shown in FIG. 3c, the user may navigate back to LA story 291. When viewing video LA7, the user may then select image LA 7, and second sub-story 320 will be received from the server system in response to the selection of image LA 7. The user may then view some or all videos or images from content messages LA 80 through LA 84 of second sub-story 320 before navigating back to viewing the content of LA story 291.


For example, if LA story 291 includes videos of flooding and image LA 55 shows flood water in a local geographic area, a communication of this selection is sent to server system 250. Server system 250 then responds with a first sub-story 310 having content that share content characteristics with the selected image LA 55. In this case, all content associated with content messages LA 50 through LA 57 may include pictures or videos showing a specific area from different angles, as well as older pictures or videos of the specific area before the flooding occurred.


The user may then return to the original story to continue viewing content in LA story 291, and may select an additional image or video within LA story 291. If the user then selects a video from content message LA 7 of a dog walking through the flood water of the event that initiated the creation of LA story 291, then this selection is communicated to server system 250, and the server system 250 responds with second sub-story 320. Based on the video of the dog and the flood water images from content messages, LA80-LA84 may include images or videos of dogs. This process can be recursive, such that a user can then select an image or video within a sub-story, and receive an additional sub-story. For example, if a user selects an image or video from content communication LA80 showing a particular type of dog, then another sub-story may be received including content including that type of dog from different times or from other areas. If a user selects a piece of content from content communication LA84 showing a video of dogs playing around flood water, then another sub-story may be generated showing only dog content with dogs playing around water. Additional details related to selection of content for sub-stories are discussed below with respect to FIG. 6.



FIG. 4 is a flowchart illustrating aspects of a method 400, according to some example embodiments. For illustrative purposes, method 400 is described with respect to networked system 100 of FIG. 1. It is to be understood that method 400 may be practiced with other system configurations in other embodiments.


In operation 404, a server system 150 receives content messages 112, 122 from a client device 110, 120 via network 140. In operation 406, the content received in operation 404 is processed to identify content characteristics. This operation 406 may identify a time at which the content was generated, a location where it was generated, or other associated time and location information. If more than one piece of content (e.g. multiple video clips or pictures) are received, then a time period may be identified. Server system 150 may also include a machine vision module which is configured to identify objects within the content. In certain embodiments, a machine vision module may include a dictionary of objects and object arrangements. Based on the objects and/or object arrangements identified by the machine vision module, one or more values may then be assigned as content values as part of a set of characteristics associated with the piece of content by the processing of operation 406. Additionally, image or video quality values may be assigned to content. Such values may include blurriness values, brightness values, color profile values, contrast values, or any other such quality values. In embodiments where content include video clips having different frame rates or other characteristics unique to video clips, this information may also be used to assign quality values as part of a set of content characteristics.


In operation 408, the content received in operation 404 is processed with other incoming pieces of content to identify system trends. For example, a server system 150 may keep a record of image content values assigned by system processing, and how frequently (e.g. a content receipt rate) content with a particular content value is received. Such frequency and receipt rate metrics may be maintained anonymously by server system 150 for any content characteristic values, and used to establish expected baseline values that are associated with normal system activity for particular dates, times, events, or other periods that may be identified within a system. When the server system 150 identifies a spike (e.g. a variation from the expected baseline) in a receipt rate of content associated with a particular content characteristic value, this can be identified by the server system 150 as a system trend. Selection of particular pieces of content as part of story viewing may also be tracked by a system. When the server system 150 receives user selections associated with a piece of content and sends an associated sub-story to a client device, this may be tracked to determine system trends. If a particular piece of content is selected frequently, this information may be used as system feedback for selecting the piece of content for future stories, or for including it in stories for a larger geographic area. In various embodiments, an application operating on a client device may also gather information about how a user interacts with certain pieces of content or stories. For example, the application may record how frequently or for how long a particular story or piece of content within a story is viewed. The application may also track how many images or videos within a story are viewed prior to the user navigating away from a story. This information may be collected and sent to server system 150 for use in determining trends. For all of the above, in different embodiments, server 150 may use different statistical analyses with associated thresholds or criteria to trigger the identification of a system trend.


In operation 410, the system trends identified in operation 408 and the individual content characteristics for the piece of content identified in operation 406 are used to determine if a story should be generated or updated.


If a story is being generated for the first time, a user segment or visibility area is assigned to the story. This may involve an identification at server system 150 of user segments with shared characteristics to be used for story segmentation. This may simply involve assigning a story as visible within a geofence where content from the story originated. Grouping users reduces processing loads on server system 150 by reducing processing resources needed to determine which stories are available to which devices. In other embodiments, stories may be generated on a per client device basis, without such user segments. In such embodiments, stories may be considered individually curated for single client devices 110, 120. One example embodiment of a user segment is a user segment based on area tiers as described above. In other embodiments, user segments may be based on system supported interest groups. For example, the system may allow a user to indicate an interest in sports. In such an example, basketball, football, soccer, baseball, hockey may correspond to the higher level tiers, with different leagues and/or levels corresponding to lower level tiers. When stories containing content related to basketball are generated, a user's device may be provided access to that story regardless of where the user's device is located. In some embodiments, this interest indication may be used as system trend data to trigger the system to generate more stories related to basketball.


If a story is being updated, then feedback information received at server system 150 is analyzed to determine if a story should be more widely available or less widely available based on system metrics for story visibility.


In some embodiments, a user provides one or more system settings to identify categories that a user is interested in. These categories are then used by the system to identify user segments, which are groups of users that have expressed interest in shared categories or are otherwise grouped together by the system. The system can independently generate story sets for a user's devices based on category selections. In other embodiments, content viewing characteristics associated with a client device or a user account may be used to generate or update interest profiles. This information may be used not only to generate story sets for the user and other users with similar profiles, but this information may also be used as system feedback for determining trends in the system. Other embodiments may particularly exclude the use of individual device or account profiles for privacy purposes, and may only use data received from client devices that is stored anonymously.


Additionally, in some embodiments as new content is received That is associated with categories that were used to generate a story, then the pieces of content for a story may be adjusted. In certain embodiments, new content is appended to the end of a story. In other embodiments, content may be both added and removed from a story based on threshold values for inclusion in a particular story. When a story is generated or updated as part of operation 410, the new story is made available to individual client devices 110, 120. In some embodiments, the communication of the story to a particular client device 110, 120 may occur automatically as part of a push from server system 150 to the client device 110, 120. In other embodiments, a client device 110, 120 generates a request for a story as part of application operations at the client device 110, 120. For example a user navigating to a story interface within an application may automatically generate a request from the client device 110, 120 to server system 150 for the main story associated with the client device's 110, 120 user segment.


Operations 404 through 410 will repeat during system operation. In certain embodiments, a server system 150 may aggregate content over a set period of time, or may aggregate a set number of pieces of content before processing the content and updating a story or generating a new story. In other embodiments, updates and new stories for a user segment may occur only when a client device 110, 120 associated with a user segment requests a list of available stories. In further embodiments, criteria associated with incoming content may be used to trigger an update or new story generation. For example, during periods when large numbers of content messages are received that are related with categories or events identified as trending, a new story or a story update may be triggered. In other embodiments, various combinations of these update periods and triggers may be used, along with any other possible criteria for initiating an update to a story.


As these operations above repeat to generate new stories and update existing stories, a client device 110, 120 may periodically send a communication to server system 150 identifying a user selection of a picture or video with a story, as illustrated by operation 412. After receipt of such communication in operation 412, in operation 414 a sub-story is identified by the server system 150, with the sub-story containing content sharing content characteristics with the selected picture or video. This sub-story may be generated as the request is received, or may be generated by the system as the piece of content is initially placed in a story. The sub-story is then communicated to the client device 110, 120 that sent the communication. This process of operations 412 through 416 may similarly repeat with the client device 110, 120 selecting different pieces of content or navigating to previously received stories, and the server system 150 communicating the associated stories and content to the client device 110, 120.



FIG. 5 illustrates aspects of a server system 550 for automated local story generation and curation, according to some example embodiments. In various embodiments, server system 550 may be used as an implementation of server system 150 or server system 250. The example server system 550 includes input and output (I/O) module 552, content characteristic analysis module 554, machine vision module 556, content characteristic database 558, trend analysis module 560, and story generation module 562.


I/O module 552 may include any hardware, firmware, or software elements needed to send and receive content and stories to client devices 110, 120 via a network 140. Content characteristic analysis module 554 may include devices, processors, and software to analyze images from pictures and frames of video clips, and then determine content characteristics, including details about when and where a picture or video was generated. In certain embodiments, content characteristic analysis module 554 may be implemented as a plurality of different modules, each analyzing a different content characteristic, including any content characteristic described herein.


Machine vision module 556 describes a particular module that may be used to identify content characteristics based on the content of an image or images in a video. Machine vision module 556 includes hardware, firmware, and/or software for analyzing and understanding content. In one embodiment, machine vision module 556 is associated with a dictionary comprising image and video content values. Objects identified in images of a piece of content and the arrangement of the identified objects therein may be used by machine vision module 556, in such an embodiment, to select one or more content values from the dictionary as content characteristics. For example, a simple such machine vision module 556 may identify a ball in an image, and select the values ball and game as content characteristics. A more complex module may identify the type of ball as a basketball, and include “basketball” as a characteristic value. A still more complex machine vision module 556 may identify a basketball, a crowd, a court color, and an elevated perspective of the court to identify “professional basketball game” and “basketball arena” as content values for the content. The same complex machine vision module 556 may identify a basketball, a park background, and a concrete court surface and associate “amateur basketball game” and “playground basketball” as content values for the content.


These content values generated by machine vision module 556 can then be stored in content characteristic database 558 along with other characteristic values. Such characteristic values can include: one or more content values (i.e., an identification of what's in the content); a generation time; a generation time period; a generation location; a generation area; one or more quality values, any metadata value associated with content, an identifier for a particular piece of content, or any other such values. In some embodiments, a copy of content may be stored in content characteristic database 558 with location information, capture time information, and any other such information about a piece of content. In certain embodiments, content characteristic database 558 may anonymously store details about content use. For example, client devices 110, 120 can communicate details about presentation of the content on a screen of the device, and about screenshots taken of the content. Anonymous metrics about how often a piece of content is viewed as part of a story, how long the content is viewed for, and how frequently screenshots are taken may then be measured by server system 550, as part of analysis by content characteristic analysis module 554, with the resulting data stored in content characteristic database 558.


Trend analysis module 560 may then use details from content characteristic database 558 to identify patterns associated with content characteristics. Trend analysis module 560 may track how frequently machine vision module 556 associates content with the content value “basketball.” Trend analysis module 560 can also track content characteristics associated with location, times of day, times of year, holidays, and other such characteristics in addition to content characteristics. Further, multiple characteristics may be tracked together to identify complex patterns.


Story generation module 562 may then use information about pieces of content from content characteristic database 558 as well as information about trends from trend analysis module 560 to select particular pictures or videos for an automatically generated story. In various embodiments, story generation module 562 may use complex scoring, weighting, and other rules in generating a story. For example, certain embodiments may require that all pieces of content meet a quality threshold unless a trend having certain threshold characteristics is identified and all content associated with the trend are below the quality threshold. Another embodiment may weight story generation based on a number of stories currently available in a local geographic area. In still further embodiments, any number of complex rules may be applied together as part of story generation to filter images and videos for a story based on time, location, content, and quality.


Similarly, when a user selects a piece of content in a story, if a single input is provided, the system may select content for a sub-story using similar rules. For example, if a selected piece of content is associated with six different content characteristics, the system may attempt to provide images or videos for the sub-story having a variety of each of the six different content characteristics. Selection of a piece of content in the sub-story that shares two of the original six characteristics may then result in a second story that includes content having those two shared characteristics. Certain embodiments may allow content in sub-stories to be older or further away from a requesting client device 110, 120, while other systems may maintain strict limits on how far away and how recently pieces of content were generated. In certain embodiments, content selection may provide a user interface listing content characteristics, and a user may select which content characteristics are to be used to generate a sub-story.



FIG. 6 is a flowchart illustrating aspects of a method 600, according to some example embodiments. Method 600 is a method performed by a server system 550. For the purposes of illustration, method 600 is described with respect to server system 550. In other embodiments, method 600 may be performed by various other server system implementations.


Method 600 begins with operation 602 receiving, at an I/O module 552 of server system 550, a plurality of communications from a plurality of client devices 110, 120. Each communication includes a piece of content, a location associated with the content, and a time associated with the content.


Operation 604 then involves processing, by the content characteristic analysis module 554 of the server system 550, each content communication from the plurality of communications to determine a set of content characteristics for each piece of content.


Operation 606 then involves generating, using a story generation module 562 of server system 550, at least a first story set 292, where the first story set 292 includes a first plurality of content from the plurality of communications, and where the first plurality of content for the first story set 292 are selected based on the set of content characteristics for each piece of content of the first plurality of content. In certain embodiments, content characteristics are additionally identified using machine vision module 556 to identify content values. Additional embodiments of method 600 may also involve performing a trend analysis associated with one or more content characteristic values using trend analysis module 560, and a story may be generated based on trend analysis and content characteristics.


While method 400 and method 600 each present a set of operations in a particular order, each of these methods may be implemented with operations in different orders, or with additional operations included between the described operations. Other methods, including a variety of other system implementations and operations, are also possible in other embodiments.



FIG. 7 is a block diagram 700 illustrating architecture of software 702, which can be installed on any one or more of the devices described above. For example, in various embodiments, client devices 110 and 120 and server systems 150, 250, and 550 may be implemented using some or all of the elements of software 702. FIG. 7 is merely a non-limiting example of a software architecture, and it will be appreciated that many other architectures can be implemented to facilitate the functionality described herein. In various embodiments, the software 702 is implemented by hardware such as machine 900 of FIG. 9 that includes processors 910, memory 930, and I/O components 950. In this example architecture, the software 702 can be conceptualized as a stack of layers where each layer may provide a particular functionality. For example, the software 702 includes layers such as an operating system 704, libraries 706, frameworks 708, and applications 710. Operationally, the applications 710 invoke application programming interface (API) calls 712 through the software stack and receive messages 714 in response to the API calls 712, consistent with some embodiments.


In various implementations, the operating system 704 manages hardware resources and provides common services. The operating system 704 includes, for example, a kernel 720, services 722, and drivers 724. The kernel 720 acts as an abstraction layer between the hardware and the other software layers, consistent with some embodiments. For example, the kernel 720 provides memory management, processor management (e.g., scheduling), component management, networking, and security settings, among other functionality. The services 722 can provide other common services for the other software layers. The drivers 724 are responsible for controlling or interfacing with the underlying hardware, according to some embodiments. For instance, the drivers 724 can include display drivers, camera drivers, BLUETOOTH® or BLUETOOTH® Low Energy drivers, flash memory drivers, serial communication drivers (e.g., Universal Serial Bus (USB) drivers), WI-FI® drivers, audio drivers, power management drivers, and so fourth.


In some embodiments, the libraries 706 provide a low-level common infrastructure utilized by the applications 710. The libraries 706 can include system libraries 730 (e.g., C standard library) that can provide functions such as memory allocation functions, string manipulation functions, mathematic functions, and the like. In addition, the libraries 706 can include API libraries 732 such as media libraries (e.g., libraries to support presentation and manipulation of various media formats such as Moving Picture Experts Group-4 (MPEG4), Advanced Video Coding (H.264 or AVC), Moving Picture Experts Group Layer-3 (MP3), Advanced Audio Coding (AAC), Adaptive Multi-Rate (AMR) audio codec, Joint Photographic Experts Group (JPEG or JPG), or Portable Network Graphics (PNG)), graphics libraries (e.g., an OpenGL framework used to render in two dimensions (2D) and three dimensions (3D) in a graphic content on a display), database libraries (e.g., SQLite to provide various relational database functions), web libraries (e.g., WebKit to provide web browsing functionality), and the like. The libraries 706 can also include a wide variety of other libraries 734 to provide many other APIs to the applications 710.


The frameworks 708 provide a high-level common infrastructure that can be utilized by the applications 710, according to some embodiments. For example, the frameworks 708 provide various graphic user interface (GUI) functions, high-level resource management, high-level location services, and so forth. The frameworks 708 can provide a broad spectrum of other APIs that can be utilized by the applications 710, some of which may be specific to a particular operating system 704 or platform.


In an example embodiment, the applications 710 include a home application 750, a contacts application 752, a browser application 754, a book reader application 756, a location application 758, a media application 760, a messaging application 762, a game application 764, and a broad assortment of other applications such as a third party application 766. According to some embodiments, the applications 710 are programs that execute functions defined in the programs. Various programming languages can be employed to create one or more of the applications 710, structured in a variety of manners, such as object-oriented programming languages (e.g., Objective-C, Java, or C++) or procedural programming languages (e.g., C or assembly language). In a specific example, the third party application 766 (e.g., an application developed using the ANDROID™ or IOS™ software development kit (SDK) by an entity other than the vendor of the particular platform) may be mobile software running on a mobile operating system such as IOS™, ANDROID™, WINDOWS® Phone, or another mobile operating system. In this example, the third party application 766 can invoke the API calls 712 provided by the operating system 704 to facilitate functionality described herein.


Some embodiments may particularly include a story application 767. In certain embodiments, this may be a stand-alone application that operates to manage communications with a server system such as server system 150. In other embodiments, this functionality may be integrated with another application such as a social media application 760 or another such application. Story application 767 may manage collection of content using a camera device of machine 900, communication with a server system via I/O components 950, and receipt and storage of received stories in memory 930. Presentation of content and user inputs associated with content may be managed by story application 767 using different frameworks 708, library 706 elements, or operating system 704 elements operating on a machine 900.



FIG. 8 illustrates an example mobile device 800 executing a mobile operating system (e.g., IOS™, ANDROID™, WINDOWS® Phone, or other mobile operating systems), consistent with some embodiments. Mobile device 800 may implement software architecture 702 in certain embodiments. In one embodiment, the mobile device 800 includes a touch screen operable to receive tactile data from a user. The illustrated embodiment of mobile device 800 shows a plurality of images or videos presented as part of a story, with each piece of content have additional associated options and information. FIG. 8 particularly shows content 801 and associated information 802. For example, content 801 may be similar to content LA7. Associated information 802 may include multiple different details or content characteristics associated with content 801. A user selecting content 801 to generate a sub-story may select from the content characteristics or provide additional information related to the desired characteristics for a sub-story based on additional information 802 associated with content 801. The user may physically touch the mobile device 800, and in response to the touch, the mobile device 800 may determine tactile data such as touch location, touch force, or gesture motion. This input may then be sent to a server system to generate a sub-story and communicate the sub-story back to mobile device 800. In various example embodiments, the mobile device 800 displays a home screen operable to launch applications 710 or otherwise manage various aspects of the mobile device 800. In some example embodiments, the home screen provides status information such as battery life, connectivity, or other hardware statuses. The user can activate user interface elements by touching an area occupied by a respective user interface element. In this manner, the user interacts with the applications 710 of the mobile device 800. For example, touching the area occupied by a particular icon included in the home screen causes launching of an application 710 corresponding to the particular icon.


In certain embodiments, content may be presented within the touch screen of mobile device 800 operating as a client device 110, 120, and a touch input may be used to initiate a communication to a server system 550 to request a sub-story, as described above.


Many varieties of applications 710 (also referred to as “apps”) can be executing on the mobile device 800, such as native applications (e.g., applications programmed in Objective-C, Swift, or another suitable language running on IOS™ or applications 710 programmed in lava running on ANDROID™), mobile web applications (e.g., applications 710 written in Hypertext Markup Language-5 (HTML5)), or hybrid applications (e.g., a native shell application 710 that launches an HTML5 session). For example, the mobile device 800 includes a messaging app, an audio recording app, a camera app, a book reader app, a media app, a fitness app, a file management app, a location app, a browser app, a settings app, a contacts app, a telephone call app, or other apps (e.g., gaming apps, social networking apps, biometric monitoring apps). In another example, the mobile device 800 includes a social messaging app such as SNAPCHAT® that, consistent with some embodiments, allows users to send public content to a server system 550, and to receive stories from the server system 550. Such an SNAPCHAT application 710 may additionally enable exchange private ephemeral image and/or video content messages.



FIG. 9 is a block diagram illustrating components of a machine 900, according to some embodiments, able to read instructions from a machine-readable medium (e.g., a machine-readable storage medium) and perform any one or more of the methodologies discussed herein. Specifically, FIG. 9 shows a diagrammatic representation of the machine 900 in the example form of a computer system, within which instructions 916 (e.g., software, a program, an application 710, an apples, an app, or other executable code) for causing the machine 900 to perform any one or more of the methodologies discussed herein can be executed. In alternative embodiments, the machine 900 operates as a standalone device or can be coupled (e.g., networked) to other machines. In a networked deployment, the machine 900 may operate in the capacity of a server machine 550 or a client machine 110, 120 in a server-client network environment, or as a peer machine in a peer-to-peer (or distributed) network environment. The machine 900 can comprise, but not be limited to, a server computer, a client computer, a personal computer (PC), a tablet computer, a laptop computer, a netbook, a set-top box (STB), a personal digital assistant (PDA), an entertainment media system, a cellular telephone, a smart phone, a mobile device 800, a wearable device (e.g., a smart watch), a smart home device (e.g., a smart appliance), other smart devices, a web appliance, a network router, a network switch, a network bridge, or any machine capable of executing the instructions 916, sequentially or otherwise, that specify actions to be taken by the machine 900. Further, while only a single machine 900 is illustrated, the term “machine” shall also be taken to include a collection of machines 900 that individually or jointly execute the instructions 916 to perform any one or more of the methodologies discussed herein.


In various embodiments, the machine 900 comprises processors 910, memory 930, and I/O components 950, which can be configured to communicate with each other via a bus 902. In an example embodiment, the processors 910 (e.g., a central processing unit (CPU), a reduced instruction set computing (RISC) processor, a complex instruction set computing (CISC) processor, a graphics processing unit (GPU), a digital signal processor (DSP), an application specific integrated circuit (ASIC), a radio-frequency integrated circuit (RFIC), another processor, or any suitable combination thereof) include, for example, a processor 912 and a processor 914 that may execute the instructions 916. The term “processor” is intended to include multi-core processors 910 that may comprise two or more independent processors 912, 914 (also referred to as “cores”) that can execute instructions 916 contemporaneously. Although FIG. 9 shows multiple processors 910, the machine 900 may include a single processor 910 with a single core, a single processor 910 with multiple cores (e.g., a multi-core processor 910), multiple processors 912, 914 with a single core, multiple processors 910, 912 with multiples cores, or any combination thereof.


The memory 930 comprises a main memory 932, a static memory 934, and a storage unit 936 accessible to the processors 910 via the bus 902, according to some embodiments. The storage unit 936 can include a machine-readable medium 938 on which are stored the instructions 916 embodying any one or more of the methodologies or functions described herein. The instructions 916 can also reside, completely or at least partially, within the main memory 932, within the static memory 934, within at least one of the processors 910 (e.g., within the processor's cache memory), or any suitable combination thereof, during execution thereof by the machine 900. Accordingly, in various embodiments, the main memory 932, the static memory 934, and the processors 910 are considered machine-readable media 938.


As used herein, the term “memory” refers to a machine-readable medium 938 able to store data temporarily or permanently and may be taken to include, but not be limited to, random-access memory (RAM), read-only memory (ROM), buffer memory, flash memory, and cache memory. While the machine-readable medium 938 is shown, in an example embodiment, to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) able to store the instructions 916. The term “machine-readable medium” shall also be taken to include any medium, or combination of multiple media, that is capable of storing instructions (e.g., instructions 916) for execution by a machine (e.g., machine 900), such that the instructions 916, when executed by one or more processors of the machine 900 (e.g., processors 910), cause the machine 900 to perform any one or more of the methodologies described herein. Accordingly, a “machine-readable medium” refers to a single storage apparatus or device, as well as “cloud-based” storage systems or storage networks that include multiple storage apparatus or devices. The term “machine-readable medium” shall accordingly be taken to include, but not be limited to, one or more data repositories in the form of a solid-state memory (e.g., flash memory), an optical medium, a magnetic medium, other non-volatile memory (e.g., erasable programmable read-only memory (EPROM)), or any suitable combination thereof. The term “machine-readable medium” specifically excludes non-statutory signals per se.


The I/O components 950 include a wide variety of components to receive input, provide output, produce output, transmit information, exchange information, capture measurements, and so on. In general, it will be appreciated that the I/O components 950 can include many other components that are not shown in FIG. 9. The I/O components 950 are grouped according to functionality merely for simplifying the following discussion, and the grouping is in no way limiting. In various example embodiments, the I/O components 950 include output components 952 and input components 954. The output components 952 include visual components (e.g., a display such as a plasma display panel (PDP), a light emitting diode (LED) display, a liquid crystal display (LCD), a projector, or a cathode ray tube (CRT)), acoustic components (e.g., speakers), haptic components (e.g., a vibratory motor), other signal generators, and so forth. The input components 954 include alphanumeric input components (e.g., a keyboard, a touch screen configured to receive alphanumeric input, a photo-optical keyboard, or other alphanumeric input components), point-based input components (e.g., a mouse, a touchpad, a trackball, a joystick, a motion sensor, or other pointing instruments), tactile input components (e.g., a physical button, a touch screen that provides location and force of touches or touch gestures, or other tactile input components), audio input components (e.g., a microphone), and the like.


In some further example embodiments, the I/O components 950 include biometric components 956, motion components 958, environmental components 960, or position components 962, among a wide array of other components. For example, the biometric components 956 include components to detect expressions (e.g., hand expressions, facial expressions, vocal expressions, body gestures, or eye tracking), measure biosignals (e.g., blood pressure, heart rate, body temperature, perspiration, or brain waves), identify a person (e.g., voice identification, retinal identification, facial identification, fingerprint identification, or electroencephalogram based identification), and the like. The motion components 958 include acceleration sensor components (e.g., accelerometer), gravitation sensor components, rotation sensor components (e.g., gyroscope), and so forth. The environmental components 960 include, for example, illumination sensor components (e.g., photometer), temperature sensor components (e.g., one or more thermometers that detect ambient temperature), humidity sensor components, pressure sensor components (e.g., barometer), acoustic sensor components (e.g., one or more microphones that detect background noise), proximity sensor components (e.g., infrared sensors that detect nearby objects), gas sensor components (e.g., machine olfaction detection sensors, gas detection sensors to detect concentrations of hazardous gases for safety or to measure pollutants in the atmosphere), or other components that may provide indications, measurements, or signals corresponding to a surrounding physical environment. The position components 962 include location sensor components (e.g., a Global Positioning System (GPS) receiver component), altitude sensor components (e.g., altimeters or barometers that detect air pressure from which altitude may be derived), orientation sensor components (e.g., magnetometers), and the like.


Communication can be implemented using a wide variety of technologies. The I/O components 950 may include communication components 964 operable to couple the machine 900 to a network 980 or devices 970 via a coupling 982 and a coupling 972, respectively. For example, the communication components 964 include a network interface component or another suitable device to interface with the network 980. In further examples, communication components 964 include wired communication components, wireless communication components, cellular communication components, near field communication (NFC) components, BLUETOOTH® components (e.g., BLUETOOTH® Low Energy), WI-FI® components, and other communication components to provide communication via other modalities. The devices 970 may be another machine 900 or any of a wide variety of peripheral devices (e.g., a peripheral device coupled via a Universal Serial Bus (USB)).


Moreover, in some embodiments, the communication components 964 detect identifiers or include components operable to detect identifiers. For example, the communication components 964 include radio frequency identification (RFID) tag reader components, NFC smart tag detection components, optical reader components (e.g., an optical sensor to detect a one-dimensional bar codes such as a Universal Product Code (UPC) bar code, multi-dimensional bar codes such as a Quick Response (QR) code, Aztec Code, Data Matrix, Dataglyph, MaxiCode, PDF417, Ultra Code, Uniform Commercial Code Reduced Space Symbology (UCC RSS)-2D bar codes, and other optical codes), acoustic detection components (e.g., microphones to identify tagged audio signals), or any suitable combination thereof. In addition, a variety of information can be derived via the communication components 964, such as location via Internet Protocol (IP) geo-location, location via WI-FI® signal triangulation, location via detecting a BLUETOOTH® or NFC beacon signal that may indicate a particular location, and so forth.


Transmission Medium


In various example embodiments, one or more portions of the network 980 can be an ad hoc network, an intranet, an extranet, a virtual private network (VPN), a local area network (LAN), a wireless LAN (WLAN), a wide area network (WAN), a wireless WAN (WWAN), a metropolitan area network (MAN), the Internet, a portion of the Internet, a portion of the public switched telephone network (PSTN), a plain old telephone service (POTS) network, a cellular telephone network, a wireless network, a WI-FI® network, another type of network, or a combination of two or more such networks. For example, the network 980 or a portion of the network 980 may include a wireless or cellular network, and the coupling 982 may be a Code Division Multiple Access (CDMA) connection, a Global System for Mobile communications (GSM) connection, or another type of cellular or wireless coupling. In this example, the coupling 982 can implement any of a variety of types of data transfer technology, such as Single Carrier Radio Transmission Technology (1×RTT), Evolution-Data Optimized (EVDO) technology, General Packet Radio Service (GPRS) technology, Enhanced Data rates for GSM Evolution (EDGE) technology, third Generation Partnership Project (3GPP) including 3G, fourth generation wireless (4G) networks, Universal Mobile Telecommunications System (UMTS), High Speed Packet Access (HSPA), Worldwide Interoperability for Microwave Access (WiMAX), Long Term Evolution (LTE) standard, others defined by various standard-setting organizations, other long range protocols, or other data transfer technology.


In example embodiments, the instructions 916 are transmitted or received over the network 980 using a transmission medium via a network interface device (e.g., a network interface component included in the communication components 964) and utilizing any one of a number of well-known transfer protocols (e.g., Hypertext Transfer Protocol (HTTP)). Similarly, in other example embodiments, the instructions 916 are transmitted or received using a transmission medium via the coupling 972 (e.g., a peer-to-peer coupling) to the devices 970. The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding, or carrying the instructions 916 for execution by the machine 900, and includes digital or analog communications signals or other intangible media to facilitate communication of such software.


Furthermore, the machine-readable medium 938 is non-transitory (in other words, not having any transitory signals) in that it does not embody a propagating signal. However, labeling the machine-readable medium 938 “non-transitory” should not be construed to mean that the medium is incapable of movement; the medium 938 should be considered as being transportable from one physical location to another. Additionally, since the machine-readable medium 938 is tangible, the medium 938 may be considered to be a machine-readable device.


Language


Throughout this specification, plural instances may implement components, operations, or structures described as a single instance. Although individual operations of one or more methods are illustrated and described as separate operations, one or more of the individual operations may be performed concurrently, and nothing requires that the operations be performed in the order illustrated. Structures and functionality presented as separate components in example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the subject matter herein.


Although an overview of the inventive subject matter has been described with reference to specific example embodiments, various modifications and changes may be made to these embodiments without departing from the broader scope of embodiments of the present disclosure. Such embodiments of the inventive subject matter may be referred to herein, individually or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single disclosure or inventive concept if more than one is, in fact, disclosed.


The embodiments illustrated herein are described in sufficient detail to enable those skilled in the art to practice the teachings disclosed. Other embodiments may be used and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. The Detailed Description, therefore, is not to be taken in a limiting sense, and the scope of various embodiments is defined only by the appended claims, along with the full range of equivalents to which such claims are entitled.


As used herein, the term “or” may be construed in either an inclusive or exclusive sense. Moreover, plural instances may be provided for resources, operations, or structures described herein as a single instance. Additionally, boundaries between various resources, operations, modules, engines, and data stores are somewhat arbitrary, and particular operations are illustrated in a context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within a scope of various embodiments of the present disclosure. In general, structures and functionality presented as separate resources in the example configurations may be implemented as a combined structure or resource. Similarly, structures and functionality presented as a single resource may be implemented as separate resources. These and other variations, modifications, additions, and improvements fall within a scope of embodiments of the present disclosure as represented by the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.

Claims
  • 1. A method comprising: receiving, at a server system, a plurality of content communications from a first plurality of client devices, each content communication from the plurality of content communications comprising a video clip, a location and a time associated with the video clip;processing, by the server system, each content communication from the plurality of content communications to determine a plurality of content characteristics, for each video clip, the plurality of content characteristics comprising quality metrics;automatically generating, by the server system, at least a first media collection, wherein the first media collection comprises a first plurality of video clips from the plurality of content communications associated with a first geographic visibility area, and wherein the first plurality of video clips for the first media collection are selected based on the location for each video clip and the quality metrics for each video clip of the first plurality of video clips;communicating the first media collection to a second plurality of client devices within the first geographic visibility area;analyzing a plurality of incoming content messages from the second plurality of client devices within the first geographic visibility area to determine system trends associated with the first media collection;adjusting the first geographic visibility area of the first media collection to a second geographic visibility area based on the system trends associated with the first media collection;communicating the first media collection to a third plurality of client devices within the second geographic visibility area, the third plurality of client devices within the second geographic visibility area comprising a first client device;receiving, at the server system from the first client device, a selection communication associated with a video clip of the first media collection;automatically generating, by the server system, a second media collection, wherein the second media collection comprises a second plurality of video clips, and wherein the second plurality of video clips are selected from the first plurality of video clips based on having one or more content characteristics in common with the video clip associated with the selection communication; andcommunicating the second media collection to the first client device.
  • 2. The method of claim 1 wherein the first plurality of video clips is further selected based on: a content time period; andone or more content categories associated with each video clip of the first plurality of video clips by a machine vision analysis of each video clip.
  • 3. The method of claim 2 further comprising, prior to generating the first media collection: determining, by the server system, a baseline content receipt rate for a first set of content characteristics;determining, by the server system, that a current content receipt rate associated with the first set of content characteristics has deviated from the baseline content receipt rate by more than a threshold amount; andadjusting a media collection visibility area for the first media collection based on the determination that the current content receipt rate for the first set of content characteristics has deviated from the baseline content receipt rate by more than the threshold amount.
  • 4. The method of claim 2 wherein the one or more content categories are determined using machine vision processes operating as part of the server system to analyze each received content communication.
  • 5. The method of claim 4 wherein the machine vision processes generate one or more content characteristic values for each video clip from a content dictionary; and wherein the one or more content categories are determined using the content characteristic values for each video clip.
  • 6. The method of claim 1 wherein first geographic visibility area is a local geographic area, the second geographic visibility area is a regional geographic area comprising a plurality of local geographic areas, and the first geographic visibility area is a first local geographic area of the plurality of local geographic areas within the regional geographic area.
  • 7. The method of claim 1 wherein the second geographic visibility area is a local geographic area, the first geographic visibility area is a regional geographic area comprising a plurality of local geographic areas, and the second geographic visibility area is a first local geographic area of the plurality of local geographic areas within the regional geographic area.
  • 8. The method of claim 1 further comprising: receiving, from the first client device, a first client device location;communicating at least two stories to the first client device, wherein the at least two stories comprise the first media collection, wherein each of the at least two stories is associated with the first geographic visibility area, and wherein the first geographic visibility area for each of the at least two stories encompasses the first client device location.
  • 9. The method of claim 1 further comprising: after the adjusting the first geographic visibility area, automatically re-generating, by the server system, the first media collection based on the second geographic visibility area.
  • 10. A non-transitory computer readable medium comprising computer readable instructions that, when executed by one or more processors cause a server system to: receive, at a server system, a plurality of content communications from a first plurality of client devices, each content communication from the plurality of content communications comprising a video clip, a location and a time associated with the video clip;process, by the server system, each content communication from the plurality of content communications to determine a plurality of content characteristics, for each video clip, the plurality of content characteristics comprising quality metrics;automatically generate, by the server system, at least a first media collection, wherein the first media collection comprises a first plurality of video clips from the plurality of content communications associated with a first geographic visibility area, and wherein the first plurality of video clips for the first media collection are selected based on the location for each video clip and the quality metrics for each video clip of the first plurality of video clips;communicate the first media collection to a second plurality of client devices within the first geographic visibility area;analyze a plurality of incoming content messages from the second plurality of client devices within the first geographic visibility area to determine system trends associated with the first media collection;adjust the first geographic visibility area of the first media collection to a second geographic visibility area based on the system trends associated with the first media collection;communicate the first media collection to a third plurality of client devices within the second geographic visibility area, the third plurality of client devices within the second geographic visibility area comprising a first client device;receive, at the server system from the first client device, a selection communication associated with a video clip of the first media collection;automatically generate, by the server system, a second media collection, wherein the second media collection comprises a second plurality of video clips, and wherein the second plurality of video clips are selected from the first plurality of video clips based on having one or more content characteristics in common with the video clip associated with the selection communication; andcommunicate the second media collection to the first client device.
  • 11. The non-transitory computer readable medium of claim 10 wherein the set of content characteristics for each video clip comprises: a local content geolocation area;a content time period; andone or more content categories determined from a machine vision analysis of each piece of content.
  • 12. The non-transitory computer readable medium of claim 10 wherein the computer readable instructions further cause the server system to: after the adjusting the first geographic visibility area, automatically re-generating, by the server system, the first media collection based on the second geographic visibility area.
PRIORITY

This application is a continuation of and claims the benefit of priority of U.S. patent application Ser. No. 14/704,188, filed on May 5, 2015, which is hereby incorporated by reference herein in its entirety.

US Referenced Citations (612)
Number Name Date Kind
666223 Shedlock Jan 1901 A
4581634 Williams Apr 1986 A
4975690 Torres Dec 1990 A
5072412 Henderson, Jr. et al. Dec 1991 A
5493692 Theimer et al. Feb 1996 A
5713073 Warsta Jan 1998 A
5754939 Herz et al. May 1998 A
5855008 Goldhaber et al. Dec 1998 A
5883639 Walton et al. Mar 1999 A
5999932 Paul Dec 1999 A
6012098 Bayeh et al. Jan 2000 A
6014090 Rosen et al. Jan 2000 A
6029141 Bezos et al. Feb 2000 A
6038295 Mattes Mar 2000 A
6049711 Yehezkel et al. Apr 2000 A
6154764 Nitta et al. Nov 2000 A
6167435 Druckenmiller et al. Dec 2000 A
6204840 Petelycky et al. Mar 2001 B1
6205432 Gabbard et al. Mar 2001 B1
6216141 Straub et al. Apr 2001 B1
6285381 Sawano et al. Sep 2001 B1
6285987 Roth et al. Sep 2001 B1
6310694 Okimoto et al. Oct 2001 B1
6317789 Rakavy et al. Nov 2001 B1
6334149 Davis, Jr. et al. Dec 2001 B1
6349203 Asaoka et al. Feb 2002 B1
6353170 Eyzaguirre et al. Mar 2002 B1
6446004 Cao et al. Sep 2002 B1
6449657 Stanbach et al. Sep 2002 B2
6456852 Bar et al. Sep 2002 B2
6484196 Maurille Nov 2002 B1
6487601 Hubacher et al. Nov 2002 B1
6523008 Avrunin Feb 2003 B1
6542749 Tanaka et al. Apr 2003 B2
6549768 Fraccaroli Apr 2003 B1
6618593 Drutman et al. Sep 2003 B1
6622174 Ukita et al. Sep 2003 B1
6631463 Floyd et al. Oct 2003 B1
6636247 Hamzy et al. Oct 2003 B1
6636855 Holloway et al. Oct 2003 B2
6643684 Malkin et al. Nov 2003 B1
6658095 Yoakum et al. Dec 2003 B1
6665531 Soderbacka et al. Dec 2003 B1
6668173 Greene Dec 2003 B2
6684238 Dutta Jan 2004 B1
6684257 Camut et al. Jan 2004 B1
6698020 Zigmond et al. Feb 2004 B1
6700506 Winkler Mar 2004 B1
6720860 Narayanaswami Apr 2004 B1
6724403 Santoro et al. Apr 2004 B1
6757713 Ogilvie et al. Jun 2004 B1
6832222 Zimowski Dec 2004 B1
6834195 Brandenberg et al. Dec 2004 B2
6836792 Chen Dec 2004 B1
6898626 Ohashi May 2005 B2
6959324 Kubik et al. Oct 2005 B1
6970088 Kovach Nov 2005 B2
6970907 Ullmann et al. Nov 2005 B1
6980909 Root et al. Dec 2005 B2
6981040 Konig et al. Dec 2005 B1
7020494 Spriestersbach et al. Mar 2006 B2
7027124 Foote et al. Apr 2006 B2
7043555 McClain et al. May 2006 B1
7072963 Anderson et al. Jul 2006 B2
7085571 Kalhan et al. Aug 2006 B2
7110744 Freeny, Jr. Sep 2006 B2
7124164 Chemtob Oct 2006 B1
7149893 Leonard et al. Dec 2006 B1
7173651 Knowles Feb 2007 B1
7188143 Szeto Mar 2007 B2
7203380 Chiu et al. Apr 2007 B2
7206568 Sudit Apr 2007 B2
7227937 Yoakum et al. Jun 2007 B1
7237002 Estrada et al. Jun 2007 B1
7240089 Boudreau Jul 2007 B2
7269426 Kokkonen et al. Sep 2007 B2
7280658 Amini et al. Oct 2007 B2
7315823 Brondrup Jan 2008 B2
7349768 Bruce et al. Mar 2008 B2
7356564 Hartselle et al. Apr 2008 B2
7394345 Ehlinger et al. Jul 2008 B1
7411493 Smith Aug 2008 B2
7423580 Markhovsky et al. Sep 2008 B2
7454442 Cobleigh et al. Nov 2008 B2
7508419 Toyama et al. Mar 2009 B2
7512649 Faybishenko et al. Mar 2009 B2
7519670 Hagale et al. Apr 2009 B2
7535890 Rojas May 2009 B2
7546554 Chiu et al. Jun 2009 B2
7607096 Oreizy et al. Oct 2009 B2
7639943 Kalajan Dec 2009 B1
7650231 Gadler Jan 2010 B2
7668537 DeVries Feb 2010 B2
7770137 Forbes et al. Aug 2010 B2
7778973 Choi Aug 2010 B2
7779444 Glad Aug 2010 B2
7787886 Markhovsky et al. Aug 2010 B2
7796946 Eisenbach Sep 2010 B2
7801954 Cadiz et al. Sep 2010 B2
7856360 Kramer et al. Dec 2010 B2
8001204 Burtner et al. Aug 2011 B2
8032586 Challenger et al. Oct 2011 B2
8082255 Carlson, Jr. et al. Dec 2011 B1
8090351 Klein Jan 2012 B2
8098904 Ioffe et al. Jan 2012 B2
8099109 Altman et al. Jan 2012 B2
8112716 Kobayashi Feb 2012 B2
8131597 Hudetz Mar 2012 B2
8135166 Rhoads Mar 2012 B2
8136028 Loeb et al. Mar 2012 B1
8146001 Reese Mar 2012 B1
8161115 Yamamoto Apr 2012 B2
8161417 Lee Apr 2012 B1
8195203 Tseng Jun 2012 B1
8199747 Rojas et al. Jun 2012 B2
8208943 Petersen Jun 2012 B2
8214443 Hamburg Jul 2012 B2
8234350 Gu et al. Jul 2012 B1
8276092 Narayanan et al. Sep 2012 B1
8279090 Becker Oct 2012 B2
8279319 Date Oct 2012 B2
8280406 Ziskind et al. Oct 2012 B2
8285199 Hsu et al. Oct 2012 B2
8287380 Nguyen et al. Oct 2012 B2
8301159 Hamynen et al. Oct 2012 B2
8306922 Kunal et al. Nov 2012 B1
8312086 Velusamy et al. Nov 2012 B2
8312097 Siegel et al. Nov 2012 B1
8326315 Phillips et al. Dec 2012 B2
8326327 Hymel et al. Dec 2012 B2
8332475 Rosen et al. Dec 2012 B2
8352546 Dollard Jan 2013 B1
8379130 Forutanpour et al. Feb 2013 B2
8385950 Wagner et al. Feb 2013 B1
8402097 Szeto Mar 2013 B2
8405773 Hayashi et al. Mar 2013 B2
8418067 Cheng et al. Apr 2013 B2
8423409 Rao Apr 2013 B2
8471914 Sakiyama et al. Jun 2013 B2
8472935 Fujisaki Jun 2013 B1
8510383 Hurley et al. Aug 2013 B2
8527345 Rothschild et al. Sep 2013 B2
8554627 Svendsen et al. Oct 2013 B2
8560612 Kilmer et al. Oct 2013 B2
8594680 Ledlie et al. Nov 2013 B2
8613089 Holloway et al. Dec 2013 B1
8639767 Harris et al. Jan 2014 B1
8660358 Bergboer et al. Feb 2014 B1
8660369 Llano et al. Feb 2014 B2
8660793 Ngo et al. Feb 2014 B2
8682350 Altman et al. Mar 2014 B2
8718333 Wolf et al. May 2014 B2
8724622 Rojas May 2014 B2
8732168 Johnson May 2014 B2
8744523 Fan et al. Jun 2014 B2
8745132 Obradovich Jun 2014 B2
8761800 Kuwahara Jun 2014 B2
8768876 Shim et al. Jul 2014 B2
8775972 Spiegel Jul 2014 B2
8788680 Naik Jul 2014 B1
8790187 Walker et al. Jul 2014 B2
8797415 Arnold Aug 2014 B2
8798646 Wang et al. Aug 2014 B1
8849829 Shalabi et al. Sep 2014 B2
8856349 Jain et al. Oct 2014 B2
8874677 Rosen et al. Oct 2014 B2
8886227 Schmidt et al. Nov 2014 B2
8909679 Root et al. Dec 2014 B2
8909725 Sehn Dec 2014 B1
8965409 Abhyanker Feb 2015 B2
8972357 Shim et al. Mar 2015 B2
8995433 Rojas Mar 2015 B2
9015285 Ebsen et al. Apr 2015 B1
9020745 Johnston et al. Apr 2015 B2
9040574 Wang et al. May 2015 B2
9055416 Rosen et al. Jun 2015 B2
9094137 Sehn et al. Jul 2015 B1
9100806 Rosen et al. Aug 2015 B2
9100807 Rosen et al. Aug 2015 B2
9113301 Spiegel et al. Aug 2015 B1
9119027 Sharon et al. Aug 2015 B2
9123074 Jacobs et al. Sep 2015 B2
9143382 Bhogal et al. Sep 2015 B2
9143681 Ebsen et al. Sep 2015 B1
9152477 Campbell et al. Oct 2015 B1
9191776 Root et al. Nov 2015 B2
9204252 Root Dec 2015 B2
9225897 Sehn et al. Dec 2015 B1
9256761 Sahu et al. Feb 2016 B1
9258459 Hartley Feb 2016 B2
9344606 Hartley et al. May 2016 B2
9385983 Sehn Jul 2016 B1
9396354 Murphy et al. Jul 2016 B1
9407712 Sehn Aug 2016 B1
9407816 Sehn Aug 2016 B1
9418482 Yang et al. Aug 2016 B1
9430783 Sehn Aug 2016 B1
9439041 Parvizi et al. Sep 2016 B2
9443227 Evans et al. Sep 2016 B2
9450907 Pridmore et al. Sep 2016 B2
9459778 Hogeg et al. Oct 2016 B2
9489661 Evans et al. Nov 2016 B2
9491134 Rosen et al. Nov 2016 B2
9532171 Allen et al. Dec 2016 B2
9537811 Allen et al. Jan 2017 B2
9552399 Browning et al. Jan 2017 B1
9628950 Noeth et al. Apr 2017 B1
9652475 Shakib May 2017 B2
9710821 Heath Jul 2017 B2
9854219 Sehn Dec 2017 B2
9881094 Pavlovskaia Jan 2018 B2
9952742 Plesur et al. Apr 2018 B2
10223438 Xu et al. Mar 2019 B1
10592574 Pavlovskaia et al. Mar 2020 B2
20020047868 Miyazawa Apr 2002 A1
20020053078 Holtz et al. May 2002 A1
20020078456 Hudson et al. Jun 2002 A1
20020087631 Sharma Jul 2002 A1
20020097257 Miller et al. Jul 2002 A1
20020122659 Mcgrath et al. Sep 2002 A1
20020128047 Gates Sep 2002 A1
20020144154 Tomkow Oct 2002 A1
20030001846 Davis et al. Jan 2003 A1
20030016247 Lai et al. Jan 2003 A1
20030017823 Mager et al. Jan 2003 A1
20030020623 Cao et al. Jan 2003 A1
20030023874 Prokupets et al. Jan 2003 A1
20030037124 Yamaura et al. Feb 2003 A1
20030052925 Daimon et al. Mar 2003 A1
20030101230 Benschoter et al. May 2003 A1
20030110503 Perkes Jun 2003 A1
20030126215 Udell Jul 2003 A1
20030131362 Jasinschi et al. Jul 2003 A1
20030148773 Spriestersbach et al. Aug 2003 A1
20030164856 Prager et al. Sep 2003 A1
20030229607 Zellweger et al. Dec 2003 A1
20040027371 Jaeger Feb 2004 A1
20040064429 Hirstius et al. Apr 2004 A1
20040078367 Anderson et al. Apr 2004 A1
20040111467 Willis Jun 2004 A1
20040158739 Wakai et al. Aug 2004 A1
20040189465 Capobianco et al. Sep 2004 A1
20040203959 Coombes Oct 2004 A1
20040215625 Svendsen et al. Oct 2004 A1
20040243531 Dean Dec 2004 A1
20040243688 Wugofski Dec 2004 A1
20050021444 Bauer et al. Jan 2005 A1
20050022211 Veselov et al. Jan 2005 A1
20050048989 Jung Mar 2005 A1
20050078804 Yomoda Apr 2005 A1
20050097176 Schatz et al. May 2005 A1
20050102381 Jiang et al. May 2005 A1
20050104976 Currans May 2005 A1
20050114783 Szeto May 2005 A1
20050119936 Buchanan et al. Jun 2005 A1
20050122405 Voss et al. Jun 2005 A1
20050288954 McCarthy et al. Dec 2005 A1
20060007901 Roskowski Jan 2006 A1
20060026067 Nicholas et al. Feb 2006 A1
20060107297 Toyama et al. May 2006 A1
20060114338 Rothschild Jun 2006 A1
20060119882 Harris et al. Jun 2006 A1
20060242239 Morishima et al. Oct 2006 A1
20060252438 Ansamaa et al. Nov 2006 A1
20060287878 Wadhwa et al. Dec 2006 A1
20070004426 Pfleging et al. Jan 2007 A1
20070073517 Panje Mar 2007 A1
20070075898 Markhovsky et al. Apr 2007 A1
20070136228 Petersen Jun 2007 A1
20070198340 Lucovsky et al. Aug 2007 A1
20070198495 Buron et al. Aug 2007 A1
20070208751 Cowan et al. Sep 2007 A1
20070210936 Nicholson Sep 2007 A1
20070214180 Crawford Sep 2007 A1
20070233556 Koningstein Oct 2007 A1
20070233859 Zhao et al. Oct 2007 A1
20070243887 Bandhole et al. Oct 2007 A1
20070244750 Grannan et al. Oct 2007 A1
20070255456 Funayama Nov 2007 A1
20070281690 Altman et al. Dec 2007 A1
20080022329 Glad Jan 2008 A1
20080032703 Krumm et al. Feb 2008 A1
20080043041 Hedenstroem et al. Feb 2008 A2
20080076505 Ngyen et al. Mar 2008 A1
20080082499 Koski Apr 2008 A1
20080092233 Tian et al. Apr 2008 A1
20080109844 Baldeschweiler et al. May 2008 A1
20080120409 Sun et al. May 2008 A1
20080147730 Lee et al. Jun 2008 A1
20080148150 Mall Jun 2008 A1
20080158230 Sharma et al. Jul 2008 A1
20080168033 Ott et al. Jul 2008 A1
20080168489 Schraga Jul 2008 A1
20080021421 Rasanen et al. Sep 2008 A1
20080288338 Wiseman et al. Nov 2008 A1
20080306826 Kramer et al. Dec 2008 A1
20080313329 Wang et al. Dec 2008 A1
20080318616 Chipalkatti et al. Dec 2008 A1
20090006191 Arankalle et al. Jan 2009 A1
20090015703 Kim et al. Jan 2009 A1
20090030774 Rothschild et al. Jan 2009 A1
20090030999 Gatzke et al. Jan 2009 A1
20090058822 Chaudhri Mar 2009 A1
20090079846 Chou Mar 2009 A1
20090008971 Wood et al. Apr 2009 A1
20090093261 Ziskind Apr 2009 A1
20090132341 Klinger May 2009 A1
20090132453 Hangartner et al. May 2009 A1
20090132665 Thomsen et al. May 2009 A1
20090148045 Lee et al. Jun 2009 A1
20090153492 Popp Jun 2009 A1
20090157450 Athsani et al. Jun 2009 A1
20090157752 Gonzalez Jun 2009 A1
20090160970 Fredlund et al. Jun 2009 A1
20090163182 Gatti et al. Jun 2009 A1
20090164641 Rogers Jun 2009 A1
20090177299 Van De Sluis Jul 2009 A1
20090192900 Collision Jul 2009 A1
20090199242 Johnson et al. Aug 2009 A1
20090215469 Fisher et al. Aug 2009 A1
20090232354 Camp, Jr. et al. Sep 2009 A1
20090234815 Boerries et al. Sep 2009 A1
20090239552 Churchill et al. Sep 2009 A1
20090249222 Schmidt et al. Oct 2009 A1
20090249244 Robinson et al. Oct 2009 A1
20090265647 Martin et al. Oct 2009 A1
20090288022 Almstrand et al. Nov 2009 A1
20090291672 Treves et al. Nov 2009 A1
20090292608 Polachek Nov 2009 A1
20090319607 Belz et al. Dec 2009 A1
20090327073 Li Dec 2009 A1
20100062794 Han Mar 2010 A1
20100082427 Burgener et al. Apr 2010 A1
20100082693 Hugg et al. Apr 2010 A1
20100083124 Druzgalski et al. Apr 2010 A1
20100100537 Druzgalski Apr 2010 A1
20100100568 Papin Apr 2010 A1
20100113065 Narayan et al. May 2010 A1
20100130233 Lansing May 2010 A1
20100131880 Lee et al. May 2010 A1
20100131895 Wohlert May 2010 A1
20100153144 Miller et al. Jun 2010 A1
20100159944 Pascal et al. Jun 2010 A1
20100161658 Hamynen et al. Jun 2010 A1
20100161831 Haas et al. Jun 2010 A1
20100162149 Sheleheda et al. Jun 2010 A1
20100177938 Martinez et al. Jul 2010 A1
20100183280 Beauregard et al. Jul 2010 A1
20100185552 Deluca et al. Jul 2010 A1
20100185665 Horn et al. Jul 2010 A1
20100191631 Weidmann Jul 2010 A1
20100197318 Peterson et al. Aug 2010 A1
20100197319 Petersen et al. Aug 2010 A1
20100198683 Aarabi Aug 2010 A1
20100198694 Muthukrishnan Aug 2010 A1
20100198826 Petersen Aug 2010 A1
20100198828 Petersen et al. Aug 2010 A1
20100198862 Jennings et al. Aug 2010 A1
20100198870 Petersen et al. Aug 2010 A1
20100198917 Petersen et al. Aug 2010 A1
20100201482 Robertson et al. Aug 2010 A1
20100201536 Robertson et al. Aug 2010 A1
20100214436 Kim et al. Aug 2010 A1
20100223128 Dukellis et al. Sep 2010 A1
20100223343 Bosan et al. Sep 2010 A1
20100250109 Johnston et al. Sep 2010 A1
20100257196 Waters et al. Oct 2010 A1
20100259386 Holley et al. Oct 2010 A1
20100273509 Sweeney et al. Oct 2010 A1
20100281045 Dean Nov 2010 A1
20100306669 Della Pasqua Dec 2010 A1
20100313009 Combet et al. Dec 2010 A1
20110004071 Faiola et al. Jan 2011 A1
20110010205 Richards Jan 2011 A1
20110029512 Folgner et al. Feb 2011 A1
20110040783 Uemichi et al. Feb 2011 A1
20110040804 Peirce et al. Feb 2011 A1
20110050909 Ellenby et al. Mar 2011 A1
20110050915 Wang et al. Mar 2011 A1
20110064388 Brown et al. Mar 2011 A1
20110066743 Hurley et al. Mar 2011 A1
20110083101 Sharon et al. Apr 2011 A1
20110099199 Stalenhoef et al. Apr 2011 A1
20110102630 Rukes May 2011 A1
20110119133 Igelman et al. May 2011 A1
20110137881 Cheng et al. Jun 2011 A1
20110145564 Moshir et al. Jun 2011 A1
20110159890 Fortescue et al. Jun 2011 A1
20110164163 Bilbrey et al. Jul 2011 A1
20110173150 Van Zwol et al. Jul 2011 A1
20110197194 D'Angelo et al. Aug 2011 A1
20110202598 Evans et al. Aug 2011 A1
20110202968 Nurmi Aug 2011 A1
20110211534 Schmidt et al. Sep 2011 A1
20110213845 Logan et al. Sep 2011 A1
20110215966 Kim et al. Sep 2011 A1
20110225048 Nair Sep 2011 A1
20110238763 Shin et al. Sep 2011 A1
20110255736 Thompson et al. Oct 2011 A1
20110028321 Berger et al. Nov 2011 A1
20110273575 Lee Nov 2011 A1
20110282799 Huston Nov 2011 A1
20110283188 Farrenkopf Nov 2011 A1
20110314419 Dunn et al. Dec 2011 A1
20110320373 Lee et al. Dec 2011 A1
20120150978 Monaco Jan 2012 A1
20120028659 Whitney et al. Feb 2012 A1
20120033718 Kauffman et al. Feb 2012 A1
20120036015 Sheikh Feb 2012 A1
20120036443 Ohmori et al. Feb 2012 A1
20120054797 Skog et al. Mar 2012 A1
20120059722 Rao Mar 2012 A1
20120062805 Candelore Mar 2012 A1
20120082401 Berger et al. Apr 2012 A1
20120084731 Filman et al. Apr 2012 A1
20120084835 Thomas et al. Apr 2012 A1
20120099800 Llano et al. Apr 2012 A1
20120108293 Law et al. May 2012 A1
20120110096 Smarr et al. May 2012 A1
20120113143 Adhikari et al. May 2012 A1
20120113272 Hata May 2012 A1
20120123830 Svendsen et al. May 2012 A1
20120123871 Svendsen et al. May 2012 A1
20120123875 Svendsen et al. May 2012 A1
20120124126 Alcazar et al. May 2012 A1
20120124176 Curtis et al. May 2012 A1
20120124458 Cruzada May 2012 A1
20120131507 Sparandara et al. May 2012 A1
20120131512 Takeuchi et al. May 2012 A1
20120001651 Lalancette et al. Jun 2012 A1
20120143760 Abulafia et al. Jun 2012 A1
20120158527 Cannelongo Jun 2012 A1
20120166971 Sachson et al. Jun 2012 A1
20120169855 Oh Jul 2012 A1
20120172062 Altman et al. Jul 2012 A1
20120173991 Roberts et al. Jul 2012 A1
20120176401 Hayward et al. Jul 2012 A1
20120184248 Speede Jul 2012 A1
20120197724 Kendall Aug 2012 A1
20120200743 Blanchflower et al. Aug 2012 A1
20120209924 Evans et al. Aug 2012 A1
20120210244 De Francisco Lopez et al. Aug 2012 A1
20120212632 Mate et al. Aug 2012 A1
20120220264 Kawabata Aug 2012 A1
20120226748 Bosworth et al. Sep 2012 A1
20120233000 Fisher et al. Sep 2012 A1
20120236162 Imamura Sep 2012 A1
20120239761 Linner et al. Sep 2012 A1
20120250951 Chen Oct 2012 A1
20120252418 Kandekar et al. Oct 2012 A1
20120254325 Majeti et al. Oct 2012 A1
20120278387 Garcia et al. Nov 2012 A1
20120278692 Shi Nov 2012 A1
20120290637 Perantatos et al. Nov 2012 A1
20120299954 Wada et al. Nov 2012 A1
20120304052 Tanaka et al. Nov 2012 A1
20120304080 Wormald et al. Nov 2012 A1
20120307096 Bray et al. Dec 2012 A1
20120307112 Kunishige et al. Dec 2012 A1
20120319904 Lee et al. Dec 2012 A1
20120323933 He et al. Dec 2012 A1
20120324018 Metcalf et al. Dec 2012 A1
20130006759 Srivastava et al. Jan 2013 A1
20130024757 Doll et al. Jan 2013 A1
20130036364 Johnson Feb 2013 A1
20130045753 Obermeyer et al. Feb 2013 A1
20130046823 Mitchell et al. Feb 2013 A1
20130050260 Reitan Feb 2013 A1
20130055083 Fino Feb 2013 A1
20130057587 Leonard et al. Mar 2013 A1
20130059607 Herz et al. Mar 2013 A1
20130060690 Oskolkov et al. Mar 2013 A1
20130063369 Malhotra et al. Mar 2013 A1
20130067027 Song et al. Mar 2013 A1
20130071093 Hanks et al. Mar 2013 A1
20130080254 Thramann Mar 2013 A1
20130085790 Palmer et al. Apr 2013 A1
20130086072 Peng et al. Apr 2013 A1
20130090171 Holton et al. Apr 2013 A1
20130095857 Garcia et al. Apr 2013 A1
20130104053 Thornton et al. Apr 2013 A1
20130110885 Brundrett, III May 2013 A1
20130111514 Slavin et al. May 2013 A1
20130128059 Kristensson May 2013 A1
20130129252 Lauper May 2013 A1
20130132477 Bosworth et al. May 2013 A1
20130145286 Feng et al. Jun 2013 A1
20130159110 Rajaram et al. Jun 2013 A1
20130159919 Leydon Jun 2013 A1
20130169822 Zhu et al. Jul 2013 A1
20130173531 Rinearson et al. Jul 2013 A1
20130173729 Starenky et al. Jul 2013 A1
20130182133 Tanabe Jul 2013 A1
20130185131 Sinha et al. Jul 2013 A1
20130191198 Carlson et al. Jul 2013 A1
20130194301 Robbins et al. Aug 2013 A1
20130198176 Kim Aug 2013 A1
20130218965 Abrol et al. Aug 2013 A1
20130218968 Mcevilly et al. Aug 2013 A1
20130222323 Mckenzie Aug 2013 A1
20130227476 Frey Aug 2013 A1
20130232194 Knapp et al. Sep 2013 A1
20130263031 Oshiro et al. Oct 2013 A1
20130265450 Barnes, Jr. Oct 2013 A1
20130267253 Case et al. Oct 2013 A1
20130275505 Gauglitz et al. Oct 2013 A1
20130290443 Collins et al. Oct 2013 A1
20130304646 De Geer Nov 2013 A1
20130311255 Cummins et al. Nov 2013 A1
20130325964 Berberat Dec 2013 A1
20130344896 Kirmse et al. Dec 2013 A1
20130346869 Asver et al. Dec 2013 A1
20130346877 Borovoy et al. Dec 2013 A1
20140006129 Heath Jan 2014 A1
20140011538 Mulcahy et al. Jan 2014 A1
20140019264 Wachman et al. Jan 2014 A1
20140025734 Griffin Jan 2014 A1
20140032682 Prado et al. Jan 2014 A1
20140040712 Chang Feb 2014 A1
20140043204 Basnayake et al. Feb 2014 A1
20140045530 Gordon et al. Feb 2014 A1
20140047016 Rao Feb 2014 A1
20140047045 Baldwin et al. Feb 2014 A1
20140047335 Lewis et al. Feb 2014 A1
20140049652 Moon et al. Feb 2014 A1
20140052485 Shidfar Feb 2014 A1
20140052633 Gandhi Feb 2014 A1
20140057660 Wager Feb 2014 A1
20140067901 Shaw et al. Mar 2014 A1
20140082651 Sharifi Mar 2014 A1
20140092130 Anderson et al. Apr 2014 A1
20140096029 Schultz Apr 2014 A1
20140114565 Aziz et al. Apr 2014 A1
20140122658 Haeger et al. May 2014 A1
20140122787 Shalvi et al. May 2014 A1
20140129331 Spivack May 2014 A1
20140129953 Spiegel May 2014 A1
20140143143 Fasoli et al. May 2014 A1
20140149519 Redfern et al. May 2014 A1
20140155102 Cooper et al. Jun 2014 A1
20140164118 Polachi Jun 2014 A1
20140173424 Hogeg et al. Jun 2014 A1
20140173457 Wang et al. Jun 2014 A1
20140189592 Benchenaa et al. Jul 2014 A1
20140207679 Cho Jul 2014 A1
20140214471 Schreiner, III Jul 2014 A1
20140214883 Sanderson et al. Jul 2014 A1
20140222564 Kranendonk et al. Aug 2014 A1
20140236673 Smith Aug 2014 A1
20140250126 Baldwin et al. Sep 2014 A1
20140258405 Perkin Sep 2014 A1
20140265359 Cheng et al. Sep 2014 A1
20140266703 Dalley, Jr. et al. Sep 2014 A1
20140278769 Mccandless Sep 2014 A1
20140279061 Elimeliah et al. Sep 2014 A1
20140279436 Dorsey et al. Sep 2014 A1
20140279540 Jackson Sep 2014 A1
20140280501 Turner, Jr. Sep 2014 A1
20140280537 Pridmore et al. Sep 2014 A1
20140282096 Rubinstein et al. Sep 2014 A1
20140287779 O'keefe et al. Sep 2014 A1
20140289833 Briceno Sep 2014 A1
20140306986 Gottesman et al. Oct 2014 A1
20140317302 Naik Oct 2014 A1
20140324627 Haver et al. Oct 2014 A1
20140324629 Jacobs Oct 2014 A1
20140325383 Brown et al. Oct 2014 A1
20140358885 Zhou et al. Dec 2014 A1
20150006237 Beck et al. Jan 2015 A1
20150012593 Phillips et al. Jan 2015 A1
20150020086 Chen et al. Jan 2015 A1
20150046278 Pei et al. Feb 2015 A1
20150058079 Freund et al. Feb 2015 A1
20150071619 Brough Mar 2015 A1
20150081723 Ogawa Mar 2015 A1
20150087263 Branscomb et al. Mar 2015 A1
20150088622 Ganschow et al. Mar 2015 A1
20150095020 Leydon Apr 2015 A1
20150096042 Mizrachi Apr 2015 A1
20150116529 Wu et al. Apr 2015 A1
20150169694 Longo et al. Jun 2015 A1
20150169827 Laborde Jun 2015 A1
20150170039 Hostyn et al. Jun 2015 A1
20150172534 Miyakawaa et al. Jun 2015 A1
20150178260 Brunson Jun 2015 A1
20150222814 Li et al. Aug 2015 A1
20150234787 Itamoto Aug 2015 A1
20150261917 Smith Sep 2015 A1
20150312184 Langholz et al. Oct 2015 A1
20150350136 Flynn, III et al. Dec 2015 A1
20150365447 Klein Dec 2015 A1
20150365795 Allen et al. Dec 2015 A1
20150378502 Hu et al. Dec 2015 A1
20160006927 Sehn Jan 2016 A1
20160014063 Hogeg et al. Jan 2016 A1
20160042075 Brett Feb 2016 A1
20160085773 Chang et al. Mar 2016 A1
20160085863 Allen et al. Mar 2016 A1
20160099901 Allen et al. Apr 2016 A1
20160180887 Sehn Jun 2016 A1
20160182422 Sehn et al. Jun 2016 A1
20160182875 Sehn Jun 2016 A1
20160203143 Kritt et al. Jul 2016 A1
20160239248 Sehn Aug 2016 A1
20160277419 Allen et al. Sep 2016 A1
20160321708 Sehn Nov 2016 A1
20160328360 Pavlovskaia et al. Nov 2016 A1
20170006094 Abou Mahmoud et al. Jan 2017 A1
20170061308 Chen et al. Mar 2017 A1
20170287006 Azmoodeh et al. Oct 2017 A1
20180121450 Pavlovskaia et al. May 2018 A1
20200175086 Pavlovskaia et al. Jun 2020 A1
Foreign Referenced Citations (41)
Number Date Country
2887596 Jul 2015 CA
1645366 Jul 2005 CN
101068347 Nov 2007 CN
101292238 Oct 2008 CN
101374214 Feb 2009 CN
107710188 Feb 2018 CN
107710188 Jun 2021 CN
113282771 Aug 2021 CN
2051480 Apr 2009 EP
2151797 Feb 2010 EP
2399928 Sep 2004 GB
19990073076 Oct 1999 KR
20010078417 Aug 2001 KR
102117056 May 2020 KR
102248234 May 2021 KR
WO-1996024213 Aug 1996 WO
WO-1999063453 Dec 1999 WO
WO-2000058882 Oct 2000 WO
WO-2001029642 Apr 2001 WO
WO-2001050703 Jul 2001 WO
WO-2006118755 Nov 2006 WO
WO-2007092668 Aug 2007 WO
WO-2009043020 Apr 2009 WO
WO-2011040821 Apr 2011 WO
WO-2011119407 Sep 2011 WO
WO-2013008238 Jan 2013 WO
WO-2013008238 Jan 2013 WO
WO-2013045753 Apr 2013 WO
WO-2014006129 Jan 2014 WO
WO-2014068573 May 2014 WO
WO-2014115136 Jul 2014 WO
WO-2014194262 Dec 2014 WO
WO-2015192026 Dec 2015 WO
WO-2016044424 Mar 2016 WO
WO-2016054562 Apr 2016 WO
WO-2016065131 Apr 2016 WO
WO-2016100318 Jun 2016 WO
WO-2016100318 Jun 2016 WO
WO-2016100342 Jun 2016 WO
WO-2016149594 Sep 2016 WO
WO-2016179166 Nov 2016 WO
Non-Patent Literature Citations (67)
Entry
“A Whole New Story”, URL: https://www.snap.com/en-US/news/, (2017), 13 pgs.
“Adding a watermark to your photos”, eBay, URL: http://pages.ebay.com/help/sell/pictures.html, (accessed May 24, 2017), 4 pgs.
“U.S. Appl. No. 14/704,188, Final Office Action dated Feb. 2, 2016”, 27 pgs.
“U.S. Appl. No. 14/704,188, Non Final Office Action dated Jan. 31, 2017”, 31 pgs.
“U.S. Appl. No. 14/704,188, Non Final Office Action dated Jul. 17, 2015”, 24 pgs.
“U.S. Appl. No. 14/704,188, Notice of Allowance dated Sep. 29, 2017”, 16 pgs.
“U.S. Appl. No. 14/704,188, Response filed Oct. 19, 2015 to Non Final Office Action dated Jul. 17, 2015”, 11 pgs.
“U.S. Appl. No. 14/704,188, Response to Non Final Office Action dated Jan. 31, 2017”, 13 pgs.
“U.S. Appl. No. 15/853,609, Non Final Office Action dated Feb. 12, 2018”, 24 pgs.
“U.S. Appl. No. 15/853,609, Response filed May 14, 2018 to Non Final Office Action dated Feb. 12, 2018”, 12 pgs.
“U.S. Appl. No. 14/704,188, Response filed Jun. 2, 2016 to Final Office Action dated Feb. 2, 2016”, 12 pgs.
“BlogStomp”, URL: http://stompsoftware.com/blogstomp, (accessed May 24, 2017), 12 pgs.
“Cup Magic Starbucks Holiday Red Cups come to life with AR app”, URL: http://www.blastradius.com/work/cup-magic, (2016), 7 pgs.
“Daily App: InstaPlace (iOS/Android): Give Pictures a Sense of Place”, TechPP, URL: http://techpp.com/2013/02/15/instaplace-app-review, (2013), 13 pgs.
“European Application Serial No. 16789931.9, Extended European Search Report dated Mar. 14, 2018”, 7 pgs.
“How we analyzed Twitter social media networks with NodeXL”, PewResearchCenter in association with the Social media—Research Foundation, (Feb. 20, 2014), 23 pgs.
“InstaPlace Photo App Tell The Whole Story”, URL: https://youtu.be/uF_gFkg1hBM, (Nov. 8, 2013), 113 pgs.
“International Application Serial No. PCT/US2015/037251, International Search Report dated Sep. 29, 2015”, 2 pgs.
“International Application Serial No. PCT/US2016/030558, International Preliminary Report on Patentability dated Nov. 16, 2017”, 13 pgs.
“International Application Serial No. PCT/US2016/030558, International Seach Report dated May 31, 2016”, 3 pgs.
“International Application Serial No. PCT/US2016/030558, Written Opinion dated May 31, 2016”, 11 pgs.
“Introducing Snapchat Stories”, URL: https://www.youtube.com/watch?v=88Cu3yN-LIM, (Oct. 3, 2013), 92 pgs.
“Macy's Believe-o-Magic”, URL: https://www.youtube.com/watch?v=xvzRXy3J0Z0, (Nov. 7, 2011), 102 pgs.
“Macys Introduces Augmented Reality Experience in Stores across Country as Part of Its 2011 Believe Campaign”, URL: https://www.businesswire.com/news/home/20111102006759/en/Macys-Introduces-Augmented-Reality-Experience-Stores-Country, (Nov. 2, 2011), 6 pgs.
“Starbucks Cup Magic”, URL: https://www.youtube.com/watch?v=RWwQXi9RG0w, (Nov. 8, 2011), 87 pgs.
“Starbucks Cup Magic for Valentine's Day”, URL: https://www.youtube.com/watch?v=8nvqOzjq10w, (Feb. 6, 2012), 88 pgs.
“Starbucks Holiday Red Cups Come to Life, Signaling the Return of the Merriest Season”, URL: http://www.businesswire.com/news/home/20111115005744/en/2479513/Starbucks-Holiday-Red-Cups-Life-Signaling-Return, (Nov. 15, 2011), 5 pgs.
Carthy, Roi, “Dear All Photo Apps: Mobli Just Won Filters”, URL: https://techcrunch.com/2011/09/08/mobli-filters, (Sep. 8, 2011), 10 pgs.
Janthong, Isaranu, “Android App Review Thailand”, URL: http://www.android-free-app-review.com/2013/01/instaplace-android-google-play-store.html, (Jan. 23, 2013), 9 pgs.
Leyden, John, “This SMS will self-destruct in 40 seconds”, [Online], Retrieved from the Internet: <URL: http://www.theregister.co.uk/2005/12/12/stealthtext/, (Dec. 12, 2005), 1 pg.
MacLeod, Duncan, “Macys Believe-o-Magic App”, URL: http://theinspirationroom.com/daily/2011/macys-believe-o-magic-app, (Nov. 14, 2011), 10 pgs.
MacLeod, Duncan, “Starbucks Cup Magic Lets Merry”, URL: http://theinspirationroom.com/daily/2011/starbucks-cup-magic, (Nov. 12, 2011), 8 pgs.
Notopoulos, Katie, “A Guide To The New Snapchat Filters And Big Fonts”, URL: https://www.buzzfeed.com/katienotopoulos/a-guide-to-the-new-snapchat-filters-and-big-fonts?utm_term=.bkQ9qVZWe#.nv58YXpkV, (Dec. 22, 2013), 13 pgs.
Panzarino, Matthew, “Snapchat Adds Filters, A Replay Function And For Whatever Reason, Time, Temperature And Speed Overlays”, URL: https://techcrunch.com/2013/12/20/snapchat-adds-filters-new-font-and-for-some-reason-time-temperature-and-speed-overlays/, (Dec. 20, 2013), 12 pgs.
Tripathi, Rohit, “Watermark Images in PHP And Save File on Server”, URL: http://code.rohitink.com/2012/12/28/watermark-images-in-php-and-save-file-on-server, (Dec. 28, 2012), 4 pgs.
Yu, et al., “Social network analysis—You Tube”, 508 Project Final Report, (Jan. 25, 2008), 25 pgs.
“U.S. Appl. No. 15/853,609, Final Office Action dated Aug. 14, 2019”, 8 pgs.
“U.S. Appl. No. 15/853,609, Final Office Action dated Sep. 6, 2018”, 23 pgs.
“U.S. Appl. No. 15/853,609, Non Final Office Action dated Feb. 7, 2019”, 19 pgs.
“U.S. Appl. No. 15/853,609, Notice of Allowance dated Nov. 4, 2019”, 6 pgs.
“U.S. Appl. No. 15/853,609, Response filed Jan. 7, 2019 to Final Office Action dated Sep. 6, 2018”, 12 pgs.
“U.S. Appl. No. 15/853,609, Response filed Oct. 14, 2019 to Final Office Action dated Aug. 14, 2019”, 10 pgs.
“U.S. Appl. No. 15/853,609, Response filed May 7, 2019 to Non Final Office Action dated Feb. 7, 2019”, 14 pgs.
“U.S. Appl. No. 16/786,933, Non Final Office Action dated Sep. 16, 2021”, 19 pgs.
“Chinese Application Serial No. 201680034736.8, Office Action dated Jan. 25, 2021”, w/ English Translation, 7 pgs.
“Chinese Application Serial No. 201680034736.8, Office Action dated Jul. 3, 2020”, w/ English translation, 15 pgs.
“Chinese Application Serial No. 201680034736.8, Response filed Mar. 1, 2021 to Office Action dated Jan. 25, 2021”, w/ English Claims, 11 pgs.
“Chinese Application Serial No. 201680034736.8, Response filed Nov. 17, 20 to Office Action dated Jul. 3, 2020”, w/ English Claims, 12 pgs.
“European Application Serial No. 16789931.9, Communication Pursuant to Article 94(3) EPC dated Jan. 4, 2019”, 5 pgs.
“European Application Serial No. 16789931.9, EPO Written Decision to Refuse dated Jun. 25, 2021”, 15 pgs.
“European Application Serial No. 16789931.9, Response filed May 7, 2019 to Communication Pursuant to Article 94(3) EPC dated Jan. 4, 2019”, 1 pg.
“European Application Serial No. 16789931.9, Response filed May 10, 2021 to Summons to Attend Oral Proceedings mailed Jan. 20, 2021”, 52 pgs.
“European Application Serial No. 16789931.9, Summons to Attend Oral Proceedings mailed Jan. 20, 2021”, 6 pgs.
“Korean Application Serial No. 10-2017-7034976, Notice of Preliminary Rejection dated Jun. 25, 2019”, w/ English Translation, 15 pgs.
“Korean Application Serial No. 10-2017-7034976, Response filed Oct. 25, 2019 to Notice of Preliminary Rejection dated Jun. 25, 2019”, w/ English Claims, 34 pgs.
“Korean Application Serial No. 10-2020-7014942, Notice of Preliminary Rejection dated Jul. 20, 2020”, w/ English translation, 8 pgs.
“Korean Application Serial No. 10-2020-7014942, Response filed Sep. 17, 2020 to Notice of Preliminary Rejection dated Jul. 20, 2020”, w/ English Claims, 28 pgs.
“Korean Application Serial No. 10-2021-7012943, Notice of Preliminary Rejection dated Jun. 7, 2021”, w/ English Translation, 4 pgs.
“Surprise!”, [Online] Retrieved from the Internet: <URL: https://www.snap.com/en-US/news/post/surprise>, (Oct. 3, 2013), 1 pg.
Buscemi, Scott, “Snapchat introduces ‘Stories’, a narrative built with snaps”, [Online] Retrieved from the Internet: <URL: https://9to5mac.com/2013/10/03/snapchat-introduces-stories-a-narrative-built-with-snaps/>, (Oct. 3, 2013), 2 pgs.
Etherington, Darrell, “Snapchat Gets Its Own Timeline With Snapchat Stories, 24-Hour Photo & Video Tales”, [Online] Retrieved from the Internet: <URL: https://techcrunch.com/2013/10/03/snapchat-gets-its-own-timeline-with-snapchat-stories-24-hour-photo-video-tales/>, (Oct. 3, 2013), 2 pgs.
Hamburger, Ellis, “Snapchat's next big thing: ‘Stories’ that don't just disappear”, [Online] Retrieved from the Internet: <URL: https://www.theverge.com/2013/10/3/4791934/snapchats-next-big-thing-stories-that-dont-just-disappear>, (Oct. 3, 2013), 5 pgs.
Han, et al., “Text-Based Twitter User Geolocation Prediction”, Journal of Artificial Intelligence Research 49, (2014), 451-500.
U.S. Appl. No. 14/704,188 U.S. Pat. No. 9,881,094, filed May 5, 2015, Systems and Methods for Automated Local Story Generation and Curation.
U.S. Appl. No. 15/853,609, filed Dec. 22, 2017, Systems and Methods for Automated Local Story Generation and Curation.
“U.S. Appl. No. 16/786,933, Notice of Allowance dated May 10, 2022”, 18 pgs.
U.S. Appl. No. 16/786,933, filed Feb. 10, 2020, Automated Local Story Generation and Curation.
Related Publications (1)
Number Date Country
20180121451 A1 May 2018 US
Continuations (1)
Number Date Country
Parent 14704188 May 2015 US
Child 15853619 US