US20150186545A1 - Smart Content Pre-Loading on Client Devices - Google Patents

Smart Content Pre-Loading on Client Devices Download PDF

Info

Publication number
US20150186545A1
US20150186545A1 US14/144,544 US201314144544A US2015186545A1 US 20150186545 A1 US20150186545 A1 US 20150186545A1 US 201314144544 A US201314144544 A US 201314144544A US 2015186545 A1 US2015186545 A1 US 2015186545A1
Authority
US
United States
Prior art keywords
content item
content
resource
user
cache
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US14/144,544
Other versions
US9990440B2 (en
Inventor
Steve Krutzler
Edward J. Campbell, III
Amit Motgi
Gamaiel Zavala
Arons Lee
Devrim Tufan
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Yahoo Assets LLC
Original Assignee
Yahoo Inc until 2017
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority to US14/144,544 priority Critical patent/US9990440B2/en
Application filed by Yahoo Inc until 2017 filed Critical Yahoo Inc until 2017
Assigned to YAHOO! INC. reassignment YAHOO! INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ZAVALA, GAMAIEL, MOTGI, AMIT, KRUTZLER, STEVE, TUFAN, DEVRIM, CAMPBELL, EDWARD J., III, LEE, ARONS
Publication of US20150186545A1 publication Critical patent/US20150186545A1/en
Assigned to YAHOO HOLDINGS, INC. reassignment YAHOO HOLDINGS, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: YAHOO! INC.
Assigned to OATH INC. reassignment OATH INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: YAHOO HOLDINGS, INC.
Priority to US15/997,677 priority patent/US10387523B2/en
Publication of US9990440B2 publication Critical patent/US9990440B2/en
Application granted granted Critical
Priority to US16/544,123 priority patent/US10909208B2/en
Assigned to VERIZON MEDIA INC. reassignment VERIZON MEDIA INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: OATH INC.
Assigned to YAHOO ASSETS LLC reassignment YAHOO ASSETS LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: YAHOO AD TECH LLC (FORMERLY VERIZON MEDIA INC.)
Assigned to ROYAL BANK OF CANADA, AS COLLATERAL AGENT reassignment ROYAL BANK OF CANADA, AS COLLATERAL AGENT PATENT SECURITY AGREEMENT (FIRST LIEN) Assignors: YAHOO ASSETS LLC
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • G06F17/30902
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • G06F16/9574Browsing optimisation, e.g. caching or content distillation of access to content, e.g. by caching
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/03Arrangements for converting the position or the displacement of a member into a coded form
    • G06F3/033Pointing devices displaced or positioned by the user, e.g. mice, trackballs, pens or joysticks; Accessories therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0487Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser
    • G06F3/0488Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0487Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser
    • G06F3/0488Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures
    • G06F3/04883Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures for inputting data by handwriting, e.g. gesture or text
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2216/00Indexing scheme relating to additional aspects of information retrieval not explicitly covered by G06F16/00 and subgroups
    • G06F2216/13Prefetching

Definitions

  • Some browsers such as Mozilla Firefox, support link prefetching, which is a syntax that can be used in a loading/loaded webpage to provide a hint to a browser about what webpage and/or resource the browser should prefetch and cache in order to anticipate a user's likely navigation. For example, after the first webpage in a multi-page news article is loaded, the browser might pre-fetch and cache the second webpage on the basis of a link-prefetching hint in the first webpage.
  • link prefetching is developer-centric, rather than user-centric. That is to say, it does not make use of explicit/implicit user feedback, though present-day mobile and desktop computing devices provide numerous means for gathering such feedback.
  • a processor-executed method is described.
  • software on a client device presents a webpage through a browser.
  • the webpage is from an online content-aggregation website and includes a plurality of panels containing a plurality of content items.
  • the software selectively pre-loads into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items.
  • the cache is controlled by the browser.
  • the software retrieves the resource from the cache upon receiving a command from a user and presents the resource through the browser.
  • an apparatus which persistently store a program that runs on a client device.
  • the program presents a webpage through a browser.
  • the webpage is from an online content-aggregation website and includes a plurality of panels containing a plurality of content items.
  • the program selectively pre-loads into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items.
  • the cache is controlled by the browser.
  • the program retrieves the resource from the cache upon receiving a command from a user and presents the resource through the browser.
  • Another example embodiment also involves a processor-executed method.
  • software on a client device presents a view.
  • the view includes a plurality of panels containing a plurality of content items received from an online content-aggregation website.
  • the software selectively pre-loads into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items.
  • the software retrieves the resource from the cache upon receiving a command from a user and presents the resource in a view.
  • FIG. 1 is a network diagram showing a website hosting an online social network and a website hosting online content aggregation, in accordance with an example embodiment.
  • FIG. 2 is a three-paneled webpage showing a stream of content items in the center panel, in accordance with an example embodiment.
  • FIG. 3A is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment.
  • FIG. 3B is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment.
  • FIG. 3C is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment.
  • FIG. 4A is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment.
  • FIG. 4B is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment.
  • FIG. 4C is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment.
  • FIG. 1 is a network diagram showing a website hosting an online social network and a website hosting online content aggregation, in accordance with an example embodiment.
  • a personal computer 102 e.g., a laptop or other mobile computer
  • a mobile device 103 e.g., a smartphone such as an iPhone, Android, Windows Phone, etc., or a tablet computer such as an iPad, Galaxy, etc.
  • a network 101 e.g., a wide area network (WAN) including the Internet, which might be wireless in part or in whole
  • a website 104 hosting an online social network and a website 106 hosting online content aggregation e.g., a wide area network (WAN) including the Internet, which might be wireless in part or in whole
  • online social network is to be broadly interpreted to include, for example, any online service, including a social-media service, that allows its users to, among other things, (a) selectively access (e.g., according to a friend list, contact list, buddy list, social graph, or other control list) content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) associated with each other's profiles (e.g., Facebook walls, Flickr photo albums, Pinterest boards, etc.); (b) selectively (e.g., according to a friend list, contact list, buddy list, social graph, distribution list, or other control list) broadcast content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) to each other's newsfeeds (e.g., content/activity streams such as Facebook's News Feed, Twitter's Timeline, Google Plus's Stream, etc.); and/or (c) selectively communicate (e.g., according to a friend list)
  • content e.g., text,
  • online content aggregation is to be broadly construed to include any online service, including a social-media service, that allows its users to, among other things, access and/or annotate (e.g., comment on) content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) generated by the online service (e.g., using its own curators and/or its own algorithms) and/or its users and presented in a content stream.
  • Yahoo! News is an example of such an online service.
  • a website hosting online content aggregation might have social features based on a friend list, contact list, buddy list, social graph, distribution list, or other control list that is accessed over the network from a social-networking website through an application programming interface (API) exposed by the social networking website.
  • API application programming interface
  • Yahoo! News identifies the content items in its newsfeed that have been viewed/read by a user's friends, as identified on a Facebook friend list that the user has authorized Yahoo! News to access.
  • websites 104 and 106 might be composed of a number of servers (e.g., racked servers) connected by a network (e.g., a local area network (LAN) or a WAN) to each other in a cluster (e.g., a load-balancing cluster, a Beowulf cluster, a Hadoop cluster, etc.) or other distributed system which might run website software (e.g., web-server software, database software, search-engine software, etc.), and distributed-computing and/or cloud software such as Map-Reduce, Google File System, Hadoop, Hadoop File System, Pig, Hive, Dremel, CloudBase, etc.
  • a network e.g., a local area network (LAN) or a WAN
  • a cluster e.g., a load-balancing cluster, a Beowulf cluster, a Hadoop cluster, etc.
  • other distributed system which might run website software (e.g., web-server software, database software, search-engine software, etc
  • the servers in website 104 might be connected to persistent storage 105 and the servers in website 106 might be connected to persistent storage 107 .
  • Persistent storage 105 and persistent storage 107 might include flash memory, a redundant array of independent disks (RAID), and/or a storage area network (SAN), in an example embodiment.
  • the servers in website 104 and website 106 and/or the persistent storage in persistent storage 105 and persistent storage 107 might be hosted wholly or partially in a public and/or private cloud, e.g., where the cloud resources serve as a platform-as-a-service (PaaS) or an infrastructure-as-a-service (IaaS).
  • PaaS platform-as-a-service
  • IaaS infrastructure-as-a-service
  • Persistent storage 105 and persistent storage 107 might be used to store data related content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) and data related to users and their social contacts (e.g., Facebook friends), as well as software including algorithms and other processes for presenting the content to the users in a stream (which might be (a) ranked according to a personalized interestingness algorithm, or (b) chronological).
  • some of the data related to content and/or some of the software e.g., Internet applications, including rich Internet applications or RIAs
  • persistent storage 105 or persistent storage 107 might have been received from a content delivery or distribution network (CDN), e.g., Akami Technologies.
  • CDN content delivery or distribution network
  • some of the data related to content and/or some of the software might be delivered directly from the CDN to the personal computer 102 or the mobile device 103 , without being stored in persistent storage 105 or persistent storage 107 .
  • Personal computer 102 and the servers at websites 104 and 106 might include (1) hardware consisting of one or more microprocessors (e.g., from the x86 family, the ARM family, or the PowerPC family), volatile storage (e.g., RAM), and persistent storage (e.g., flash memory, a hard disk, or a solid-state drive), and (2) an operating system (e.g., Windows, Mac OS, Linux, Windows Server, Mac OS Server, etc.) that runs on the hardware.
  • microprocessors e.g., from the x86 family, the ARM family, or the PowerPC family
  • volatile storage e.g., RAM
  • persistent storage e.g., flash memory, a hard disk, or a solid-state drive
  • an operating system e.g., Windows, Mac OS, Linux, Windows Server, Mac OS Server, etc.
  • mobile device 103 might include (1) hardware consisting of one or more microprocessors (e.g., from the ARM family or the x86 family), volatile storage (e.g., RAM), and persistent storage (e.g., flash memory such as microSD) and (2) an operating system (e.g., iOS, webOS, Windows Mobile, Android, Linux, Symbian OS, RIM BlackBerry OS, etc.) that runs on the hardware.
  • microprocessors e.g., from the ARM family or the x86 family
  • volatile storage e.g., RAM
  • persistent storage e.g., flash memory such as microSD
  • an operating system e.g., iOS, webOS, Windows Mobile, Android, Linux, Symbian OS, RIM BlackBerry OS, etc.
  • personal computer 102 and mobile device 103 might each include a browser as an application program or as part of an operating system. Examples of browsers that might execute on personal computer 102 include Internet Explorer, Mozilla Firefox, Safari, and Google Chrome. Examples of browsers that might execute on mobile device 103 include Safari, Mozilla Firefox, Android Browser, and webOS Browser. It will be appreciated that users of personal computer 102 and/or mobile device 103 might use browsers to access content presented by website 104 or website 106 . Alternatively, users of personal computer 102 and/or mobile device 103 might use application programs (or apps) to access content presented by website 104 or website 106 .
  • application programs or apps
  • FIG. 2 is a three-paneled webpage showing a stream of content items in the center panel, in accordance with an example embodiment.
  • this webpage might be served to a client device by a content-aggregation website (e.g., Yahoo! News).
  • webpage 201 includes three panels: left panel 202 , center panel 203 , and right panel 204 .
  • Left panel 202 includes an ad for Netflix, which is not a targeted ad.
  • Right panel 204 includes a targeted ad for lyft and personalized weather data for Mendocino.
  • Center panel 203 includes a stream (or news feed) of content items, e.g., where a content item is a summary of a news article and a related image.
  • a content item is a summary of a news article and a related image.
  • the selection and ordering (from top to bottom) of the content items in the stream might be result an interestingness algorithm, in an example embodiment.
  • FIG. 3A is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment.
  • all of the operations in this process might performed by software running on personal computer 102 or mobile device 103 , e.g., JavaScript (or another EMAScript language) as rendered executable by a browser.
  • some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • the software receives identifying data (e.g., a username and a password) from a user of a browser on client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 301 .
  • client device e.g., laptop or smartphone
  • the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a webpage with multiple panels using a browser, e.g., as described above.
  • the software pre-loads a resource (e.g., the HTML file for a news article) into a browser cache, if the resource is associated with a content item that is (A) relatively persistent in comparison to other content items and/or (B) the subject of an implicit signal (e.g., a mouse-over or a mouse-hover) indicative of user focus.
  • a resource e.g., the HTML file for a news article
  • the software retrieves the resource (e.g., the HTML file for a news article) from the browser cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource using the browser.
  • a resource is pre-loaded into a browser cache if the resource is associated with an implicitly-signaled content item that is relatively persistent in comparison to other content items.
  • a content item might be relatively persistent in comparison to other content items if it is not personalized using user data and/or device data. So, for example, in FIG. 2 , the news summaries in the stream in center panel 203 are relatively persistent in comparison to the real-time or near real-time temperatures in a particular locale (e.g., Mendocino) in right panel 204 and the targeted ad in right panel 204 .
  • a targeted ad might be regarded as a form of personalized content, if it is served to a user based on the user's profile/history with the content-aggregation website.
  • a content item might be relatively persistent in comparison to other content items if the content item probably will not change during a specified period time, e.g., in the approximate range of 1-12 hours. Such a probability might be calculated using historical data for similar content items.
  • a content item might be relatively persistent in comparison to other content items if it is not subject to explicit relevance feedback by the user. For example, the news summaries in the stream in center panel 203 might not be subject to explicit relevance feedback (e.g., hiding) by the user.
  • the user might be allowed to change the locale associated with the temperatures in right panel 204 (e.g., by an explicit change to the user's profile with the online content-aggregation website) and the user would expect to see that change immediately confirmed in the locale and temperatures shown in that panel. Otherwise, the user might re-attempt the change.
  • an implicit signal is a mouse-over or mouse-hover.
  • a mouse-over or mouse-hover occurs when the user positions a mouse cursor over a content item (e.g., a summary of a news article) or a panel containing a content item for a specified period of time, e.g., in the approximate range of 100-1000 ms (milliseconds).
  • a content item e.g., a summary of a news article
  • a panel containing a content item e.g., in the approximate range of 100-1000 ms (milliseconds).
  • other implicit symbols might be used in the same or alternative embodiments.
  • the implicit signal might be a finger-over or finger-hover or a stylus-over or stylus-hover.
  • the implicit signal might be gaze-over or gaze-hover.
  • a mouse-over or mouse-hover occurs when the when the user positions a mouse cursor over a content item or a panel containing the content item for a specified period of time.
  • the specified amount of time might vary from panel to panel. So, for example, if the webpage has three panels as in FIG. 2 , the specified amount of time might be in the range of approximately 150 ms for the center panel, approximately 250 ms for the left panel, and 500 ms for the right panel. That is to say, if the mouse-over or mouse-hover lasts lest than 150 ms over the center panel, there will be no pre-loading of a content item in that panel.
  • the lowest specified amount of time is assigned to the panel (e.g., the center panel) that includes the stream, e.g., the news feed.
  • the highest specified amount of time is assigned to the panel (e.g., the right panel) that includes personalized content items that are not relatively persistent in comparison to other content items.
  • the specified period of time for a mouse-over or mouse-hover might be specified by the developers at the content-aggregation website.
  • the specified period of time for a mouse-over or mouse-hover might be specified and dynamically adjusted by machine-learning software (e.g., performing regression analysis with an independent variable of specified time and a dependent variable of probability of mouse-click) at the content-aggregation website. So, for example, initial values such as those discussed above (e.g., 250 ms for the left panel, 150 ms for the center panel, and 500 ms for the right panel) might be set by the machine-learning software.
  • the machine-learning software might dynamically adjust the initial values (e.g., to 500 ms for the left panel, 100 ms for the center panel, and 400 ms for the right panel).
  • the user feedback might take the form of explicit relevance feedback, e.g., likes, hidings, etc., or implicit relevance feedback, namely, mouse-clicks, pageviews, mouse-overs or mouse-hovers, etc.
  • the software pre-loads a resource into a browser cache and, in operation 304 , the software retrieves the resource from the browser cache and presents the resource using the browser.
  • the resource might be kept in the browser cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource.
  • this specified period of time might be specified by the developers at the content-aggregation website.
  • this specified period of time might specified by machine-learning software (e.g., performing regression analysis with an independent variable of specified time and a dependent variable of probability of mouse-click) at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the browser cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file.
  • the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • GUI graphical user interface
  • the flowchart in FIG. 3A describes the operations of software, including a browser, on a client device receiving content items and related resources from a content-aggregation website.
  • the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • a content-aggregation website shares many similarities to a social-networking website that maintains an interest graph (e.g., in addition to a social graph), particularly when the content-aggregation website engages in a significant amount of personalization based on user data and/or device data. If such personalization occurs, the user tends to be deciding factor with respect to what content is served, rather than a human or automated curator.
  • FIG. 3B is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment.
  • all of the operations in this process might performed by software running on personal computer 102 or mobile device 103 , e.g., JavaScript (or another EMAScript language) as rendered executable by a browser.
  • some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • the software receives identifying data (e.g., a username and a password) from a user of a browser on a client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 311 .
  • identifying data e.g., a username and a password
  • the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a webpage with multiple panels using a browser, e.g., as described above.
  • the software pre-loads a resource (e.g., the HTML file for a news article) into a browser cache, where the resource is related to a content item (e.g., a news summary) that has a relatively high ranking in terms of interestingness to the user (e.g., is from the top of the stream).
  • a content item e.g., a news summary
  • the software retrieves the resource (e.g., the HTML file for a news article) from the browser cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource using the browser.
  • a resource that is related to a relatively highly-ranked content item is pre-loaded into a browser cache.
  • the ranking might be in terms of interestingness (or buzzworthiness) to the user, e.g., as determined by an algorithm that uses implicit and explicit relevance feedback, as described above, from the user and other users.
  • an algorithm that uses implicit and explicit relevance feedback as described above, from the user and other users.
  • Facebook a social-networking website has used an algorithm called EdgeRank to construct a News Feed that is personalized in terms of interestingness, among other things, for each user profile/history.
  • Flickr a social-media website, has disclosed a personalized interestingness algorithm to recommend social media (e.g., images and video) to users. See the personalized interestingness algorithm described in co-owned U.S. Published Patent Application No.
  • the ranking might be in terms of a metric other than interestingness, e.g., relevance to user's profile/history.
  • the ranking might be the output of a similarity-based recommender system that uses content-based filtering and/or collaborative filtering.
  • the software pre-loads a resource into a browser cache and, in operation 314 , the software retrieves the resource from the browser cache and presents the resource using the browser.
  • the resource might be kept in the browser cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource.
  • this specified period of time might be specified by the developers at the content-aggregation website.
  • this specified period of time might be specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the browser cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file.
  • the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • GUI graphical user interface
  • FIG. 3B describes the operations of software, including a browser, on a client device receiving content items and related resources from a content-aggregation website.
  • the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • FIG. 3C is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment.
  • all of the operations in this process might performed by software running on personal computer 102 or mobile device 103 , e.g., JavaScript (or another EMAScript language) as rendered executable by a browser.
  • some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • the software receives identifying data (e.g., a username and a password) from a user of a browser on client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 321 .
  • client device e.g., laptop or smartphone
  • the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a webpage with multiple panels using a browser, e.g., as described above.
  • the software pre-loads a resource (e.g., the HTML file for a news article) into a browser cache, where the resource is related to a content item (e.g., a news summary) that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts (e.g., Facebook friends) of the user according to a list maintained by an online content-aggregation website or an online social-networking website.
  • the software retrieves the resource (e.g., the HTML file for a news article) from the browser cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource using the browser.
  • a resource is pre-loaded that is related to a content item that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts of the user according to a list maintained by an online content-aggregation website or an online social-networking website.
  • a list might be obtained by a content-aggregation website from a social-networking website through an application program interface (API) exposed by the social-networking website, following explicit approval by the user (e.g., as obtained through a GUI dialog).
  • API application program interface
  • a user of Yahoo! News might use a series of GUI dialogs to connect his/her Yahoo! account to his/her Facebook account. And thereafter, Yahoo! News could determine which content items were being clicked on, liked, viewed, etc., by the user's Facebook friends.
  • the software pre-loads a resource into a browser cache and, in operation 324 , the software retrieves the resource from the browser cache and presents the resource using the browser.
  • the resource might be kept in the browser cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource.
  • this specified period of time might be specified by the developers at the content-aggregation website.
  • this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the browser cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file.
  • the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • GUI graphical user interface
  • FIG. 3C describes the operations of software, including a browser, on a client device receiving content items and related resources from a content-aggregation website.
  • the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • two or more of the processes shown in FIGS. 3A , 3 B, and 3 C might be combined into a hybrid process for browser pre-loading of a resource related to a content item.
  • a hybrid process might pre-load into a browser cache (a) a resource based on an implicit signal indicative of user focus, (b) a resource related to a content item based on the content item's interestingness ranking, and (c) a resource based on online activities performed by social contacts of a user.
  • a hybrid process might pre-load into a browser cache the resources (a) and (b) or the resources (a) and (c) or the resources (b) and (c).
  • FIG. 4A is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment.
  • all of the operations in this process might performed by software running on personal computer 102 or mobile device 103 , e.g., an application (or app).
  • some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • the software receives identifying data (e.g., a username and a password) from a user of an application (or app) on client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 401 .
  • client device e.g., laptop or smartphone
  • the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a view with multiple panels.
  • content items e.g., summaries of news articles, where each summary might include text and a thumbnail image
  • the software pre-loads a resource (e.g., the HTML file for a news article) into a cache on the client device, if the resource is associated with a content item that is (A) relatively persistent in comparison to other content items and/or (B) the subject of an implicit signal (e.g., a mouse-over or a mouse-hover) indicative of user focus.
  • a resource e.g., the HTML file for a news article
  • the software retrieves the resource (e.g., the HTML file for a news article) from the cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource in a view.
  • a resource is pre-loaded into the cache if the resource is associated with an implicitly-signaled content item that is relatively persistent in comparison to other content items.
  • a content item might be relatively persistent in comparison to other content items if it is not personalized using user data and/or device data. So, for example, in FIG. 2 , the news summaries in the stream in center panel 203 are relatively persistent in comparison to the real-time or near real-time temperatures in a particular locale (e.g., Mendocino) in right panel 204 and the targeted ad in right panel 204 .
  • a content item might be might be relatively persistent in comparison to other content items if the content item probably will not change during a specified period time, e.g., in the approximate range of 1-12 hours. Such a probability might be calculated using historical data for similar content items.
  • a content item might be relatively persistent in comparison to other content items if it is not subject to explicit relevance feedback by the user. For example, the news summaries in the stream in center panel 203 might not be subject to explicit relevance feedback (e.g., hiding) by the user.
  • the user might be allowed to change the locale associated with the temperatures in right panel 204 (e.g., by an explicit change to the user's profile with the online content-aggregation website) and the user would expect to see that change immediately confirmed in the locale and temperatures shown in that panel. Otherwise, the user might re-attempt the change.
  • an implicit signal is a mouse-over or mouse-hover.
  • a mouse-over or mouse-hover occurs when the user positions a mouse cursor over a content item (e.g., a summary of a news article) or a panel containing a content item for a specified period of time, e.g., in the approximate range of 100-1000 ms (milliseconds).
  • a content item e.g., a summary of a news article
  • a panel containing a content item e.g., in the approximate range of 100-1000 ms (milliseconds).
  • other implicit symbols might be used in the same or alternative embodiments.
  • the implicit signal might be a finger-over or finger-hover or a stylus-over or stylus-hover.
  • the implicit signal might be a gaze-over or a gaze-hover.
  • a mouse-over or mouse-hover occurs when the when the user positions a mouse cursor over a content item or a panel containing the content item for a specified period of time.
  • the specified amount of time might vary from panel to panel. So, for example, if the view has three panels as in FIG. 2 , the specified amount of time might be in the range of approximately 150 ms for the center panel, approximately 250 ms for the left panel, and 500 ms for the right panel. That is to say, if the mouse-over or mouse-hover lasts lest than 150 ms over the center panel, there will be no pre-loading of a content item in that panel.
  • the lowest specified amount of time is assigned to the panel (e.g., the center panel) that includes the stream, e.g., the news feed.
  • the highest specified amount of time is assigned to the panel (e.g., the right panel) that includes personalized content items that are not relatively persistent in comparison to other content items.
  • the specified period of time for a mouse-over or mouse-hover might be specified by the developers at the content-aggregation website.
  • the specified period of time for a mouse-over or mouse-hover might be specified and dynamically adjusted by machine-learning software (e.g., performing regression analysis with an independent variable of specified time and a dependent variable of probability of mouse-click) at the content aggregation website. So, for example, initial values such as those discussed above (e.g., 250 ms for the left panel, 150 ms for the center panel, and 500 ms for the right panel) might be set by the machine-learning software.
  • the machine-learning software might dynamically adjust the initial values (e.g., to 500 ms for the left panel, 100 ms for the center panel, and 400 ms for the right panel).
  • the user feedback might take the form of explicit relevance feedback, e.g., likes, hidings, etc., or implicit relevance feedback, namely, mouse-clicks, views, mouse-overs or mouse-hovers, etc.
  • the software pre-loads a resource into a cache and, in operation 404 , the software retrieves the resource from the cache and presents the resource in a view.
  • the resource might be kept in the cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource.
  • this specified period of time might be specified by the developers at the content-aggregation website.
  • this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file.
  • the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • GUI graphical user interface
  • FIG. 4A describes the operations of software on a client device receiving content items and related resources from a content-aggregation website.
  • the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • FIG. 4B is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment.
  • all of the operations in this process might performed by software running on personal computer 102 or mobile device 103 , e.g., an application (or app).
  • some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • the software receives identifying data (e.g., a username and a password) from a user of an application (or app) on a client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 411 .
  • identifying data e.g., a username and a password
  • client device e.g., laptop or smartphone
  • the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a view with multiple panels.
  • content items e.g., summaries of news articles, where each summary might include text and a thumbnail image
  • the software pre-loads a resource (e.g., the HTML file for a news article) into a cache on the client device, where the resource is related to a content item (e.g., a news summary) that has a relatively high ranking in terms of interestingness to the user (e.g., is from the top of the stream).
  • a content item e.g., a news summary
  • the software retrieves the resource (e.g., the HTML file for a news article) from the cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource in a view.
  • a resource that is related to a relatively highly-ranked content item is pre-loaded into a cache.
  • the ranking might be in terms of interestingness (or buzzworthiness) to the user, e.g., as determined by an algorithm that uses implicit and explicit relevance feedback, as described above, from the user and other users.
  • the software pre-loads a resource into a cache and, in operation 414 , the software retrieves the resource from the cache and presents the resource in a view.
  • the resource might be kept in the cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource.
  • this specified period of time might be specified by the developers at the content-aggregation website.
  • this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file.
  • the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • GUI graphical user interface
  • FIG. 4B describes the operations of software on a client device receiving content items and related resources from a content-aggregation website.
  • the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • FIG. 4C is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment.
  • all of the operations in this process might performed by software running on personal computer 102 or mobile device 103 , e.g., an application (or app).
  • some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • the software receives identifying data (e.g., a username and a password) from a user of an application (or app) on a client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 421 .
  • identifying data e.g., a username and a password
  • client device e.g., laptop or smartphone
  • the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a view with multiple panels.
  • content items e.g., summaries of news articles, where each summary might include text and a thumbnail image
  • the software pre-loads a resource (e.g., the HTML file for a news article) into a cache on the client device, where the resource is related to a content item (e.g., a news summary) that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts (e.g., Facebook friends) of the user according to a list maintained by an online content-aggregation website or an online social-networking website.
  • a resource e.g., the HTML file for a news article
  • a content item e.g., a news summary
  • online activities e.g., mouse-clicks, likes, views, etc.
  • social contacts e.g., Facebook friends
  • the software retrieves the resource (e.g., the HTML file for a news article) from the cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource in a view.
  • the resource e.g., the HTML file for a news article
  • a command e.g., a mouse-click on a news summary
  • a resource is pre-loaded that is related to a content item that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts of the user according to a list maintained by an online content-aggregation website or an online social-networking website.
  • a list might be obtained by a content-aggregation website from a social-networking website through an application program interface (API) exposed by the social-networking website, following explicit approval by the user (e.g., as obtained through a GUI dialog).
  • API application program interface
  • a user of Yahoo! News might use a series of GUI dialogs to connect his/her Yahoo! account to his/her Facebook account. And thereafter, Yahoo! News could determine which content items were being clicked on, liked, viewed, etc., by the user's Facebook friends.
  • the software pre-loads a resource into a cache and, in operation 424 , the software retrieves the resource from the cache and presents the resource in a view.
  • the resource might be kept in the cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource.
  • this specified period of time might be specified by the developers at the content-aggregation website.
  • this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file.
  • the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • GUI graphical user interface
  • FIG. 4C describes the operations of software on a client device receiving content items and related resources from a content-aggregation website.
  • the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • two or more of the processes shown in FIGS. 4A , 4 B, and 4 C might be combined into a hybrid process for cache pre-loading of a resource related to a content item.
  • a hybrid process might pre-load into a cache (a) a resource based on an implicit signal indicative of user focus, (b) a resource related to a content item based on the content item's interestingness ranking, and (c) a resource based on online activities performed by social contacts of a user.
  • a hybrid process might pre-load into a cache the resources (a) and (b) or the resources (a) and (c) or the resources (b) and (c).
  • the inventions might employ various computer-implemented operations involving data stored in computer systems. Any of the operations described herein that form part of the inventions are useful machine operations.
  • the inventions also relate to a device or an apparatus for performing these operations.
  • the apparatus may be specially constructed for the required purposes, such as the carrier network discussed above, or it may be a general purpose computer selectively activated or configured by a computer program stored in the computer.
  • various general purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
  • the inventions can also be embodied as computer readable code on a computer readable medium.
  • the computer readable medium is any data storage device that can store data, which can thereafter be read by a computer system. Examples of the computer readable medium include hard drives, network attached storage (NAS), read-only memory, random-access memory, CD-ROMs, CD-Rs, CD-RWs, DVDs, Flash, magnetic tapes, and other optical and non-optical data storage devices.
  • the computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
  • the website providing the content items might be an online publication or an online retailer/wholesaler, rather than a content-aggregation website or a social-networking website.
  • the operations described above can be ordered, modularized, and/or distributed in any suitable way. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the inventions are not to be limited to the details given herein, but may be modified within the scope and equivalents of the following claims.
  • elements and/or steps do not imply any particular order of operation, unless explicitly stated in the claims or implicitly required by the disclosure.

Abstract

Software on a client device presents a webpage through a browser. The webpage is from an online content-aggregation website and includes a plurality of panels containing a plurality of content items. The software selectively pre-loads into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items. The cache is controlled by the browser. The software retrieves the resource from the cache upon receiving command from a user and presents the resource through the browser.

Description

    BACKGROUND
  • Some browsers, such as Mozilla Firefox, support link prefetching, which is a syntax that can be used in a loading/loaded webpage to provide a hint to a browser about what webpage and/or resource the browser should prefetch and cache in order to anticipate a user's likely navigation. For example, after the first webpage in a multi-page news article is loaded, the browser might pre-fetch and cache the second webpage on the basis of a link-prefetching hint in the first webpage.
  • By definition, link prefetching is developer-centric, rather than user-centric. That is to say, it does not make use of explicit/implicit user feedback, though present-day mobile and desktop computing devices provide numerous means for gathering such feedback.
  • SUMMARY
  • In an example embodiment, a processor-executed method is described. According to the method, software on a client device presents a webpage through a browser. The webpage is from an online content-aggregation website and includes a plurality of panels containing a plurality of content items. The software selectively pre-loads into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items. The cache is controlled by the browser. The software retrieves the resource from the cache upon receiving a command from a user and presents the resource through the browser.
  • In another example embodiment, an apparatus is described, namely, computer-readable media which persistently store a program that runs on a client device. The program presents a webpage through a browser. The webpage is from an online content-aggregation website and includes a plurality of panels containing a plurality of content items. The program selectively pre-loads into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items. The cache is controlled by the browser. The program retrieves the resource from the cache upon receiving a command from a user and presents the resource through the browser.
  • Another example embodiment also involves a processor-executed method. According to the method, software on a client device presents a view. The view includes a plurality of panels containing a plurality of content items received from an online content-aggregation website. The software selectively pre-loads into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items. The software retrieves the resource from the cache upon receiving a command from a user and presents the resource in a view.
  • Other aspects and advantages of the inventions will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, which illustrate by way of example the principles of the inventions.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a network diagram showing a website hosting an online social network and a website hosting online content aggregation, in accordance with an example embodiment.
  • FIG. 2 is a three-paneled webpage showing a stream of content items in the center panel, in accordance with an example embodiment.
  • FIG. 3A is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment.
  • FIG. 3B is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment.
  • FIG. 3C is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment.
  • FIG. 4A is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment.
  • FIG. 4B is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment.
  • FIG. 4C is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment.
  • DETAILED DESCRIPTION
  • In the following description, numerous specific details are set forth in order to provide a thorough understanding of the exemplary embodiments. However, it will be apparent to one skilled in the art that the example embodiments may be practiced without some of these specific details. In other instances, process operations and implementation details have not been described in detail, if already well known.
  • FIG. 1 is a network diagram showing a website hosting an online social network and a website hosting online content aggregation, in accordance with an example embodiment. As depicted in this figure, a personal computer 102 (e.g., a laptop or other mobile computer) and a mobile device 103 (e.g., a smartphone such as an iPhone, Android, Windows Phone, etc., or a tablet computer such as an iPad, Galaxy, etc.) are connected by a network 101 (e.g., a wide area network (WAN) including the Internet, which might be wireless in part or in whole) with a website 104 hosting an online social network and a website 106 hosting online content aggregation. As used here and elsewhere in this disclosure, the term “online social network” is to be broadly interpreted to include, for example, any online service, including a social-media service, that allows its users to, among other things, (a) selectively access (e.g., according to a friend list, contact list, buddy list, social graph, or other control list) content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) associated with each other's profiles (e.g., Facebook walls, Flickr photo albums, Pinterest boards, etc.); (b) selectively (e.g., according to a friend list, contact list, buddy list, social graph, distribution list, or other control list) broadcast content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) to each other's newsfeeds (e.g., content/activity streams such as Facebook's News Feed, Twitter's Timeline, Google Plus's Stream, etc.); and/or (c) selectively communicate (e.g., according to a friend list, contact list, buddy list, social graph, distribution list, or other control list) with each other (e.g., using a messaging protocol such as email, instant messaging, short message service (SMS), etc.). And as used in this disclosure, the term “online content aggregation” is to be broadly construed to include any online service, including a social-media service, that allows its users to, among other things, access and/or annotate (e.g., comment on) content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) generated by the online service (e.g., using its own curators and/or its own algorithms) and/or its users and presented in a content stream. Yahoo! News is an example of such an online service. It will be appreciated that a website hosting online content aggregation might have social features based on a friend list, contact list, buddy list, social graph, distribution list, or other control list that is accessed over the network from a social-networking website through an application programming interface (API) exposed by the social networking website. For example, as described in further detail below, Yahoo! News identifies the content items in its newsfeed that have been viewed/read by a user's friends, as identified on a Facebook friend list that the user has authorized Yahoo! News to access.
  • In an example embodiment, websites 104 and 106 might be composed of a number of servers (e.g., racked servers) connected by a network (e.g., a local area network (LAN) or a WAN) to each other in a cluster (e.g., a load-balancing cluster, a Beowulf cluster, a Hadoop cluster, etc.) or other distributed system which might run website software (e.g., web-server software, database software, search-engine software, etc.), and distributed-computing and/or cloud software such as Map-Reduce, Google File System, Hadoop, Hadoop File System, Pig, Hive, Dremel, CloudBase, etc. The servers in website 104 might be connected to persistent storage 105 and the servers in website 106 might be connected to persistent storage 107. Persistent storage 105 and persistent storage 107 might include flash memory, a redundant array of independent disks (RAID), and/or a storage area network (SAN), in an example embodiment. In an alternative example embodiment, the servers in website 104 and website 106 and/or the persistent storage in persistent storage 105 and persistent storage 107 might be hosted wholly or partially in a public and/or private cloud, e.g., where the cloud resources serve as a platform-as-a-service (PaaS) or an infrastructure-as-a-service (IaaS).
  • Persistent storage 105 and persistent storage 107 might be used to store data related content (e.g., text, including hyperlinks, images, videos, audio recordings, etc.) and data related to users and their social contacts (e.g., Facebook friends), as well as software including algorithms and other processes for presenting the content to the users in a stream (which might be (a) ranked according to a personalized interestingness algorithm, or (b) chronological). In an example embodiment, some of the data related to content and/or some of the software (e.g., Internet applications, including rich Internet applications or RIAs) stored in persistent storage 105 or persistent storage 107 might have been received from a content delivery or distribution network (CDN), e.g., Akami Technologies. Or, alternatively, some of the data related to content and/or some of the software might be delivered directly from the CDN to the personal computer 102 or the mobile device 103, without being stored in persistent storage 105 or persistent storage 107.
  • Personal computer 102 and the servers at websites 104 and 106 might include (1) hardware consisting of one or more microprocessors (e.g., from the x86 family, the ARM family, or the PowerPC family), volatile storage (e.g., RAM), and persistent storage (e.g., flash memory, a hard disk, or a solid-state drive), and (2) an operating system (e.g., Windows, Mac OS, Linux, Windows Server, Mac OS Server, etc.) that runs on the hardware. Similarly, in an example embodiment, mobile device 103 might include (1) hardware consisting of one or more microprocessors (e.g., from the ARM family or the x86 family), volatile storage (e.g., RAM), and persistent storage (e.g., flash memory such as microSD) and (2) an operating system (e.g., iOS, webOS, Windows Mobile, Android, Linux, Symbian OS, RIM BlackBerry OS, etc.) that runs on the hardware.
  • Also in an example embodiment, personal computer 102 and mobile device 103 might each include a browser as an application program or as part of an operating system. Examples of browsers that might execute on personal computer 102 include Internet Explorer, Mozilla Firefox, Safari, and Google Chrome. Examples of browsers that might execute on mobile device 103 include Safari, Mozilla Firefox, Android Browser, and webOS Browser. It will be appreciated that users of personal computer 102 and/or mobile device 103 might use browsers to access content presented by website 104 or website 106. Alternatively, users of personal computer 102 and/or mobile device 103 might use application programs (or apps) to access content presented by website 104 or website 106.
  • FIG. 2 is a three-paneled webpage showing a stream of content items in the center panel, in accordance with an example embodiment. In an example embodiment, this webpage might be served to a client device by a content-aggregation website (e.g., Yahoo! News). As depicted in this figure, webpage 201 includes three panels: left panel 202, center panel 203, and right panel 204. Left panel 202 includes an ad for Netflix, which is not a targeted ad. Right panel 204 includes a targeted ad for lyft and personalized weather data for Mendocino. Here, it will be appreciated that a targeted ad might be regarded as a form of personalized content, if it is served to a user based on the user's profile/history stored on the content-aggregation website. Center panel 203 includes a stream (or news feed) of content items, e.g., where a content item is a summary of a news article and a related image. As discussed in further detail below, the selection and ordering (from top to bottom) of the content items in the stream might be result an interestingness algorithm, in an example embodiment.
  • FIG. 3A is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment. In an example embodiment, all of the operations in this process might performed by software running on personal computer 102 or mobile device 103, e.g., JavaScript (or another EMAScript language) as rendered executable by a browser. In an alternative embodiment, some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • As depicted in FIG. 3A, the software receives identifying data (e.g., a username and a password) from a user of a browser on client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 301. In operation 302, the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a webpage with multiple panels using a browser, e.g., as described above. In operation 303, the software pre-loads a resource (e.g., the HTML file for a news article) into a browser cache, if the resource is associated with a content item that is (A) relatively persistent in comparison to other content items and/or (B) the subject of an implicit signal (e.g., a mouse-over or a mouse-hover) indicative of user focus. The term “implicit” is used here by way of analogy to implicit relevance feedback. Then in operation 304, the software retrieves the resource (e.g., the HTML file for a news article) from the browser cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource using the browser.
  • In operation 303, a resource is pre-loaded into a browser cache if the resource is associated with an implicitly-signaled content item that is relatively persistent in comparison to other content items. In an example embodiment, a content item might be relatively persistent in comparison to other content items if it is not personalized using user data and/or device data. So, for example, in FIG. 2, the news summaries in the stream in center panel 203 are relatively persistent in comparison to the real-time or near real-time temperatures in a particular locale (e.g., Mendocino) in right panel 204 and the targeted ad in right panel 204. Here, it will be appreciated that a targeted ad might be regarded as a form of personalized content, if it is served to a user based on the user's profile/history with the content-aggregation website. Or, a content item might be relatively persistent in comparison to other content items if the content item probably will not change during a specified period time, e.g., in the approximate range of 1-12 hours. Such a probability might be calculated using historical data for similar content items. In another example embodiment, a content item might be relatively persistent in comparison to other content items if it is not subject to explicit relevance feedback by the user. For example, the news summaries in the stream in center panel 203 might not be subject to explicit relevance feedback (e.g., hiding) by the user. But the user might be allowed to change the locale associated with the temperatures in right panel 204 (e.g., by an explicit change to the user's profile with the online content-aggregation website) and the user would expect to see that change immediately confirmed in the locale and temperatures shown in that panel. Otherwise, the user might re-attempt the change.
  • In the description above, the example of an implicit signal is a mouse-over or mouse-hover. It will be appreciated that a mouse-over or mouse-hover occurs when the user positions a mouse cursor over a content item (e.g., a summary of a news article) or a panel containing a content item for a specified period of time, e.g., in the approximate range of 100-1000 ms (milliseconds). However, other implicit symbols might be used in the same or alternative embodiments. For example, if the client device supports gesture recognition, the implicit signal might be a finger-over or finger-hover or a stylus-over or stylus-hover. And if the client device supports facial or other three-dimensional (3D) recognition and the display associated with the client device is sufficiently large so that a user would re-position his/her head to look at a content item or a panel in the webpage, the implicit signal might be gaze-over or gaze-hover.
  • As just discussed, a mouse-over or mouse-hover occurs when the when the user positions a mouse cursor over a content item or a panel containing the content item for a specified period of time. In an example embodiment, the specified amount of time might vary from panel to panel. So, for example, if the webpage has three panels as in FIG. 2, the specified amount of time might be in the range of approximately 150 ms for the center panel, approximately 250 ms for the left panel, and 500 ms for the right panel. That is to say, if the mouse-over or mouse-hover lasts lest than 150 ms over the center panel, there will be no pre-loading of a content item in that panel. It will be appreciated that in this example, the lowest specified amount of time is assigned to the panel (e.g., the center panel) that includes the stream, e.g., the news feed. And the highest specified amount of time is assigned to the panel (e.g., the right panel) that includes personalized content items that are not relatively persistent in comparison to other content items.
  • In an example embodiment, the specified period of time for a mouse-over or mouse-hover might be specified by the developers at the content-aggregation website. Alternatively, in an example embodiment, the specified period of time for a mouse-over or mouse-hover might be specified and dynamically adjusted by machine-learning software (e.g., performing regression analysis with an independent variable of specified time and a dependent variable of probability of mouse-click) at the content-aggregation website. So, for example, initial values such as those discussed above (e.g., 250 ms for the left panel, 150 ms for the center panel, and 500 ms for the right panel) might be set by the machine-learning software. Then, based on user feedback collected and communicated by software on the client device, the machine-learning software might dynamically adjust the initial values (e.g., to 500 ms for the left panel, 100 ms for the center panel, and 400 ms for the right panel). In an example embodiment, the user feedback might take the form of explicit relevance feedback, e.g., likes, hidings, etc., or implicit relevance feedback, namely, mouse-clicks, pageviews, mouse-overs or mouse-hovers, etc.
  • In operation 303, the software pre-loads a resource into a browser cache and, in operation 304, the software retrieves the resource from the browser cache and presents the resource using the browser. In an example embodiment, the resource might be kept in the browser cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource. Here again, this specified period of time might be specified by the developers at the content-aggregation website. Alternatively, this specified period of time might specified by machine-learning software (e.g., performing regression analysis with an independent variable of specified time and a dependent variable of probability of mouse-click) at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • In the description of FIG. 3A above, the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the browser cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file. In that example embodiment, the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files. In this regard, it will be appreciated that more and more Internet-service providers are charging for data bandwidth per the amount used, rather than using a flat fee.
  • On its face, the flowchart in FIG. 3A describes the operations of software, including a browser, on a client device receiving content items and related resources from a content-aggregation website. In an alternative example embodiment, the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website. In this regard, it will be appreciated that a content-aggregation website shares many similarities to a social-networking website that maintains an interest graph (e.g., in addition to a social graph), particularly when the content-aggregation website engages in a significant amount of personalization based on user data and/or device data. If such personalization occurs, the user tends to be deciding factor with respect to what content is served, rather than a human or automated curator.
  • FIG. 3B is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment. In an example embodiment, all of the operations in this process might performed by software running on personal computer 102 or mobile device 103, e.g., JavaScript (or another EMAScript language) as rendered executable by a browser. In an alternative embodiment, some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • As depicted in FIG. 3B, the software receives identifying data (e.g., a username and a password) from a user of a browser on a client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 311. In operation 312, the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a webpage with multiple panels using a browser, e.g., as described above. In operation 313, the software pre-loads a resource (e.g., the HTML file for a news article) into a browser cache, where the resource is related to a content item (e.g., a news summary) that has a relatively high ranking in terms of interestingness to the user (e.g., is from the top of the stream). Then in operation 314, the software retrieves the resource (e.g., the HTML file for a news article) from the browser cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource using the browser.
  • In operation 313, a resource that is related to a relatively highly-ranked content item is pre-loaded into a browser cache. In an example embodiment, the ranking might be in terms of interestingness (or buzzworthiness) to the user, e.g., as determined by an algorithm that uses implicit and explicit relevance feedback, as described above, from the user and other users. For example, Facebook, a social-networking website has used an algorithm called EdgeRank to construct a News Feed that is personalized in terms of interestingness, among other things, for each user profile/history. And Flickr, a social-media website, has disclosed a personalized interestingness algorithm to recommend social media (e.g., images and video) to users. See the personalized interestingness algorithm described in co-owned U.S. Published Patent Application No. 2006/0242139, entitled “Interestingness Ranking of Media Objects”. In an alternative example embodiment, the ranking might be in terms of a metric other than interestingness, e.g., relevance to user's profile/history. Or the ranking might be the output of a similarity-based recommender system that uses content-based filtering and/or collaborative filtering.
  • In operation 313, the software pre-loads a resource into a browser cache and, in operation 314, the software retrieves the resource from the browser cache and presents the resource using the browser. In an example embodiment, the resource might be kept in the browser cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource. Here again, this specified period of time might be specified by the developers at the content-aggregation website. Alternatively, this specified period of time might be specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • In the description of FIG. 3B above, the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the browser cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file. In that example embodiment, the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • Here again, on its face, the flowchart in FIG. 3B describes the operations of software, including a browser, on a client device receiving content items and related resources from a content-aggregation website. In an alternative example embodiment, the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • FIG. 3C is a flowchart diagram of a process for browser pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment. In an example embodiment, all of the operations in this process might performed by software running on personal computer 102 or mobile device 103, e.g., JavaScript (or another EMAScript language) as rendered executable by a browser. In an alternative embodiment, some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • As depicted in FIG. 3C, the software receives identifying data (e.g., a username and a password) from a user of a browser on client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 321. In operation 322, the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a webpage with multiple panels using a browser, e.g., as described above. In operation 323, the software pre-loads a resource (e.g., the HTML file for a news article) into a browser cache, where the resource is related to a content item (e.g., a news summary) that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts (e.g., Facebook friends) of the user according to a list maintained by an online content-aggregation website or an online social-networking website. Then in operation 324, the software retrieves the resource (e.g., the HTML file for a news article) from the browser cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource using the browser.
  • In operation 323, a resource is pre-loaded that is related to a content item that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts of the user according to a list maintained by an online content-aggregation website or an online social-networking website. In an example embodiment, such a list might be obtained by a content-aggregation website from a social-networking website through an application program interface (API) exposed by the social-networking website, following explicit approval by the user (e.g., as obtained through a GUI dialog). For example, a user of Yahoo! News might use a series of GUI dialogs to connect his/her Yahoo! account to his/her Facebook account. And thereafter, Yahoo! News could determine which content items were being clicked on, liked, viewed, etc., by the user's Facebook friends.
  • In operation 323, the software pre-loads a resource into a browser cache and, in operation 324, the software retrieves the resource from the browser cache and presents the resource using the browser. In an example embodiment, the resource might be kept in the browser cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource. Here again, this specified period of time might be specified by the developers at the content-aggregation website. Alternatively, this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • In the description of FIG. 3C above, the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the browser cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file. In that example embodiment, the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • Here again, on its face, the flowchart in FIG. 3C describes the operations of software, including a browser, on a client device receiving content items and related resources from a content-aggregation website. In an alternative example embodiment, the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • In an example embodiment, two or more of the processes shown in FIGS. 3A, 3B, and 3C might be combined into a hybrid process for browser pre-loading of a resource related to a content item. For example, such a hybrid process might pre-load into a browser cache (a) a resource based on an implicit signal indicative of user focus, (b) a resource related to a content item based on the content item's interestingness ranking, and (c) a resource based on online activities performed by social contacts of a user. Or, in example embodiments, a hybrid process might pre-load into a browser cache the resources (a) and (b) or the resources (a) and (c) or the resources (b) and (c).
  • FIG. 4A is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on an implicit signal indicative of user focus, in accordance with an example embodiment. In an example embodiment, all of the operations in this process might performed by software running on personal computer 102 or mobile device 103, e.g., an application (or app). In an alternative embodiment, some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • As depicted in FIG. 4A, the software receives identifying data (e.g., a username and a password) from a user of an application (or app) on client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 401. In operation 402, the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a view with multiple panels. In operation 403, the software pre-loads a resource (e.g., the HTML file for a news article) into a cache on the client device, if the resource is associated with a content item that is (A) relatively persistent in comparison to other content items and/or (B) the subject of an implicit signal (e.g., a mouse-over or a mouse-hover) indicative of user focus. Then in operation 404, the software retrieves the resource (e.g., the HTML file for a news article) from the cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource in a view.
  • In operation 403, a resource is pre-loaded into the cache if the resource is associated with an implicitly-signaled content item that is relatively persistent in comparison to other content items. In an example embodiment, a content item might be relatively persistent in comparison to other content items if it is not personalized using user data and/or device data. So, for example, in FIG. 2, the news summaries in the stream in center panel 203 are relatively persistent in comparison to the real-time or near real-time temperatures in a particular locale (e.g., Mendocino) in right panel 204 and the targeted ad in right panel 204. Or, a content item might be might be relatively persistent in comparison to other content items if the content item probably will not change during a specified period time, e.g., in the approximate range of 1-12 hours. Such a probability might be calculated using historical data for similar content items. In another example embodiment, a content item might be relatively persistent in comparison to other content items if it is not subject to explicit relevance feedback by the user. For example, the news summaries in the stream in center panel 203 might not be subject to explicit relevance feedback (e.g., hiding) by the user. But the user might be allowed to change the locale associated with the temperatures in right panel 204 (e.g., by an explicit change to the user's profile with the online content-aggregation website) and the user would expect to see that change immediately confirmed in the locale and temperatures shown in that panel. Otherwise, the user might re-attempt the change.
  • In the description above, the example of an implicit signal is a mouse-over or mouse-hover. It will be appreciated that a mouse-over or mouse-hover occurs when the user positions a mouse cursor over a content item (e.g., a summary of a news article) or a panel containing a content item for a specified period of time, e.g., in the approximate range of 100-1000 ms (milliseconds). However, other implicit symbols might be used in the same or alternative embodiments. For example, if the client device supports gesture recognition, the implicit signal might be a finger-over or finger-hover or a stylus-over or stylus-hover. And if the client device supports facial or other three-dimensional (3D) recognition and the display associated with the client device is sufficiently large so that a user would re-position his/her head to look at a content item or a panel in the view, the implicit signal might be a gaze-over or a gaze-hover.
  • As just discussed, a mouse-over or mouse-hover occurs when the when the user positions a mouse cursor over a content item or a panel containing the content item for a specified period of time. In an example embodiment, the specified amount of time might vary from panel to panel. So, for example, if the view has three panels as in FIG. 2, the specified amount of time might be in the range of approximately 150 ms for the center panel, approximately 250 ms for the left panel, and 500 ms for the right panel. That is to say, if the mouse-over or mouse-hover lasts lest than 150 ms over the center panel, there will be no pre-loading of a content item in that panel. It will be appreciated that in this example, the lowest specified amount of time is assigned to the panel (e.g., the center panel) that includes the stream, e.g., the news feed. And the highest specified amount of time is assigned to the panel (e.g., the right panel) that includes personalized content items that are not relatively persistent in comparison to other content items.
  • In an example embodiment, the specified period of time for a mouse-over or mouse-hover might be specified by the developers at the content-aggregation website. Alternatively, in an example embodiment, the specified period of time for a mouse-over or mouse-hover might be specified and dynamically adjusted by machine-learning software (e.g., performing regression analysis with an independent variable of specified time and a dependent variable of probability of mouse-click) at the content aggregation website. So, for example, initial values such as those discussed above (e.g., 250 ms for the left panel, 150 ms for the center panel, and 500 ms for the right panel) might be set by the machine-learning software. Then, based on user feedback collected and communicated by software on the client device, the machine-learning software might dynamically adjust the initial values (e.g., to 500 ms for the left panel, 100 ms for the center panel, and 400 ms for the right panel). In an example embodiment, the user feedback might take the form of explicit relevance feedback, e.g., likes, hidings, etc., or implicit relevance feedback, namely, mouse-clicks, views, mouse-overs or mouse-hovers, etc.
  • In operation 403, the software pre-loads a resource into a cache and, in operation 404, the software retrieves the resource from the cache and presents the resource in a view. In an example embodiment, the resource might be kept in the cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource. Here again, this specified period of time might be specified by the developers at the content-aggregation website. Alternatively, this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • In the description of FIG. 4A above, the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file. In that example embodiment, the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • On its face, the flowchart in FIG. 4A describes the operations of software on a client device receiving content items and related resources from a content-aggregation website. In an alternative example embodiment, the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • FIG. 4B is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on the content item's interestingness ranking, in accordance with an example embodiment. In an example embodiment, all of the operations in this process might performed by software running on personal computer 102 or mobile device 103, e.g., an application (or app). In an alternative embodiment, some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • As depicted in FIG. 4B, the software receives identifying data (e.g., a username and a password) from a user of an application (or app) on a client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 411. In operation 412, the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a view with multiple panels. In operation 413, the software pre-loads a resource (e.g., the HTML file for a news article) into a cache on the client device, where the resource is related to a content item (e.g., a news summary) that has a relatively high ranking in terms of interestingness to the user (e.g., is from the top of the stream). Then in operation 414, the software retrieves the resource (e.g., the HTML file for a news article) from the cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource in a view.
  • In operation 413, a resource that is related to a relatively highly-ranked content item is pre-loaded into a cache. In an example embodiment, the ranking might be in terms of interestingness (or buzzworthiness) to the user, e.g., as determined by an algorithm that uses implicit and explicit relevance feedback, as described above, from the user and other users.
  • In operation 413, the software pre-loads a resource into a cache and, in operation 414, the software retrieves the resource from the cache and presents the resource in a view. In an example embodiment, the resource might be kept in the cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource. Here again, this specified period of time might be specified by the developers at the content-aggregation website. Alternatively, this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • In the description of FIG. 4B above, the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file. In that example embodiment, the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • Here again, on its face, the flowchart in FIG. 4B describes the operations of software on a client device receiving content items and related resources from a content-aggregation website. In an alternative example embodiment, the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • FIG. 4C is a flowchart diagram of a process for application pre-loading of a resource related to a content item where the pre-loading is based on online activities performed by social contacts of a user, in accordance with an example embodiment. In an example embodiment, all of the operations in this process might performed by software running on personal computer 102 or mobile device 103, e.g., an application (or app). In an alternative embodiment, some of the operations in this process might be performed by software (e.g., a PHP script) running on a server.
  • As depicted in FIG. 4C, the software receives identifying data (e.g., a username and a password) from a user of an application (or app) on a client device (e.g., laptop or smartphone) and communicates the identifying data to an online content-aggregation website that maintains/controls content items, in operation 421. In operation 422, the software receives content items (e.g., summaries of news articles, where each summary might include text and a thumbnail image) from the online content-aggregation website and presents them in a view with multiple panels. In operation 423, the software pre-loads a resource (e.g., the HTML file for a news article) into a cache on the client device, where the resource is related to a content item (e.g., a news summary) that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts (e.g., Facebook friends) of the user according to a list maintained by an online content-aggregation website or an online social-networking website. Then in operation 424, the software retrieves the resource (e.g., the HTML file for a news article) from the cache upon receiving a command (e.g., a mouse-click on a news summary) from the user and presents the resource in a view.
  • In operation 423, a resource is pre-loaded that is related to a content item that is associated with online activities (e.g., mouse-clicks, likes, views, etc.) by other users who are social contacts of the user according to a list maintained by an online content-aggregation website or an online social-networking website. In an example embodiment, such a list might be obtained by a content-aggregation website from a social-networking website through an application program interface (API) exposed by the social-networking website, following explicit approval by the user (e.g., as obtained through a GUI dialog). For example, a user of Yahoo! News might use a series of GUI dialogs to connect his/her Yahoo! account to his/her Facebook account. And thereafter, Yahoo! News could determine which content items were being clicked on, liked, viewed, etc., by the user's Facebook friends.
  • In operation 423, the software pre-loads a resource into a cache and, in operation 424, the software retrieves the resource from the cache and presents the resource in a view. In an example embodiment, the resource might be kept in the cache for a specified period of time, e.g., in the approximate range of 30 seconds to 5 minutes, before it is replaced by another resource. Here again, this specified period of time might be specified by the developers at the content-aggregation website. Alternatively, this specified period of time might specified by machine-learning software at the content-aggregation website and dynamically adjusted by that software based on user feedback collected and communicated by software on the client device.
  • In the description of FIG. 4C above, the example of a resource is the HTML file for a news article. It will be appreciated that such a resource is relatively small in terms of number of bytes and consumes a relatively small amount of bandwidth when the resource is communicated over the network to the client device, in comparison to other resources such as image files, audio and/or video files, etc. Also, such a resource consumes a relatively small amount of storage (e.g., persistent storage) in the cache on the client device, in comparison to other resources such as image files, audio and/or video files, etc. However, in an alternative example embodiment, the resource might be a larger file such as an image file or an audio and/or video file. In that example embodiment, the software on the client device might notify the user (e.g., through a graphical user interface (GUI) dialog) that the pre-loading of relatively large resource files could increase the amount of bandwidth and/or storage used by the client device and give the user the option to forego the pre-loading of those files.
  • Here again, on its face, the flowchart in FIG. 4C describes the operations of software on a client device receiving content items and related resources from a content-aggregation website. In an alternative example embodiment, the software on the client device might receive content items and related resources from a social-networking website, rather than a content-aggregation website.
  • In an example embodiment, two or more of the processes shown in FIGS. 4A, 4B, and 4C might be combined into a hybrid process for cache pre-loading of a resource related to a content item. For example, such a hybrid process might pre-load into a cache (a) a resource based on an implicit signal indicative of user focus, (b) a resource related to a content item based on the content item's interestingness ranking, and (c) a resource based on online activities performed by social contacts of a user. Or, in example embodiments, a hybrid process might pre-load into a cache the resources (a) and (b) or the resources (a) and (c) or the resources (b) and (c).
  • With the above embodiments in mind, it should be understood that the inventions might employ various computer-implemented operations involving data stored in computer systems. Any of the operations described herein that form part of the inventions are useful machine operations. The inventions also relate to a device or an apparatus for performing these operations. The apparatus may be specially constructed for the required purposes, such as the carrier network discussed above, or it may be a general purpose computer selectively activated or configured by a computer program stored in the computer. In particular, various general purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
  • The inventions can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data, which can thereafter be read by a computer system. Examples of the computer readable medium include hard drives, network attached storage (NAS), read-only memory, random-access memory, CD-ROMs, CD-Rs, CD-RWs, DVDs, Flash, magnetic tapes, and other optical and non-optical data storage devices. The computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
  • Although example embodiments of the inventions have been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications can be practiced within the scope of the following claims. For example, the website providing the content items might be an online publication or an online retailer/wholesaler, rather than a content-aggregation website or a social-networking website. Moreover, the operations described above can be ordered, modularized, and/or distributed in any suitable way. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the inventions are not to be limited to the details given herein, but may be modified within the scope and equivalents of the following claims. In the following claims, elements and/or steps do not imply any particular order of operation, unless explicitly stated in the claims or implicitly required by the disclosure.

Claims (20)

What is claimed is:
1. A method, comprising the operations of:
presenting a webpage through a browser running on a client device, wherein the webpage is from an online content-aggregation website and includes a plurality of panels containing a plurality of content items;
selectively pre-loading into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to other content items, wherein the cache is controlled by the browser;
retrieving the resource from the cache upon receiving a command from a user; and
presenting the resource through the browser, wherein each of the operations is executed by one or more processors.
2. The method of claim 1, wherein the selective pre-loading depends at least in part on an implicit signal that is indicative of user focus on a content item or a panel containing the content item.
3. The method of claim 2, wherein the implicit signal is a mouse-over or a mouse-hover associated with the content item or a panel containing the content item.
4. The method of claim 2, wherein the implicit signal is a finger-over or a finger-hover associated with the content item or a panel containing the content item.
5. The method of claim 2, wherein the implicit signal is stylus-over or a stylus-hover associated with the content item or a panel containing the content item.
6. The method of claim 2, wherein the implicit signal is associated with a specified time period that is dependent on the panel containing the content item.
7. The method of claim 1, wherein the selective pre-loading is based at least in part on an interestingness ranking associated with the content item.
8. The method of claim 1, wherein the selective pre-loading depends at least in part on activities of other users associated with the user through a list maintained by the online content-aggregation website or an online social-networking website.
9. The method of claim 1, wherein the content item is one of a plurality of content items in a stream in a panel.
10. One or more computer-readable media persistently storing a program, wherein the program, when executed, instructs a processor to perform the following operations:
present a webpage through a browser running on a client device, wherein the webpage is from an online content-aggregation website and includes a plurality of panels containing a plurality of content items;
selectively pre-load into a cache a resource associated with a content item in a panel if the content item is relatively persistent in comparison to the other content items, wherein the cache is controlled by the browser;
retrieve the resource from the cache upon receiving a command from a user; and
present the resource through the browser, wherein each of the operations is executed by one or more processors.
11. The computer-readable media of claim 10, wherein the selective pre-loading depends at least in part on an implicit signal that is indicative of user focus on a content item or a panel containing the content item.
12. The computer-readable media of claim 11, wherein the implicit signal is a mouse-over or a mouse-hover associated with the content item or a panel containing the content item.
13. The computer-readable media of claim 11, wherein the implicit signal is a finger-over or a finger-hover associated with the content item or a panel containing the content item.
14. The computer-readable media of claim 11, wherein the implicit signal is stylus-over or a stylus-hover associated with the content item or a panel containing the content item.
15. The computer-readable media of claim 11, wherein implicit signal is associated with a specified time period that is dependent on the panel containing the content item.
16. The computer-readable media of claim 10, wherein the selective pre-loading is based at least in part on an interestingness ranking associated with the content item or a panel containing the content item.
17. The computer-readable media of claim 10, wherein the selective pre-loading depends at least in part on online activities that are associated with the content item and that have been performed by social contacts of the user according to a list maintained by the online content-aggregation website or an online social-networking website.
18. The computer-readable media of claim 10, wherein the content item is one of a plurality of content items in a stream in a panel.
19. A method, comprising the operations of:
presenting a view on a client device, wherein the view includes a plurality of panels containing a plurality of content items received from an online content-aggregation website;
selectively pre-loading into a cache on the client device a resource associated with a content item in a panel if the content item is relatively persistent in comparison to the other content items;
retrieving the resource from the cache upon receiving a command from a user; and
presenting the resource in a view, wherein each of the operations is executed by one or more processors.
20. The method of claim 19, wherein the selective pre-loading depends at least in part on an implicit signal that is indicative of user focus on a content item or a panel containing the content item.
US14/144,544 2013-12-30 2013-12-30 Smart content pre-loading on client devices Active 2034-10-09 US9990440B2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
US14/144,544 US9990440B2 (en) 2013-12-30 2013-12-30 Smart content pre-loading on client devices
US15/997,677 US10387523B2 (en) 2013-12-30 2018-06-04 Smart content pre-loading on client devices
US16/544,123 US10909208B2 (en) 2013-12-30 2019-08-19 Smart content pre-loading on client devices

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US14/144,544 US9990440B2 (en) 2013-12-30 2013-12-30 Smart content pre-loading on client devices

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US15/997,677 Continuation US10387523B2 (en) 2013-12-30 2018-06-04 Smart content pre-loading on client devices

Publications (2)

Publication Number Publication Date
US20150186545A1 true US20150186545A1 (en) 2015-07-02
US9990440B2 US9990440B2 (en) 2018-06-05

Family

ID=53482064

Family Applications (3)

Application Number Title Priority Date Filing Date
US14/144,544 Active 2034-10-09 US9990440B2 (en) 2013-12-30 2013-12-30 Smart content pre-loading on client devices
US15/997,677 Active US10387523B2 (en) 2013-12-30 2018-06-04 Smart content pre-loading on client devices
US16/544,123 Active US10909208B2 (en) 2013-12-30 2019-08-19 Smart content pre-loading on client devices

Family Applications After (2)

Application Number Title Priority Date Filing Date
US15/997,677 Active US10387523B2 (en) 2013-12-30 2018-06-04 Smart content pre-loading on client devices
US16/544,123 Active US10909208B2 (en) 2013-12-30 2019-08-19 Smart content pre-loading on client devices

Country Status (1)

Country Link
US (3) US9990440B2 (en)

Cited By (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20150355795A1 (en) * 2014-06-06 2015-12-10 Apple Inc. Continuous reading of articles
US20160306894A1 (en) * 2013-10-25 2016-10-20 Uc Mobile Co., Ltd. Methods and devices for preloading webpages
WO2017131857A1 (en) * 2016-01-25 2017-08-03 Google Inc. Reducing latency
US20170286561A1 (en) * 2016-04-04 2017-10-05 International Business Machines Corporation System and method to accelerate accessing content
US20180293087A1 (en) * 2015-10-02 2018-10-11 Samsung Electronics Co., Ltd. Apparatus and method for performing application in electronic device
US20180324230A1 (en) * 2017-05-03 2018-11-08 Inshorts Medialabs Private Limited System and method for digital content broadcasting to subscribers in a network
US20190019517A1 (en) * 2017-07-13 2019-01-17 Comcast Cable Communications, Llc Caching Scheme For Voice Recognition Engines
US20190079946A1 (en) * 2017-09-13 2019-03-14 Microsoft Technology Licensing, Llc Intelligent file recommendation
CN110598137A (en) * 2018-05-23 2019-12-20 北京三快在线科技有限公司 Page display method and device and computing equipment
US10630797B2 (en) * 2018-01-30 2020-04-21 Akamai Technologies, Inc. Systems and methods for content delivery acceleration of virtual reality and augmented reality web pages
US10706119B1 (en) * 2015-04-30 2020-07-07 Tensera Networks Ltd. Content prefetching to user devices based on rendering characteristics
WO2020252486A1 (en) * 2019-06-14 2020-12-17 Zycada Networks, Inc., Proactive conditioned prefetching and origin flooding mitigation for content delivery
US11310300B2 (en) * 2016-09-02 2022-04-19 Snap Inc. Video streaming optimization for quick start of video display
US11389729B2 (en) * 2015-03-06 2022-07-19 Sony Interactive Entertainment LLC Predictive instant play for an application over the cloud
US11443099B2 (en) * 2015-10-28 2022-09-13 Viasat, Inc. Time-dependent machine-generated hinting
US20220407939A1 (en) * 2014-06-03 2022-12-22 Viasat, Inc. Server-machine-driven hint generation for improved web page loading using client-machine-driven feedback

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11194716B2 (en) 2020-04-06 2021-12-07 International Business Machines Corporation Intelligent cache preloading

Citations (53)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050071571A1 (en) * 2003-09-30 2005-03-31 International Business Machines Corporation Apparatus and method for pre-fetching data to cached memory using persistent historical page table data
US20050192814A1 (en) * 2004-02-13 2005-09-01 International Business Machines Corporation Browser URL and content preloading based on autonomic collaboration
US20060101514A1 (en) * 2004-11-08 2006-05-11 Scott Milener Method and apparatus for look-ahead security scanning
US7130890B1 (en) * 2002-09-04 2006-10-31 Hewlett-Packard Development Company, L.P. Method and system for adaptively prefetching objects from a network
US7231496B2 (en) * 2003-09-15 2007-06-12 International Business Machines Corporation Method, system and program product for caching data objects
US20080177528A1 (en) * 2007-01-18 2008-07-24 William Drewes Method of enabling any-directional translation of selected languages
US20090019354A1 (en) * 2007-07-10 2009-01-15 Yahoo! Inc. Automatically fetching web content with user assistance
US20090132949A1 (en) * 2007-11-16 2009-05-21 Jason Bosarge Methods and systems for transmitting, receiving and annotating internet content
US20090150769A1 (en) * 2007-12-11 2009-06-11 Konnola Mika Method and arrangement for paginating and previewing xhtml/html formatted information content
US20090158166A1 (en) * 2007-12-14 2009-06-18 Dewar Ami H Method, system, and computer program product for automatic rearrangement of modules based on user interaction
US7580972B2 (en) * 2001-12-12 2009-08-25 Valve Corporation Method and system for controlling bandwidth on client and server
US7640304B1 (en) * 2006-06-14 2009-12-29 Yes International Ag System and method for detecting and measuring emotional indicia
US7685255B2 (en) * 2006-04-24 2010-03-23 Blue Coat Systems, Inc. System and method for prefetching uncacheable embedded objects
US20110202827A1 (en) * 2009-12-24 2011-08-18 Vertical Acuity, Inc. Systems and Methods for Curating Content
US20110238828A1 (en) * 2008-07-23 2011-09-29 International Business Machines Corporation Redirecting web content
US20110314396A1 (en) * 2004-03-15 2011-12-22 Ali Diab Integration of personalized portals with web content syndication
US20120290675A1 (en) * 2011-04-19 2012-11-15 Michael Luna System and method for a mobile device to use physical storage of another device for caching
US8332763B2 (en) * 2009-06-09 2012-12-11 Microsoft Corporation Aggregating dynamic visual content
US8341245B1 (en) * 2011-09-26 2012-12-25 Google Inc. Content-facilitated speculative preparation and rendering
US20130238762A1 (en) * 2012-03-10 2013-09-12 Headwater Partners Ii Llc Content broker that offers preloading opportunities
US20130262966A1 (en) * 2012-04-02 2013-10-03 Industrial Technology Research Institute Digital content reordering method and digital content aggregator
US20130318448A1 (en) * 2005-12-30 2013-11-28 Facebook, Inc. Presenting image previews in electronic messages
US8713418B2 (en) * 2004-04-12 2014-04-29 Google Inc. Adding value to a rendered document
US20140136971A1 (en) * 2012-11-14 2014-05-15 Amazon Technologies, Inc. Delivery and display of page previews during page retrieval events
US20140143320A1 (en) * 2008-03-31 2014-05-22 Amazon Technologies, Inc. Content management
US20140223462A1 (en) * 2012-12-04 2014-08-07 Christopher Allen Aimone System and method for enhancing content using brain-state data
US20140278346A1 (en) * 2013-03-15 2014-09-18 Google Inc. Automatic invocation of a dialog user interface for translation applications
US20140289332A1 (en) * 2013-03-25 2014-09-25 Salesforce.Com, Inc. System and method for prefetching aggregate social media metrics using a time series cache
US20140295801A1 (en) * 2012-05-31 2014-10-02 Tip Solutions, Inc. Image response system and method of forming same
US20140372589A1 (en) * 2011-12-14 2014-12-18 Level 3 Communications, Llc Customer-Specific Request-Response Processing in a Content Delivery Network
US20140380200A1 (en) * 2002-09-10 2014-12-25 Alan Earl Swahn Internet browser zoom function
US20150012614A1 (en) * 2013-03-15 2015-01-08 Instart Logic, Inc. Efficient delivery of webpages
US8943043B2 (en) * 2010-01-24 2015-01-27 Microsoft Corporation Dynamic community-based cache for mobile search
US8990685B1 (en) * 2006-03-31 2015-03-24 United Services Automobile Association (Usaa) Systems and methods for creating and displaying web documents
US20150089352A1 (en) * 2013-09-25 2015-03-26 Akamai Technologies, Inc. Key Resource Prefetching Using Front-End Optimization (FEO) Configuration
US20150120858A1 (en) * 2013-10-28 2015-04-30 Tealium Inc. System for prefetching digital tags
US9043389B2 (en) * 2005-05-04 2015-05-26 Venturi Ip Llc Flow control method and apparatus for enhancing the performance of web browsers over bandwidth constrained links
USRE45543E1 (en) * 2001-04-24 2015-06-02 Tena Technology, Llc Method and apparatus for selectively sharing and passively tracking communication device experiences
US20150193395A1 (en) * 2012-07-30 2015-07-09 Google Inc. Predictive link pre-loading
US20150212712A1 (en) * 2004-03-02 2015-07-30 Microsoft Corporation Advanced navigation techniques for portable devices
US20150213514A1 (en) * 2010-06-29 2015-07-30 Vibrant Media, Inc. Systems and methods for providing modular configurable creative units for delivery via intext advertising
US9117232B2 (en) * 2005-07-15 2015-08-25 Amazon Technologies, Inc. Browser-based retrieval and display of content associated with a link that matches a link signature
US9118623B2 (en) * 2005-12-30 2015-08-25 Akamai Technologies, Inc. Site acceleration with customer prefetching enabled through customer-specific configurations
US20150271246A1 (en) * 2008-08-29 2015-09-24 Google Inc. Adaptive Accelerated Application Startup
US20150319260A1 (en) * 2012-06-11 2015-11-05 Amazon Technologies, Inc. Processing dns queries to identify pre-processing information
US20150379989A1 (en) * 2014-06-26 2015-12-31 Nuance Communications, Inc. Voice-controlled information exchange platform, such as for providing information to supplement advertising
US20160007057A1 (en) * 2014-07-07 2016-01-07 Alcatel-Lucent Usa Inc. Asynchronous encoding of digital content
US9275162B2 (en) * 2011-03-22 2016-03-01 Blackberry Limited Pre-caching web content for a mobile device
US9407717B1 (en) * 2010-04-18 2016-08-02 Viasat, Inc. Selective prefetch scanning
US9411856B1 (en) * 2012-10-01 2016-08-09 Google Inc. Overlay generation for sharing a website
US9454506B2 (en) * 2009-05-01 2016-09-27 International Business Machines Corporation Managing cache at a computer
US9626343B2 (en) * 2010-04-05 2017-04-18 Facebook, Inc. Caching pagelets of structured documents
US20170163759A1 (en) * 2012-02-27 2017-06-08 Amazon Technologies, Inc. Managing preloading of data on client systems

Family Cites Families (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6182133B1 (en) * 1998-02-06 2001-01-30 Microsoft Corporation Method and apparatus for display of information prefetching and cache status having variable visual indication based on a period of time since prefetching
US7886067B2 (en) * 2003-08-14 2011-02-08 Rich Hedia Club, LLC Internet-based system and method for distributing interstitial advertisements
US20050071736A1 (en) * 2003-09-26 2005-03-31 Fuji Xerox Co., Ltd. Comprehensive and intuitive media collection and management tool
US20050069225A1 (en) * 2003-09-26 2005-03-31 Fuji Xerox Co., Ltd. Binding interactive multichannel digital document system and authoring tool
US20060069617A1 (en) * 2004-09-27 2006-03-30 Scott Milener Method and apparatus for prefetching electronic data for enhanced browsing
US20070101061A1 (en) * 2005-10-27 2007-05-03 Guruprasad Baskaran Customized content loading mechanism for portions of a web page in real time environments
US20090006211A1 (en) * 2007-07-01 2009-01-01 Decisionmark Corp. Network Content And Advertisement Distribution System and Method
US8745341B2 (en) * 2008-01-15 2014-06-03 Red Hat, Inc. Web server cache pre-fetching
US8539161B2 (en) * 2009-10-12 2013-09-17 Microsoft Corporation Pre-fetching content items based on social distance
US9747604B2 (en) * 2010-01-22 2017-08-29 Google Inc. Automated agent for social media systems
US20110231482A1 (en) * 2010-03-22 2011-09-22 Strangeloop Networks Inc. Automated Optimization Based On Determination Of Website Usage Scenario
US9146909B2 (en) * 2011-07-27 2015-09-29 Qualcomm Incorporated Web browsing enhanced by cloud computing
US9208511B2 (en) * 2011-08-22 2015-12-08 Simple Rules, Inc. System and method for location-based recommendations
US8826153B2 (en) * 2011-10-04 2014-09-02 Google Inc. Speculative actions based on user dwell time over selectable content
US9373146B2 (en) * 2012-09-24 2016-06-21 Facebook, Inc. Inferring target clusters based on social connections
US20140280677A1 (en) * 2013-03-15 2014-09-18 Limelight Networks, Inc. Two-file preloading for browser-based web acceleration
US8645494B1 (en) * 2013-03-15 2014-02-04 Limelight Networks, Inc. Two-file preloading for browser-based web acceleration
US9747004B2 (en) * 2013-10-29 2017-08-29 Microsoft Technology Licensing, Llc Web content navigation using tab switching
US10009439B1 (en) * 2013-12-05 2018-06-26 Instart Logic, Inc. Cache preloading
RU2629448C2 (en) * 2014-07-09 2017-08-29 Общество С Ограниченной Ответственностью "Яндекс" System and method of controlling and organizing web-browser cash
US9729648B2 (en) * 2014-08-06 2017-08-08 Facebook, Inc. Recommending objects to a user of a social networking system based on implicit interactions between the user and the recommended objects
US9852759B2 (en) * 2014-10-25 2017-12-26 Yieldmo, Inc. Methods for serving interactive content to a user
US10169481B2 (en) * 2015-02-18 2019-01-01 Adobe Systems Incorporated Method for intelligent web reference preloading based on user behavior prediction
US10732826B2 (en) * 2017-11-22 2020-08-04 Microsoft Technology Licensing, Llc Dynamic device interaction adaptation based on user engagement

Patent Citations (55)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
USRE45543E1 (en) * 2001-04-24 2015-06-02 Tena Technology, Llc Method and apparatus for selectively sharing and passively tracking communication device experiences
US7580972B2 (en) * 2001-12-12 2009-08-25 Valve Corporation Method and system for controlling bandwidth on client and server
US7130890B1 (en) * 2002-09-04 2006-10-31 Hewlett-Packard Development Company, L.P. Method and system for adaptively prefetching objects from a network
US20140380200A1 (en) * 2002-09-10 2014-12-25 Alan Earl Swahn Internet browser zoom function
US7231496B2 (en) * 2003-09-15 2007-06-12 International Business Machines Corporation Method, system and program product for caching data objects
US20050071571A1 (en) * 2003-09-30 2005-03-31 International Business Machines Corporation Apparatus and method for pre-fetching data to cached memory using persistent historical page table data
US20050192814A1 (en) * 2004-02-13 2005-09-01 International Business Machines Corporation Browser URL and content preloading based on autonomic collaboration
US20150212712A1 (en) * 2004-03-02 2015-07-30 Microsoft Corporation Advanced navigation techniques for portable devices
US20110314396A1 (en) * 2004-03-15 2011-12-22 Ali Diab Integration of personalized portals with web content syndication
US8713418B2 (en) * 2004-04-12 2014-04-29 Google Inc. Adding value to a rendered document
US20060101514A1 (en) * 2004-11-08 2006-05-11 Scott Milener Method and apparatus for look-ahead security scanning
US9043389B2 (en) * 2005-05-04 2015-05-26 Venturi Ip Llc Flow control method and apparatus for enhancing the performance of web browsers over bandwidth constrained links
US9117232B2 (en) * 2005-07-15 2015-08-25 Amazon Technologies, Inc. Browser-based retrieval and display of content associated with a link that matches a link signature
US9118623B2 (en) * 2005-12-30 2015-08-25 Akamai Technologies, Inc. Site acceleration with customer prefetching enabled through customer-specific configurations
US20130318448A1 (en) * 2005-12-30 2013-11-28 Facebook, Inc. Presenting image previews in electronic messages
US8990685B1 (en) * 2006-03-31 2015-03-24 United Services Automobile Association (Usaa) Systems and methods for creating and displaying web documents
US7685255B2 (en) * 2006-04-24 2010-03-23 Blue Coat Systems, Inc. System and method for prefetching uncacheable embedded objects
US7640304B1 (en) * 2006-06-14 2009-12-29 Yes International Ag System and method for detecting and measuring emotional indicia
US20080177528A1 (en) * 2007-01-18 2008-07-24 William Drewes Method of enabling any-directional translation of selected languages
US20090019354A1 (en) * 2007-07-10 2009-01-15 Yahoo! Inc. Automatically fetching web content with user assistance
US20090132949A1 (en) * 2007-11-16 2009-05-21 Jason Bosarge Methods and systems for transmitting, receiving and annotating internet content
US20090150769A1 (en) * 2007-12-11 2009-06-11 Konnola Mika Method and arrangement for paginating and previewing xhtml/html formatted information content
US20090158166A1 (en) * 2007-12-14 2009-06-18 Dewar Ami H Method, system, and computer program product for automatic rearrangement of modules based on user interaction
US20140143320A1 (en) * 2008-03-31 2014-05-22 Amazon Technologies, Inc. Content management
US20110238828A1 (en) * 2008-07-23 2011-09-29 International Business Machines Corporation Redirecting web content
US20150271246A1 (en) * 2008-08-29 2015-09-24 Google Inc. Adaptive Accelerated Application Startup
US9454506B2 (en) * 2009-05-01 2016-09-27 International Business Machines Corporation Managing cache at a computer
US8332763B2 (en) * 2009-06-09 2012-12-11 Microsoft Corporation Aggregating dynamic visual content
US20110202827A1 (en) * 2009-12-24 2011-08-18 Vertical Acuity, Inc. Systems and Methods for Curating Content
US8943043B2 (en) * 2010-01-24 2015-01-27 Microsoft Corporation Dynamic community-based cache for mobile search
US20170177736A1 (en) * 2010-04-05 2017-06-22 Facebook, Inc. Caching pagelets of structured documents
US9626343B2 (en) * 2010-04-05 2017-04-18 Facebook, Inc. Caching pagelets of structured documents
US9407717B1 (en) * 2010-04-18 2016-08-02 Viasat, Inc. Selective prefetch scanning
US20150213514A1 (en) * 2010-06-29 2015-07-30 Vibrant Media, Inc. Systems and methods for providing modular configurable creative units for delivery via intext advertising
US9275162B2 (en) * 2011-03-22 2016-03-01 Blackberry Limited Pre-caching web content for a mobile device
US20120290675A1 (en) * 2011-04-19 2012-11-15 Michael Luna System and method for a mobile device to use physical storage of another device for caching
US8341245B1 (en) * 2011-09-26 2012-12-25 Google Inc. Content-facilitated speculative preparation and rendering
US20140372589A1 (en) * 2011-12-14 2014-12-18 Level 3 Communications, Llc Customer-Specific Request-Response Processing in a Content Delivery Network
US20170163759A1 (en) * 2012-02-27 2017-06-08 Amazon Technologies, Inc. Managing preloading of data on client systems
US20130238762A1 (en) * 2012-03-10 2013-09-12 Headwater Partners Ii Llc Content broker that offers preloading opportunities
US20130262966A1 (en) * 2012-04-02 2013-10-03 Industrial Technology Research Institute Digital content reordering method and digital content aggregator
US20140295801A1 (en) * 2012-05-31 2014-10-02 Tip Solutions, Inc. Image response system and method of forming same
US20150319260A1 (en) * 2012-06-11 2015-11-05 Amazon Technologies, Inc. Processing dns queries to identify pre-processing information
US20150193395A1 (en) * 2012-07-30 2015-07-09 Google Inc. Predictive link pre-loading
US9411856B1 (en) * 2012-10-01 2016-08-09 Google Inc. Overlay generation for sharing a website
US20140136971A1 (en) * 2012-11-14 2014-05-15 Amazon Technologies, Inc. Delivery and display of page previews during page retrieval events
US20140223462A1 (en) * 2012-12-04 2014-08-07 Christopher Allen Aimone System and method for enhancing content using brain-state data
US20150012614A1 (en) * 2013-03-15 2015-01-08 Instart Logic, Inc. Efficient delivery of webpages
US20140278346A1 (en) * 2013-03-15 2014-09-18 Google Inc. Automatic invocation of a dialog user interface for translation applications
US20140289332A1 (en) * 2013-03-25 2014-09-25 Salesforce.Com, Inc. System and method for prefetching aggregate social media metrics using a time series cache
US20150089352A1 (en) * 2013-09-25 2015-03-26 Akamai Technologies, Inc. Key Resource Prefetching Using Front-End Optimization (FEO) Configuration
US9081789B2 (en) * 2013-10-28 2015-07-14 Tealium Inc. System for prefetching digital tags
US20150120858A1 (en) * 2013-10-28 2015-04-30 Tealium Inc. System for prefetching digital tags
US20150379989A1 (en) * 2014-06-26 2015-12-31 Nuance Communications, Inc. Voice-controlled information exchange platform, such as for providing information to supplement advertising
US20160007057A1 (en) * 2014-07-07 2016-01-07 Alcatel-Lucent Usa Inc. Asynchronous encoding of digital content

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
Balasubramanian et al., Enhancing Interactive Web Applications in Hybrid Networks, ACM 2008, pages 70-80. *
Bright et al., Using Latency-Recency Profiles for Data Delivery on the Web, ACM 2002, pages 1-12. *
McSherry, A Uniform Approach to Accelerated PageRank Computation, ACM 2005, pages 575-582. *
Mika, Developing Social-Semantic Applications, Springer 2007, pages 121-122 (from Google Scholar). *
Temgire et al., Review on Web Prefetching Techniques, Google 2013, pages 100-105. *
Wei et al., Algorithm of Mining Sequential Patterns for Web Personalization Services, ACM 2009, pages 57-66. *

Cited By (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20160306894A1 (en) * 2013-10-25 2016-10-20 Uc Mobile Co., Ltd. Methods and devices for preloading webpages
US9798827B2 (en) * 2013-10-25 2017-10-24 Uc Mobile Co., Ltd. Methods and devices for preloading webpages
US20220407939A1 (en) * 2014-06-03 2022-12-22 Viasat, Inc. Server-machine-driven hint generation for improved web page loading using client-machine-driven feedback
US20150355795A1 (en) * 2014-06-06 2015-12-10 Apple Inc. Continuous reading of articles
US10055096B2 (en) * 2014-06-06 2018-08-21 Apple Inc. Continuous reading of articles
US11389729B2 (en) * 2015-03-06 2022-07-19 Sony Interactive Entertainment LLC Predictive instant play for an application over the cloud
US10706119B1 (en) * 2015-04-30 2020-07-07 Tensera Networks Ltd. Content prefetching to user devices based on rendering characteristics
US10936340B2 (en) * 2015-10-02 2021-03-02 Samsung Electronics Co., Ltd. Apparatus and method for performing selective application preloading in electronic device
US20180293087A1 (en) * 2015-10-02 2018-10-11 Samsung Electronics Co., Ltd. Apparatus and method for performing application in electronic device
US11443099B2 (en) * 2015-10-28 2022-09-13 Viasat, Inc. Time-dependent machine-generated hinting
US10075449B2 (en) 2016-01-25 2018-09-11 Google Llc Reducing latency
US9838399B2 (en) 2016-01-25 2017-12-05 Google Inc. Reducing latency
US11343254B2 (en) 2016-01-25 2022-05-24 Google Llc Reducing latency
CN107231816A (en) * 2016-01-25 2017-10-03 谷歌公司 Reduce time delay
CN112883305A (en) * 2016-01-25 2021-06-01 谷歌有限责任公司 Reducing time delay
WO2017131857A1 (en) * 2016-01-25 2017-08-03 Google Inc. Reducing latency
US20170286561A1 (en) * 2016-04-04 2017-10-05 International Business Machines Corporation System and method to accelerate accessing content
US11310300B2 (en) * 2016-09-02 2022-04-19 Snap Inc. Video streaming optimization for quick start of video display
US20180324230A1 (en) * 2017-05-03 2018-11-08 Inshorts Medialabs Private Limited System and method for digital content broadcasting to subscribers in a network
US10629207B2 (en) * 2017-07-13 2020-04-21 Comcast Cable Communications, Llc Caching scheme for voice recognition engines
US20190019517A1 (en) * 2017-07-13 2019-01-17 Comcast Cable Communications, Llc Caching Scheme For Voice Recognition Engines
US20190079946A1 (en) * 2017-09-13 2019-03-14 Microsoft Technology Licensing, Llc Intelligent file recommendation
KR20200126972A (en) * 2018-01-30 2020-11-09 아카마이 테크놀로지스, 인크. Systems and Methods for Accelerating Content Delivery of Virtual Reality and Augmented Reality Web Pages
US10630797B2 (en) * 2018-01-30 2020-04-21 Akamai Technologies, Inc. Systems and methods for content delivery acceleration of virtual reality and augmented reality web pages
KR102421701B1 (en) 2018-01-30 2022-07-14 아카마이 테크놀로지스, 인크. Systems and Methods for Accelerating Content Delivery of Virtual Reality and Augmented Reality Web Pages
CN110598137A (en) * 2018-05-23 2019-12-20 北京三快在线科技有限公司 Page display method and device and computing equipment
WO2020252486A1 (en) * 2019-06-14 2020-12-17 Zycada Networks, Inc., Proactive conditioned prefetching and origin flooding mitigation for content delivery
US11641389B2 (en) 2019-06-14 2023-05-02 Zycada Networks, Inc. Proactive conditioned prefetching and origin flooding mitigation for content delivery

Also Published As

Publication number Publication date
US10387523B2 (en) 2019-08-20
US20180285472A1 (en) 2018-10-04
US20190370307A1 (en) 2019-12-05
US10909208B2 (en) 2021-02-02
US9990440B2 (en) 2018-06-05

Similar Documents

Publication Publication Date Title
US10909208B2 (en) Smart content pre-loading on client devices
US9661100B2 (en) Podcasts in personalized content streams
US20220167053A1 (en) Identifying related videos based on relatedness of elements tagged in the videos
US10127311B2 (en) Personalized content sharing
US8484226B2 (en) Media recommendations for a social-software website
US10564805B2 (en) Determining content sessions using content-consumption events
US10776433B2 (en) User profile expansion for personalization and recommendation
US20160014227A1 (en) Personalizing an application with content from a social networking system
US10360642B2 (en) Global comments for a media item
US9792372B2 (en) Using exogenous sources for personalization of website services
US8756279B2 (en) Analyzing content demand using social signals
US10311362B1 (en) Identification of trending content using social network activity and user interests
WO2013019688A2 (en) Social network powered query suggestions
US8923621B2 (en) Finding engaging media with initialized explore-exploit
US10834211B2 (en) Baseline interest profile for recommendations using a geographic location
US20160380953A1 (en) Smart feed system
WO2015130822A1 (en) Splitting content channels
US9660880B2 (en) Non-committal visitor stitching
EP2725538B1 (en) Privacy protected dynamic clustering of end users
US20170193074A1 (en) Finding Related Articles for a Content Stream Using Iterative Merge-Split Clusters
EP3289786B1 (en) Notification targeting based on downstream user engagement
CN106464682B (en) Using logged-on status to online service for content item recommendation
WO2015099658A1 (en) Contextual contacts for html5
US9967354B2 (en) Cache refreshing for online social newsfeeds
Balakrishnan et al. Data Allocation Strategies in Distributed Database Systems

Legal Events

Date Code Title Description
AS Assignment

Owner name: YAHOO! INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KRUTZLER, STEVE;CAMPBELL, EDWARD J., III;MOTGI, AMIT;AND OTHERS;SIGNING DATES FROM 20131220 TO 20141201;REEL/FRAME:034308/0294

AS Assignment

Owner name: YAHOO HOLDINGS, INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:YAHOO! INC.;REEL/FRAME:042963/0211

Effective date: 20170613

AS Assignment

Owner name: OATH INC., NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:YAHOO HOLDINGS, INC.;REEL/FRAME:045240/0310

Effective date: 20171231

STCF Information on status: patent grant

Free format text: PATENTED CASE

AS Assignment

Owner name: VERIZON MEDIA INC., NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:OATH INC.;REEL/FRAME:054258/0635

Effective date: 20201005

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4

AS Assignment

Owner name: YAHOO ASSETS LLC, VIRGINIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:YAHOO AD TECH LLC (FORMERLY VERIZON MEDIA INC.);REEL/FRAME:058982/0282

Effective date: 20211117

AS Assignment

Owner name: ROYAL BANK OF CANADA, AS COLLATERAL AGENT, CANADA

Free format text: PATENT SECURITY AGREEMENT (FIRST LIEN);ASSIGNOR:YAHOO ASSETS LLC;REEL/FRAME:061571/0773

Effective date: 20220928