The disclosed method and apparatus relate generally to the processing of information received via a network and more particularly to the collection and manipulation of information related to content distributed over networks.
The world wide web is a platform that has been used to exchange various forms of content including videos, text, music, etc. Often this content is distributed to users and/or computers in an ad-hoc fashion, for example, using e-mail or as files embedded in a web page. Recently, primitive forms of “viral” distribution and/or replication of content have been developed that allow users to more easily spread content to other users than previously known ad-hoc methods. Although these primitive methods are more convenient than distributing content in an ad-hoc fashion, they have many shortcomings. For example, they do not provide for the ability to easily add services related to the content and services, if any exist, cannot be dynamically modified. The spreading of content using ad-hoc methods and/or primitive forms of viral spreading cannot be tracked as a service in a useful and efficient way. Moreover, limitations in the ability to track spreading content and to efficiently process any information that can be tracked also limits the ability to dynamically modify behavior associated with the content. Content also cannot be readily shared with users of different platforms (e.g., personal digital assistant to personal computer).
Thus, a need exists for efficiently collecting and manipulating information related to content distributed to users and/or computers.
A method includes multiple data handling stages for manipulating tracked information associated with content that has been distributed to users and/or computers, such as static objects, media objects, and/or software objects, for example. The content can be distributed as widget instances and the associated tracked information can be received over a network. The information received can be associated with a session corresponding to each widget instance and/or with multiple identifiers, such as widget, user, content, session, content aggregation point, processor, and/or placement identifiers, for example. Data handling processes, including sorting, storing, filtering, combining, queuing, and/or authenticating, for example, can be performed during the data handling stages. The processed information can be used to determine modifications to a behavior associated with widgets and/or widget containers.
The disclosed method and apparatus are described with reference to the accompanying drawings. In the drawings, identical or like reference numbers indicate identical or functionally similar elements.
A widget container (also can be referred to as a container) is a procedural software framework that contains a widget and/or contains at least one service module that can be associated with the widget. As a procedural software framework, the widget container can be a series of instructions that are executable or interpretable by, for example, a computer processor. The widget and/or service module is “contained” in the widget container when a widget and/or service module is either referenced in a widget container or actually integrated into the procedural software framework of the widget container. The widget and/or service module when being contained in the widget container can be referred to as being wrapped or containerized in the widget container.
The widget container can be a portable framework that can be embedded in (e.g., referenced using an embed or object tag) and/or accessed from/using, for example, a processor-readable vehicle (e.g., webpage) and/or a content aggregation point. A content aggregation point can be, for example, managed by (e.g., hosted at, served from) and/or executed at the network entity and can be, for example, a desktop, a start page, a wireless application protocol (WAP) gallery, a gallery, a webpage, a processor-readable vehicle, a portal, and/or a directory. The widget can be any type of object such as a static data object (e.g., a text-based object), a media object (e.g., a video, an mp3, or an image), and/or a software object (e.g., a javascript applet, a rich media object) that can be contained (e.g., integrated or referenced) in the widget container. In many embodiments, the widget and/or the service module (or references to the widget and/or service module) can be referred to as components of the widget container.
The service module (or reference to the service module) contained in the widget container can be a pre-defined and/or customizable (e.g., user-defined) function related to a variety of functions (e.g., tracking, placing) related to the widget container and/or its components. The service module and/or widget can be wrapped in the container, for example, at the time that the widget container is first generated, after the widget container has been generated, and/or dynamically when the widget container is being served. The widget container can be produced using a widget generation engine that can be implemented in hardware and/or software. In some embodiments, the widget generation engine can be controlled using, for example, a user-interface. In some embodiments, the widget container generation engine can be included in a widget container host and/or a widget container creation device. In some embodiments, the widget container can be dynamically modified using dynamic injection (i.e., injecting data into the widget container just before/when the widget container is served).
In some embodiments, the functions typically associated with the widget container and/or the functions typically associated with the service module can be invoked by a widget. In some embodiments, these functions can be invoked by a widget that is not contained in a widget container. For example, in some embodiments, these functions can be invoked at a server by a widget via, for example, an application programming interface (API). In some embodiments, these functions can be stand-alone applications that can be triggered to execute by a widget that may not be contained in a widget container. In some embodiments, the functions associated with the widget container and/or the functions associated with the service module can be included in and/or executed at a widget. In some embodiments, these functions can be referred to as kernel functions and the widget can be referred to as a kernel-containing widget.
The widget container or the widget (which can be configured to invoke a kernel) can be sent from a host to a processing device such as, for example, a computer or mobile phone when a reference to the widget container or to the widget is accessed from, for example, a webpage, a WAP page, a WAP gallery, etc. The widget container or the widget can be executed on various platforms and instances of references to the widget container or to the widget can be included in and/or spread to a variety of processor-readable vehicles (e.g., web browser) that can be read using various processing devices. Also, metadata can be associated with the widget container or the widget and/or associated with a component of the widget container or with a component of the widget, so that the widget container or the widget and/or the component of the widget container or the component of the widget can be, for example, dynamically customized and/or tracked. More details related to placement of a widget container and/or platform adaptation of a widget are set forth in co-pending application Ser. No. 11/682,626, “Method and Apparatus for Widget and Widget-Container Platform Adaptation and Distribution,” which is incorporated herein by reference in its entirety.
After a widget and/or widget container (which can contain the widget) is sent to a processing device, tracking information (e.g., widget type, user information, placement information, session information, etc.) that is collected before, during, or after the widget and/or widget container are executed at the processing device can be sent from the widget to a computing entity (e.g., set of servers). The computing entity can be configured to collect such tracking information associated with multiple widgets and/or widget containers. The widgets and/or widget containers, can be, for example, instances of widgets and/or widget containers that have been virally spread. The tracking information can be used to, for example, dynamically modify the behavior of widgets and/or widget containers that have been distributed and/or are currently executing. The tracking information can also be used to, for example, modify the behavior of subsequently shared instances of widgets and/or widget containers. The sharing of an instance of a widget can be triggered by a sharing request. In some embodiments, the sharing request can be a widget precursor. The tracking information can be collected and/or transmitted using a tracking kernel.
The tracking information can be processed using various systems, such as those shown in
In this written description and the appended claims, the singular forms “a,” “an” and “the” include plural referents unless the context clearly dictates otherwise. Thus, for example, the term “an identifier” is intended to mean a single identifier or a combination of identifiers.
The processors 110, 155, and/or 175 can include software-based modules (e.g., set of instructions executable at a processor, software code) and/or hardware-based modules (e.g., circuit system, processor, application-specific integrated circuit (ASIC), field programmable gate array (FPGA)) for handling (i.e., receiving, processing, manipulating, or modifying) tracking information. The memories 115, 160, and/or 180 can include a machine-readable storage medium, such as an integrated circuit (IC) memory, for example, that can be configured to store data at various stages of handling. The data storage mediums 1201, . . . , 120P, 1651, . . . , 165R, and 1901, . . . , 190L can correspond to, for example, databases for storing, collecting, and/or organizing information associated with the tracked information received from distributed instances of widgets. The data storage mediums 1201, . . . , 120P, 1651, . . . , 165R, and 1901, . . . , 190L can also correspond to, for example, databases (e.g., remote database, distributed database, relational database) having additional information that can be used when processing the tracked information or tracking information, such as, for example, third-party data. The additional information can be, for example, metadata such as user-defined information associated with a user profile associated with a widget or a particular instance of a widget. The additional information can be a subset of tracking information. In some embodiments, the additional information can be collected asynchronously from the tracking information (e.g., in between tracking information packet bursts).
A service module (not shown) included in the widget container 140 and/or included in the kernel 146 can be configured to transmit or communicate tracking information associated with the instance of widget 145 and 141, respectively, to at least a specified portion of the servers 1001, . . . , 100N via the network A. In this regard, the service module included in the widget container 140 and/or included in the kernel 146 can be configured before the associated widget is loaded, at the time the widget is loaded, when the widget is rendered, at the request of the widget, and/or dynamically after the widget is loaded.
The tracking information can include various types of information, such as, but not limited to, widget information such as widget type (e.g., video player, image), user information (e.g., username, user behavior, sex of user), content information such as the type of content in the widget (e.g., personal video, shared video), placement information (e.g., sharing lineage or parentage), session information (e.g., widget session activity, session identifier), content aggregation point information (e.g., webpage characteristics, browser, browser type), and processor information related to a processor type (e.g., Intel, Motorola, ARM).
Each type of tracking information can be associated with a variety of identifiers. For example, widget information can be associated with a widget identifier, user information can be associated with a user identifier, content information can be associated with a content identifier, placement information can be associated with a placement identifier, session information can be associated with a session identifier, content aggregation point information can be associated with a content aggregation point identifier, and processor information can be associated with a processor identifier. Each of these identifiers can indicate a category or sub-category of the corresponding tracking information. The tracking information can correspond to usage, behavior, performance, characteristics, and/or activities associated with the instances of the widgets and/or the processing devices. One or more of the identifiers can be associated with a group of tracking information transmitted to, for example, the servers 1001, . . . , 100N at, for example, a specified interval of time.
The network A can be any type of network such as a local area network (LAN), a wide area network (WAN), and/or a metropolitan area network (MAN) implemented as a wired and/or wireless network in a variety of environments such as, for example, an office complex or a campus. In some instances, the network A can include more than one network that collectively provides a path for the tracking information to be transmitted and/or communicated from processing devices (e.g., the processing devices 130 and 131) to at least a portion of the servers 1001, . . . , 100N.
In some embodiments, the servers 1001, . . . , 100N can be configured to perform a first portion of handling the tracking information, the servers 1501, . . . , 150M can be configured to perform a second portion of the handling of tracking information, and the servers 1701, . . . , 170K can be configured to perform a third portion of handling the tracking information. In this regard, the servers can be referred to as computing entities or computing devices that may perform one or more digital computations or operations related to processes for handling tracking information.
In some embodiments, the output of the processes performed by the servers 1001, . . . , 100N can be sent to and received by the servers 1501, . . . , 150M. Similarly, the output of the processes performed by the servers 1501, . . . , 150M can be sent to and received by the servers 1701, . . . , 170K. In some embodiments, only a subset or a portion of the servers 1001, . . . , 100N, the servers 1501, . . . , 150M, and the servers 1701, . . . , 170K can be used for one or more portions of the handling of the tracking information. For example, handling the tracking information can be performed by a subset or a portion of the servers 1001, . . . , 100N and the servers 1701, . . . , 170K. In this regard, a communication path (not shown) can exist between the servers 1001, . . . , 100N and the servers 1701, . . . , 170K that does not include the servers 1501, . . . , 150M, for example.
In another aspect of the example shown in
The server resources 185 can be configured to operate as one or more virtual servers 1951, . . . , 195M, for example. Server virtualization can simplify the interface between users and server resources, particularly when the server resources include multiple individual physical servers, processors, and operating systems. A server administrator can use a software application to divide one physical server into multiple, isolated virtual environments. The virtual environments can be referred to as virtual private servers, partitions, guests, instances, containers, or emulations. Server virtualization can be achieved by using a virtual machine model, a paravirtual machine model, or a virtualization at the operating system (OS) layer.
The virtual servers 1951, . . . , 195M, can be configured to perform operations and/or processes related to handling tracking information received from instances of widgets via the network B. In this regard, the virtual servers 1951, . . . , 195M can be organized in various configurations. For example, a first portion of the virtual servers 1951, . . . , 195M can be configured to perform a first portion of the handling of tracking information, a second portion of the virtual servers 1951, . . . , 195M can be configured to perform a second portion of the handling of tracking information, and a third portion of the virtual servers 1951, . . . , 195M can be configured to perform a third portion of the handling of tracking information. As described in
The tracked information or tracking information received at the data handling module 200 can be associated with multiple sessions, one session for each of the instances of widgets 245, 265, and 280 in the processing devices 230, 250, and 270, respectively. For example, an active or current session for the instance of widget 245 in the widget container 240 can include tracking information associated with the instance of widget 245. The current session for the instance of widget 245 can be identified using, for example, a widget identifier. The information collected and associated with the active session of the instance of widget 245 can include widget information, user information, session information, placement information, content information, information regarding the content aggregation point (e.g., webpage), information regarding the processor-readable vehicle (e.g., browser 235), and/or information associated with a processor in the processing device 230 (e.g., Intel processor). The information collected and associated with the active session for the instance of widget 245 can be associated with widget identifiers, user identifiers, session identifiers, placement identifiers, content identifiers, content aggregation point identifiers, and/or processor identifiers. The data handling module 200 can receive tracking information associated with the instance of widget 265 and with the instance of widget 280 by having corresponding active widget sessions.
An active session associated with an instance of a widget can remain active until, for example, a predetermined time is reached after a last occurrence of an activity associated with the instance of the widget. An activity timer can be used to determine when an instance of a widget has been inactive for longer than a predetermined threshold time. When the inactivity period is longer than that specified by the threshold time, the current session can become inactive (e.g., expire) or can be terminated. In some embodiments, a new session (e.g., a session with a different identifier) can be established when the activity associated with the instance of the widget later resumes, when the instance of the widget is abnormally terminated, when the instance of the widget is reloaded, or when a new instance of the widget is loaded. In some embodiments, when the widget is terminated, an indicator that the session has been terminated can be received at, for example, a server resource.
Other events that can trigger, cause, or result in the termination of an active widget session are, but need not be limited to, the closing of a content aggregation point into which the instance of the widget has been loaded, a predetermined time is reached (e.g., expired timer) after the instance of the widget is loaded into the content aggregation point, or a signal is sent from the widget container or kernel associated with the instance of the widget to terminate the session.
While the example shown in
As shown in
In one embodiment, the first stage of the data handling module 350, the receiving stage 310, can be performed by, for example, at least a portion of the servers 1001, . . . , 100N described in the system of
In some embodiments, the receiving stage 310, the processing stage 320, and the modifying stage 330 can be performed by a subset of the servers shown in, for example,
In the embodiments described above, the additional information 340 can be provided to each of the receiving stage 310, the processing stage 320, and/or the modifying stage 330 by storing the content or information in the data storage mediums 1201, . . . , 120P, 1651, . . . , 165R, and 1901, . . . , 190L, for example.
In some embodiments, the receiving stage 310, the processing stage 320, and the modifying stage 330 can be performed by virtual servers such as the virtual servers 1951, . . . , 195M configured within the server resources 185. In one example, the sharing module 300 can be performed by at least one separate server. In another example, at least a portion of the sharing module 300 can be performed by a subset of the virtual servers 1951, . . . , 195M. The additional information 340 can be provided to each of the receiving stage 310, the processing stage 320, and/or the modifying stage 330 by storing the content or information in the data storage mediums 1971, . . . , 197K, for example.
In some embodiments, the functions associated with the receiving stage 310, the functions associated with the processing stage 320, and/or the functions associated with the modifying stage 330 can be combined into one or more stages and/or separated into one or more stages within the data handling module 350 (or a separate module (not shown)). For example, some of the functions associated with the processing stage 320 can be included in and performed at the receiving stage 310 as pre-processing operations. In some embodiments, the functions associated with the modifying stage 330 can be included in and performed at the processing stage 320. In some embodiments, the functions associated with the processing stage 320 can be divided into several processing stages (not shown) that can execute in parallel and/or serially. Furthermore, the functions associated with each of the stages 310, 320, and 330 can be implemented at a single server or at multiple servers.
After operations have been performed at the processing stage 320, the processed data can be used at the modifying stage 330 to determine the manner in which behavior associated with currently distributed and/or subsequently distributed instances of widgets is to be modified. For example, the modifying stage 330 can be configured to use the processed data from the processing stage 320 to trigger a modification of a behavior or an update of a behavior associated with the widget 375 in the processing device 370. In other words, tracked information collected from a first instance of a widget being executed at a processing device can be used to modify a behavior of a second instance of the widget (the same widget) at a different processing device or the same processing device. In some embodiments, tracked information collected from an instance of a first widget being executed at a processing device can be used to modify a behavior of an instance of a second widget (a different widget) at a different processing device or the same processing device.
In some embodiments, an indicator or signal can be sent from the modifying stage 330 to, for example, processing device 370 to trigger a change in the widget 375 while the widget 375 is being executed/rendered at the processing device 370. In some embodiments, the indicator or signal can include information that is injected into the widget 375 and/or processing device 370 to trigger modification of a behavior associated with the widget 375.
In another example, the modifying information (produced at the modifying stage 330) can be communicated (e.g., sent, pushed) to the sharing module 300, which can then trigger (e.g., via an indicator/signal) a modification or an update of a behavior associated with an instance of widget 375 shared with the processing device 390.
In some embodiments, an indicator or a signal sent from the modifying stage 330 can be sent to a widget server (not shown). The indicator or signal can trigger (e.g., trigger via an instruction encoded within the indicator or signal) the behavior of the widget 375 to be modified at the widget server before the widget 375 is delivered to the processing device 390.
In some embodiments, data defined at the modifying stage 330 based on tracking information processed at the processing stage 320 can be sent to, for example, processing device 370. The data defined at the modifying stage 330 can be used to by the processing device to implementation a behavior modification of the widget 375. In other words, the widget 375 can invoke a function based on the data received from the modifying stage 330 to implement a behavior modification.
Modifying the behavior associated with instances of widgets can include, but need not be limited to, modifying the content, usage or placement characteristics, and/or operation of associated widget containers or kernels. Behavior modification can also include performance optimization of specified characteristics associated with specified widget instances (e.g., targeted advertisement based on usage). Moreover, the shared instance of widget 375 at processing device 390 can be configured to send (e.g., communicate) tracking information to the receiving stage 310 of the data handling module 350. In this regard, tracking information can be continuously received and processed (at specified time intervals and/or randomly), which can result in a continuous update or modification of behavior associated with instances of widgets at other processing devices (e.g., processing device 370). In some embodiments, the data handling module 350 can be configured to pull the tracking information from widgets (e.g., via a tracking information request).
In some embodiments, an indicator or signal can be sent from the modifying stage 330 to, for example, a widget server (not shown) to trigger the widget server to send a different widget (not shown) to processing device 370 than widget 375. In some embodiments, the widget server can be configured with intelligence to serve a particular widget based on the indicator or signal defined by the modifying stage 330. The different widget can be selected based on the tracking information as it is processed by the data handling module 350. In other words, a different widget can be delivered into the processing device 370 based on the analysis at the data handling module 350 of the tracking information. In some embodiments, the indicator or signal can be a reference to a widget that is different than widget 375, in which case a different widget would be request by, sent to, and executed by processing device 370.
In some embodiments, a widget that is an advertisement or contains an advertisement can be dynamically modified. In other words, the behavior of the widget/advertisement can be dynamically modified. A shared instance of an advertisement can be dynamically modified, for example, from an advertisement with a white vehicle model to an advertisement with a blue vehicle model. This behavior modification can be triggered while the advertisement is currently being displayed. Another example can be to change the content of a video player widget with a video that corresponds to the demographics of the viewer and/or user (e.g., update music videos to those appropriate to the viewer's demographics). In yet another example, an instance of a different widget can be shared and loaded onto the same content aggregation point of an already distributed/displayed instance of a widget based on correlations between the two widgets that resulted from the processing of tracking information (e.g., a video player playing a basketball game highlight added to same webpage having a widget displaying the basketball league's current standings). The modification can occur before the instance of the widget is loaded, at the time the instance of the widget is loaded, when the instance of the widget is rendered, at the request of the instance of the widget, or dynamically after the instance of the widget is loaded.
In this example, the behavior modification may not result in modifications to the behavior associated with the instance of widget 376 at the processing device 380. The behavior of the current instance of widget 375 at the processing device 380 and of the shared instance of widget 375 at the processing device 390, however, can be modified as a result of the processing performed at the data handling module 350.
In this example, after processing of received tracking information, the modifying stage 330 can update a behavior associated with the current instance of the widget 375 in the processing device 330. The behavior associated with the current instance of the widget 375 can be modified at the request of the instance of the widget or dynamically after the instance of the widget is loaded. The sharing module 300 can be configured to trigger sharing of an instance of a widget 395 to the processing device 380 and an instance of the widget 375 with the processing device 390. The behavior associated with shared instances of widgets 395 and 375 can be modified at various times. For example, the behavior associated with the shared instances of widgets 395 and 275 can be modified before the instance of the widget is loaded, at the time the instance of the widget is loaded, when the instance of the widget is rendered, at the request of the instance of the widget, or dynamically after the instance of the widget is loaded. Moreover, once distributed, the shared instances of widgets 395 and 375 can communicate tracking information to the receiving stage 310 of the data handling module 350.
The tracking information used to determine whether a particular widget should be sent to a processing device 390 for execution can vary. For example, in some embodiments, tracking information associated with a specific user (e.g., related to a particular user-profile) can be used to determine that a specific widget (e.g., a specific advertisement-related widget) should be delivered to a content aggregation point accessed by the specific user. The tracking information associated with the specific user can be associated with multiple instances of widgets that may be related to the content aggregation point and/or different content aggregation points. In other words, the tracking information can be collected from instances of widgets virally spread from various other content aggregation points unrelated to the content aggregation point currently being accessed by the specific user. The determination (e.g., recommendation) that the specific widget should be delivered to a content aggregation point can be performed (e.g., using the stages in the data handling module 350) in response to an indicator that the specific user has accessed the content aggregation point. The specific widget can be delivered to a location on the content aggregation point reserved for execution (e.g., display) of the widget. In some embodiments, the specific widget can be delivered to the location on the content aggregation point in lieu of a default widget.
Although not shown in
While the examples described in
For example, tracking information associated with a first widget at a first processing device and a second widget at a second processing device can be used to modify a behavior of a third widget at a third processing device. In some embodiments, the first widget and the second widget can be different instances of the same widget virally spread from a widget at a content aggregation point. In some embodiments, the first and second widget can be different widgets of, for example, the same type (e.g., both car advertisements). In some embodiments, the third widget can be a widget virally spread from the first widget or the second widget. In some embodiments, the third widget can be a widget of the same type as the first widget and/or the second widget (e.g., all sports-related widgets). In some embodiments, the third widget may have been sent to its respective processing device before the first widget and/or the second widget have been created and/or executed (e.g., rendered, displayed).
The receiving stage 400 can be configured to receive tracking information from multiple instances of widgets, such as those described in connection with
Also shown in
The processing stage 440 can include, but need not be limited to, an analysis process 450, a coalesce process 452, a queue process 454, a filter process 456, a sort process 458, a store process 460, an authenticate process 462, and a reporting process 464. Each of the processes in the processing stage 440 can correspond to, for example, a software-based and/or hardware-based module.
The modifying stage 470 can include, but need not be limited to, a determine process 480, a coalesce process 482, a queue process 484, a filter process 486, a sort process 488, a store process 490, and an authenticate process 492. Each of the processes in the modifying stage 470 can correspond to, for example, a software-based and/or hardware-based module. In some embodiments, one or more of the processes of the receiving stage 400, the processing stage 440, and the modifying stage 470 can be performed by a one or more software-based and/or hardware-based modules.
The processes in each of the receiving stage 400, the processing stage 440, and the modifying stage 470 can operate on information based on, for example, one or more identifiers. For example, widget identifiers, user identifiers, placement identifiers, content identifiers, session identifiers, processor identifiers, and/or content aggregation point identifiers, can be used to perform the processes in the various stages of the data handling module.
At the receiving stage 400, the authenticate process 422 can be configured to validate a session associated with an instance of a widget. The receive process 410 can be configured to receive tracking information from multiple instances of widgets. The receive process 410 can receive, for example, packets that can contain a header (e.g., routing information) and a payload (e.g., tracking information). The receive process 410 can be configured to remove the header and pre-process the tracking information in the payload of the packet. The coalesce process 412 can be configured to collect and/or combine tracking information associated with a session of an instance of a widget. In this regard, tracking information obtained from received packets and associated with one or more identifiers related to the instance of a widget can be coalesced into a single packet, for example. The single coalesced packet can be completed and can be ready for further processing after the session associated with the instance of the widget terminates.
The queue process 414 can be configured to queue received tracking information (e.g., packets) in a manner that results in an effective processing of the received information. The filtering process 416 can be configured to filter, augment, or remove specified received information. For example, the filtering process 416 can be used to allow valid information to proceed for further processing. The filtering process 416 can remove from further processing any received information that is not from a valid source, information that itself is not valid (e.g., fraudulent information), or information that is received from an invalid session, for example. In this regard, the filtering process 416 can use information received from, for example, the third-party data 401. In some embodiments, the filter process 416 can augment, for example, tracking information. For example, tracking information received at the filter process 416 can be augmented by combining several categories of the tracking information into new tracking information.
The sort process 418 can be configured to sort received information according to one or more identifiers. For example, the sort process 418 can be used to map the tracking information associated with an instance of a widget to a computing entity (e.g., a server). In some embodiments, the tracking information can be sent to the computing entity based on the mapping. The sorting can be based on a widget identifier (e.g., server X processes information associated with widget Y), but can also be based on other identifiers such as, for example, content identifiers (e.g., server X processes information associated with video content). The store process 420 can be configured to store tracking information before any pre-processing, during pre-processing, and/or after pre-processing. In some embodiments, the store process 420 can be configured to store tracking information in any of multiple types of data structures.
The coalesce processes 452 and 482 can be substantially similar in operation to the coalesce process 412 but are configured to operate at the processing stage 440 and the modifying stage 470, respectively. Similarly, other processes at the processing stage 440 and the modifying stage 470, such as the queue processes 454 and 484, the filter processes 456 and 486, the sort processes 458 and 488, the store processes 460 and 490, and the authenticate processes 462 and 492 can be substantially similar in operation to their corresponding processes in the receiving stage 400.
In the processing stage 440, the analysis process 450 can be configured to determine historical trends, projections, correlations, and/or statistical calculations related to instances of widgets by processing (e.g., using statistical algorithms) the tracked information received. The reporting process 464 can be configured to collect at least a portion of the processed information, including some of the determined trends, projections, and/or correlations, for example, and present them in an organized manner. In this regard, multiple reports can be generated from the same processed information based on the reporting parameters being considered. The reporting parameters can include, for example, time parameters, user profile parameters, widget-related parameters (e.g., widget identifier, widget type indicator), destination parameters (e.g., destination address), and so forth.
At the modifying stage 470, the determine process 480 can be configured to further process the results or output produced by the processing stage 440. The determine process 480 can be configured to determine or establish whether a behavior(s) associated with currently distributed and/or subsequently shared instances of a widget(s) is to be modified and/or the manner by which the modification is to occur. In some embodiments, the determine process 480 can be configured to modify or update a behavior associated with an instance of a widget, can communicate with a sharing module (e.g., a sharing server) configured to modify or update instances of widgets, and/or can communicate with a separate and distinct modification process or operation (e.g., a separate server) configured to modify instances of widgets.
In another example,
In another example,
In another example,
Other hierarchical data structures can also be implemented for efficient handling of tracking information. Such additional hierarchical data structures can include session-based data structures, placement-based data structures, and/or content-aggregation-point-based data structures, for example. The hierarchical data structures can be combined and/or divided to create different hierarchical data structure categories that can be used to process (e.g., parse) tracking information. For example, the user-based data structure 503 shown in
At 630, the sorted data can be stored in one or many data structures, such as the hierarchical data structures described in
At 730, the pre-processed tracking information can be further processed by, for example, the processing stage 440 described in
At 740, the processed tracking information can be analyzed by, for example, the analysis process 450 in the processing stage 440. The analysis process 450 can include determining, for example, historical trends, projections, correlations, and/or statistical calculations related to the instances of widgets being tracked.
At 750, before end at 760, the analyzed information can be used by, for example, the modify process 480 in the modifying stage 470, to determine whether to modify the behavior associated with instances of widgets and/or modify the behaviors associated with instances of widgets. The modification can include determining changes to the behavior associated with instances of widgets and/or their associated widget containers or kernels. The modifying stage 470 can be configured to use third-party data in its determinations. Moreover, the determinations that result at 750 can be communicated to a sharing module (e.g., a sharing server) configured to modify the behavior associated with shared instances of widgets and/or their corresponding widget containers or kernels.
The widget-sharing host 800 is configured to send and/or receive signals (e.g., instructions, data) to facilitate sharing of the widget 826. In this embodiment, the widget-sharing host 800 is configured facilitate sharing of widget 826 (e.g., instance of widget 826) from content aggregation point 842 of network entity 840 to content aggregation point 852 of network entity 850, and from content aggregation point 852 of network entity 850 to content aggregation point 862 of network entity 860, in that order.
Instances of the widget 826 are served to each of the content aggregation points 842, 852, and 862 from a widget server 810 separate from the widget-sharing host 800. Because sharing of the widget 826 is triggered through the widget-sharing host 800, the widget 826 (e.g., instances of the widget 826) can be shared without direct communication between the network entities 840, 850, and/or 860 (and/or content aggregation points 842, 852, and/or 862). Signals related to sharing of the widget 826 from content aggregation point 842 to content aggregation point 852, and from content aggregation point 852 to content aggregation point 862 are shown, in order, as lines 1 through 9.
As shown in
In some embodiments, a portion of the widget 826 can be executed (e.g., displayed) at the content aggregation point 842 of network entity 840 before the sharing signal (line 2) is sent from the network entity 840. In some embodiments, a sharing signal can be sent before the widget 826 is received (e.g., after widget precursor received). In some embodiments, the sharing signal can originate at the network entity 840 (e.g., at content aggregation point 842 of network entity 840) and/or can be triggered by the network entity 840 any time before, after, or during execution of widget 826.
In response to the sharing signal (line 2), the widget-sharing host 800 is configured to send a widget precursor (line 3) to the content aggregation point 852 of network entity 850. The widget precursor can include one or more references that can be accessed at network entity 850 and/or used by network entity 850 to request an instance of the widget 826 from widget server 810 (line 4). An instance of the widget 826 can be sent to the content aggregation point 852 of network entity 850 from the widget server 810 (line 5) in response to the request (line 4).
In some embodiments, the widget precursor can include an instruction and/or can be a message including one or more references (e.g., a widget reference, a widget-container reference). In some embodiments, a widget precursor can include a reference to another widget precursor. In some embodiments, the widget precursor can be a widget container that includes a reference to the widget 826 or a webpage (or other type of vehicle) that includes a reference to the widget 826. The widget 826 can be “contained” in a widget container when a widget and/or service module is either referenced in the widget container or integrated into the procedural software framework of the widget container. When being contained in the widget container, the widget 826 can be referred to as being wrapped or containerized in the widget container. As a procedural software framework, the widget container can be a series of instructions that are executable or interpretable by, for example, a computer processor. In some embodiments, the widget 826 can be executed within the widget container after the widget container is received at and executed within, for example, content aggregation point 852. More details related to widget-container hosting and generation are set forth in co-pending application Ser. No. 11/537,362, “Method and Apparatus for Widget-Container Hosting and Generation,” which is incorporated herein by reference in its entirety.
In some embodiments, a widget identifier, a capability indicator, and/or a user preference that can be used by the widget-sharing host 800 to define the widget precursor (line 3). In other words, the widget precursor can be dynamically defined based on the widget identifier, the capability indicator, and/or the user preference. For example, a widget identifier and/or user preference associated with widget 826 and included in the sharing signal (line 2) can be used by the widget-sharing host 800 to define the widget precursor (line 3). The widget identifier and/or user preference associated with widget 826 can be used to define a reference and/or instruction in the widget precursor (line 3) sent to the network entity 850 so that network entity 850 can request an instance of widget 826 having a particular configuration. In some embodiments, a capability indicator and/or user preference received at the widget-sharing host 800 from network entity 850 (the destination network entity) can be used to define the widget precursor (line 3).
In some embodiments, a placement identifier can be defined at the widget-sharing host and associated with an instance of the widget 826 being placed at the content aggregation point 852 of network entity 850. The widget 826 is placed at the content aggregation point 852 when a reference to the widget 826 (or a reference to a widget container that contains the widget) is, for example, associated with the content aggregation point 852. In some embodiments, the placement identifier can be defined in response to the sharing signal (line 2). In some embodiments, when the instance of the widget 826 is, for example, executed within the content aggregation point 852 and/or otherwise associated with the content aggregation point 852, a placement identifier can be defined and stored at the widget-container host 800. In some embodiments, the placement identifier can be stored at the network entity 850.
The placement identifier included in the sharing signal can be used to create parentage associated with the widget 826. For example, part of the parentage of widget 826 can be defined by associating the placement identifier associated with placement of the widget 826 at the content aggregation point 842 of network entity 840 with a placement identifier of a placement of the widget 826 at the content aggregation point 852 of network entity 850. In other words, the placement identifier can be used to determine parentage of the widget 826 as it is shared between the network entities. More details related to placement identifiers and widget parentage are set forth in co-pending application Ser. No. 11/537,375, “Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation,” which is incorporated herein by reference in its entirety.
After at least a portion of an instance of the widget 826 is received at the content aggregation point 852 of network entity 850 (line 5), sharing of an instance of the widget 826 with the content aggregation point 862 of network entity 860 can be triggered at network entity 850 and performed using the same method described above. In other words, the widget 826 can be subsequently shared after at least a portion of the widget 826 has been received at the network entity 850. A sharing signal (line 6) can be defined at network entity 850 and sent to the widget-sharing host 800. In response to the sharing signal (line 6), the widget-sharing host 800 can send a widget precursor (line 7) to the content aggregation point 862 of network entity 860. The information and/or instructions included in the widget precursor (line 7) can be used to request (line 8) an instance of widget 826. In response to the request, widget server 810 can send the instance of widget 826 for execution within the content aggregation point 862 of network entity 860.
In some embodiments, a widget container that is served as a widget precursor can contain one or more service modules. For example, a widget container that is served to, for example, network entity 850 as a widget precursor (line 3) that includes a reference to widget 826 can contain one or more service modules. In some embodiments, the service module included in the widget container can be a pre-defined function. For example, the service module can be a metadata searching/retrieval module, a polling/categorizing module, a widget container deployment module (e.g., using a placement service module), a transaction service module (e.g., service module for facilitating a web purchase, service module used for signing a user up for a web service, etc.), a security module (e.g., security firewall module), and/or a widget container tracking module. The service module can also be a referral service module (e.g., a service used to refer a viewer to a widget container), an advertisement service module (e.g., a service module that includes an advertisement), or a directory service module (e.g., a service module used for searching in a directory).
After the widget 826 has been placed at (e.g., linked at) a content aggregation point, such as content aggregation point 842, the widget 826 can be executed at the content aggregation point 842 when requested. For example, in response to an instruction included in a widget precursor, such as the widget precursor shown at line 7, a reference to the widget 826 can be included in the content aggregation point 826 and configured so that the widget is requested when the reference is accessed. In some embodiments, the widget-container is a portable framework that can be referenced in (e.g., embedded in, referenced using an embed or object tag) and/or accessed from/using a content aggregation point (e.g., web-page, mobile content vehicle).
In some embodiments, a reference to widget 826 can be included in a widget container that has been placed at the content aggregation point (e.g., a reference to the widget container included at the content aggregation point). The widget container can include one or more service modules including, for example, a sharing service module that can be used to share the widget 826. In some embodiments, the widget container and widget 826 can be served from separate entities. For example, the widget container can be served from widget-sharing host 800 when requested at, for example, network entity 850, and widget 826 can be served from the widget server 810 after a reference to the widget 826 has been accessed at the widget container. In some embodiments, the content aggregation point 852, such as a webpage, can be served from yet a different entity. In some embodiments, the widget container can be dynamically served and modified based on metadata associated with the widget 826 and/or widget container. In some embodiments, a widget 826 that is not contained in a widget container can be configured to invoke various functions associated with service modules, such as those listed above, via an API.
In some embodiments the widget-sharing host 800 can be configured to control the sharing (e.g., distribution) of widgets based on a content rules. More details related to the control of widget sharing based on content rules are set forth in co-pending application Ser. No. 11/682,639, “Method and Apparatus for Widget and Widget-Container Distribution Control Based on Content Rules,” which is incorporated herein by reference in its entirety.
In some embodiments, the widget-sharing host 800 is not in communication with, for example, network entity 850 during a time period between sending of the widget precursor (line 3) and receipt of the sharing signal (line 6). In some embodiments, during this time period only tracking data associated with the widget 826 is transmitted from the network entity 850. In some embodiments, during this time period only data related to a service module (not shown) associated with the widget 826 is transmitted from the network entity 850. In some embodiments, the functionality of the widget-sharing host 800 can be included in (e.g., distributed within) a set of widget-sharing host 800.
As shown in
After at least a portion of the widget instance has been received at 900, a share module associated with the widget is executed at 910. The share module can be a share module included in a widget container containing the widget. In some embodiments, a function associated with the share module can be invoked via an API associated with the share module. In some embodiments, the share module can be included in a content aggregation point (e.g., webpage) or a mobile content vehicle (e.g., a WAP page).
A widget identifier associated with the widget is obtained and sent to a widget-sharing host in a sharing signal at 920. The widget identifier can be obtained using the share module and sent to the widget-sharing host in a sharing signal defined using the share module. In some embodiments, the widget identifier can be associated with a set of widgets that includes more than one configuration (e.g., formats, protocols) of a single widget. One or more configurations of the single widget from the set of widgets can be associated with a platform of a network entity. For example, a first widget can have a configuration that is compatible with a particular platform of a mobile phone and a second widget can have a configuration that is compatible with a different platform. The first widget and the second widget can be associated with a single widget identifier because the first widget and the second widget have substantially the same content despite having different configurations.
In some embodiments, the sharing signal can be generated by a sharing module associated with the widget. In some embodiments, the sharing module can be referred to as a placement module. For example, the sharing module can be included in (e.g., integrated within) a widget container containing the widget. In some embodiments, the sharing signal can be defined based on a sharing module included in the content aggregation point or trigger via a link included in a content aggregation point.
In some embodiments, the sharing signal can include an indicator of a sharing target such as a particular content aggregation point or destination network entity. In some embodiments, the sharing target can be an address associated with a content aggregation point or an address associated with an entity such as a destination network entity. In some embodiments, the sharing target can be, for example, a telephone number associated with a mobile device, a handle associated with a user of a service, or a username.
A placement identifier for association with a placement of the widget at a destination content aggregation point of a destination network entity is defined at 930. The placement identifier can be defined at the widget-container host and can be, for example, a globally unique identifier. In some embodiments, the placement identifier associated with placement of the widget at the destination content aggregation point can be associated with a placement identifier of placement of the widget at the source content aggregation point to define parentage of the widget. In some embodiments, the placement identifier can be defined at, for example, a share module rather than at the widget-sharing host.
In some embodiments, the sharing signal can include other information in addition to that described above. For example, the sharing signal can include metadata associated with a widget (e.g., user preferences). The metadata can be defined at a source network entity.
A first widget precursor can be defined and sent to the destination network entity at 940. In some embodiments, the first widget precursor can be defined at and sent from the widget-sharing host. In some embodiments, a link associated with the first widget precursor can be aliased at, for example, a domain name service (DNS) server. For example, if the first widget precursor is an SMS message, a link associated with the SMS message can be aliased at, for example, a domain name service (DNS) server. In some embodiments, the widget-sharing host can be configured to trigger a separate network entity to define and send the first widget precursor to the destination network entity. In some embodiments, the proxy device can be configured to modify any portion of the SMS message (e.g., text portion, link within the SMS message).
In some embodiments, the first widget precursor can include the placement identifier and the widget identifier. If the destination network entity is a handheld mobile device, the first widget precursor can be a text-based message such as short message service (SMS) message that includes the placement identifier and the widget identifier. In some embodiments, the widget-sharing host can trigger an SMS proxy device to define and send the SMS message to the destination network entity. In some embodiments, a widget precursor sent to a handheld mobile device can be referred to as a mobile widget precursor.
A user preference and/or a capability indicator is received from the destination content aggregation point in response to the first widget precursor at 950. The capability indicator can be an indicator of a capability associated with the destination content aggregation point and/or the destination network entity. In some embodiments, the capability indicator can be an indicator of the platform of and/or resources available at the destination network entity. In some embodiments, the capability indicator can be, for example, an indicator of a capability of an application configured to process a widget and/or a widget-container associated with the widget. The application can be, for example, a web browser or a mobile content processing application (e.g., WAP browser). In some embodiments, a user preference can be received from the source network entity, in, for example, a sharing signal.
A second widget precursor that is associated with a widget reference is determined and sent based on the capability indicator, the user preference, and/or the widget identifier at 960. For example, a widget reference to a widget that is compatible with a particular destination content aggregation point and/or destination network entity can be determined based on the capability indicator, user preference, and/or the widget identifier. In some embodiments, a link associated with the second widget precursor can be aliased at, for example, a domain name service (DNS) server. In some embodiments, a service module associated with the widget can be selected based on the capability indicator, user preference, and/or the widget identifier.
In some embodiments, the second widget precursor can be, for example, a widget container, a webpage, and/or a WAP page that includes the widget reference. In some embodiments, the second widget precursor can be a reference to a different widget precursor (e.g., a reference to a widget container that includes a link to the widget).
If the second widget precursor is, for example, a WAP page or a webpage, the widget reference can be included in the WAP page or the webpage as a link. In some embodiments, the widget reference can be configured such that the widget reference (e.g., link) can be accessed in response to a user-triggered interaction with the widget reference at the destination network entity.
If the second widget precursor is a widget container (or a reference to a widget container), the widget reference can be contained (e.g., integrated into) in the widget container or included in the widget container as a link that can be accessed in response to a use-triggered interaction at the destination network entity. In some embodiments, the link can be dynamically included in the widget container when the widget container is generated in response to a reference to the widget being accessed from a content aggregation point. In some embodiments, the widget-sharing host can trigger a determination of and/or sending of the second widget precursor.
The widget reference associated with the second widget precursor is accessed at the destination content aggregation point at 970. When the widget reference is accessed, a request for an instance of the widget can be sent to a widget server. In some embodiments, the widget reference can be configured so that the widget reference is automatically accessed at the destination content aggregation point. For example, the widget reference can be included within a portion of software associated with the second widget precursor. When the software of the second widget precursor is executed, the widget reference can be accessed. In some embodiments, if the second widget precursor is a reference to, for example, a widget container that includes the widget reference, the widget container can be requested/received first and the widget reference can subsequently be accessed from the widget container.
An instance of the widget is received at the destination network entity at 980 in response to the widget reference being accessed at 970. The instance of the widget can be sent from a widget server in response to a request received from the destination network entity. The instance of the widget can be receive at the destination content aggregation point.
At least a portion of the widget is executed at the destination content aggregation point of the destination network entity at 990. For example, in some embodiments, the widget can be displayed at the destination content aggregation point. The portion of the widget can be executed in response to a user-triggered interaction.
In some embodiments, an instance of the widget can be shared with a different content aggregation point. For example, as shown in
In some embodiments, only one widget precursor can be sent rather than two widget precursors. For example, if it is determined based on a sharing signal that the destination network entity is a particular type of device (e.g., determine that destination network entity is a mobile phone because sharing signal indicates destination based on a phone number). In this scenario, a single widget precursor that is a mobile content vehicle that includes a reference to a widget can be sent to the destination network entity. In some embodiments, if the widget precursor is a widget (e.g., WAP page), the widget precursor can be sent without additional linking to a second widget precursor or an additional widget.
In some embodiments, the steps described in
While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. For example, the module for handling tracking information from multiple instances of widgets described herein can include various combinations and/or sub-combinations of the components and/or features of the different embodiments described. Although described with reference to use with multiple physical or virtual servers, it should be understood that the method for handling tracking information associated with instances of widgets can be used with other computing devices or computing entities. Embodiments of the module for handling tracking information can also include processes different from those described herein. For example, the module for handling tracking information can be configured to collect, process, analyze, modify, and/or organize third-party data before use.
Some embodiments include a processor and a related processor-readable medium having instructions or computer code thereon for performing various processor-implemented operations. Such processors can be implemented as hardware modules such as embedded microprocessors, microprocessors as part of a computer system, Application-Specific Integrated Circuits (“ASICs”), and Programmable Logic Devices (“PLDs”). Such processors can also be implemented as one or more software modules in programming languages as Java, C++, C, assembly, a hardware description language, or any other suitable programming language.
A processor according to some embodiments includes media and computer code (also can be referred to as code) specially designed and constructed for the specific purpose or purposes. Examples of processor-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs (“CD/DVDs”), Compact Disc-Read Only Memories (“CD-ROMs”), and holographic devices; magneto-optical storage media such as optical disks, and read-only memory (“ROM”) and random-access memory (“RAM”) devices. Examples of computer code include, but are not limited to, micro-code or micro-instructions, machine instructions, such as produced by a compiler, and files containing higher-level instructions that are executed by a computer using an interpreter. For example, an embodiment may be implemented using Java, C++, or other object-oriented programming language and development tools. Additional examples of computer code include, but are not limited to, control signals, encrypted code, and compressed code.
This application claims priority to the commonly owned U.S. Provisional Application Ser. No. 60/893,330, entitled “Method and Apparatus for Data Processing,” filed Mar. 6, 2007, and U.S. Provisional Application Ser. No. 60/977,544, entitled “Methods and Apparatus for Widget Sharing Between Content Aggregation Points,” filed Oct. 4, 2007, both of which are incorporated herein by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
5230072 | Smith et al. | Jul 1993 | A |
5261002 | Perlman et al. | Nov 1993 | A |
5675510 | Coffey et al. | Oct 1997 | A |
5781189 | Holleran et al. | Jul 1998 | A |
5796952 | Davis et al. | Aug 1998 | A |
5857102 | McChesney et al. | Jan 1999 | A |
5892900 | Ginter et al. | Apr 1999 | A |
5896532 | Blewett | Apr 1999 | A |
5951643 | Shelton et al. | Sep 1999 | A |
6064980 | Jacobi et al. | May 2000 | A |
6100890 | Bates et al. | Aug 2000 | A |
6108637 | Blumenau | Aug 2000 | A |
6112238 | Boyd et al. | Aug 2000 | A |
6125388 | Reisman | Sep 2000 | A |
6233601 | Walsh | May 2001 | B1 |
6233684 | Stefik et al. | May 2001 | B1 |
6236971 | Stefik et al. | May 2001 | B1 |
6266649 | Linden et al. | Jul 2001 | B1 |
6269361 | Davis et al. | Jul 2001 | B1 |
6311194 | Sheth et al. | Oct 2001 | B1 |
6314448 | Conner et al. | Nov 2001 | B1 |
6317787 | Boyd et al. | Nov 2001 | B1 |
6360261 | Boyd et al. | Mar 2002 | B1 |
6374252 | Altoff et al. | Apr 2002 | B1 |
6466974 | Nelson et al. | Oct 2002 | B1 |
6546393 | Khan | Apr 2003 | B1 |
6658568 | Ginter et al. | Dec 2003 | B1 |
6665867 | Ims et al. | Dec 2003 | B1 |
6701521 | McLlroy et al. | Mar 2004 | B1 |
6748555 | Teegan et al. | Jun 2004 | B1 |
6772180 | Li et al. | Aug 2004 | B1 |
6810356 | Garcia-Franco et al. | Oct 2004 | B1 |
6857124 | Doyle | Feb 2005 | B1 |
6970853 | Schutzer | Nov 2005 | B2 |
6985905 | Prompt et al. | Jan 2006 | B2 |
6985929 | Wilson et al. | Jan 2006 | B1 |
6986049 | Delany | Jan 2006 | B2 |
7003522 | Reynar et al. | Feb 2006 | B1 |
7003565 | Hind et al. | Feb 2006 | B2 |
7016960 | Howard et al. | Mar 2006 | B2 |
7024392 | Stefik et al. | Apr 2006 | B2 |
7031932 | Lipsky et al. | Apr 2006 | B1 |
7035943 | Yamane et al. | Apr 2006 | B2 |
7039599 | Merriman et al. | May 2006 | B2 |
7046995 | Rygaard | May 2006 | B2 |
7054900 | Goldston | May 2006 | B1 |
7062500 | Hall et al. | Jun 2006 | B1 |
7062540 | Reddy et al. | Jun 2006 | B2 |
7062561 | Reisman | Jun 2006 | B1 |
7072672 | Vanska et al. | Jul 2006 | B1 |
7076521 | Davison | Jul 2006 | B2 |
7080159 | Chu et al. | Jul 2006 | B2 |
7085682 | Heller et al. | Aug 2006 | B1 |
7089237 | Turnbull et al. | Aug 2006 | B2 |
7099926 | Ims et al. | Aug 2006 | B1 |
7100054 | Wenisch et al. | Aug 2006 | B2 |
7103912 | Xia et al. | Sep 2006 | B2 |
7117250 | Wu | Oct 2006 | B1 |
7117535 | Wecker | Oct 2006 | B1 |
7130964 | Ims et al. | Oct 2006 | B2 |
7133846 | Ginter et al. | Nov 2006 | B1 |
7159116 | Moskowitz | Jan 2007 | B2 |
7263551 | Belfiore et al. | Aug 2007 | B2 |
7346909 | Eldar et al. | Mar 2008 | B1 |
7392395 | Ginter et al. | Jun 2008 | B2 |
7392483 | Wong et al. | Jun 2008 | B2 |
7702675 | Khosla et al. | Apr 2010 | B1 |
7730082 | Sah et al. | Jun 2010 | B2 |
7735117 | Nadalin et al. | Jun 2010 | B2 |
20020040314 | Tolson | Apr 2002 | A1 |
20020040394 | Shapira | Apr 2002 | A1 |
20020072965 | Merriman et al. | Jun 2002 | A1 |
20020082914 | Beyda et al. | Jun 2002 | A1 |
20020082923 | Merriman et al. | Jun 2002 | A1 |
20020082997 | Kobata et al. | Jun 2002 | A1 |
20020083188 | Hericy et al. | Jun 2002 | A1 |
20020095336 | Trifon et al. | Jul 2002 | A1 |
20020099600 | Merriman et al. | Jul 2002 | A1 |
20020120673 | Tolson et al. | Aug 2002 | A1 |
20020129092 | Tolson et al. | Sep 2002 | A1 |
20020174200 | Kozina | Nov 2002 | A1 |
20030014483 | Stevenson et al. | Jan 2003 | A1 |
20030028433 | Merriman et al. | Feb 2003 | A1 |
20030033403 | Rhodes | Feb 2003 | A1 |
20030058277 | Bowman-Amuah | Mar 2003 | A1 |
20030070061 | Wong et al. | Apr 2003 | A1 |
20030105882 | Ali et al. | Jun 2003 | A1 |
20030196121 | Raley et al. | Oct 2003 | A1 |
20030200145 | Krassner et al. | Oct 2003 | A1 |
20040073755 | Webb et al. | Apr 2004 | A1 |
20040098349 | Tolson | May 2004 | A1 |
20040107125 | Guheen et al. | Jun 2004 | A1 |
20040143667 | Jerome | Jul 2004 | A1 |
20040153973 | Horwitz | Aug 2004 | A1 |
20040165007 | Shafron | Aug 2004 | A1 |
20040172324 | Merriman et al. | Sep 2004 | A1 |
20040172331 | Merriman et al. | Sep 2004 | A1 |
20040172332 | Merriman et al. | Sep 2004 | A1 |
20040215509 | Perry | Oct 2004 | A1 |
20040215515 | Perry | Oct 2004 | A1 |
20040215709 | Basani et al. | Oct 2004 | A1 |
20040225562 | Turner | Nov 2004 | A1 |
20040225566 | Beyda et al. | Nov 2004 | A1 |
20040225668 | Teegan et al. | Nov 2004 | A1 |
20050021611 | Knapp et al. | Jan 2005 | A1 |
20050038702 | Merriman et al. | Feb 2005 | A1 |
20050050301 | Whittle et al. | Mar 2005 | A1 |
20050055458 | Mohan et al. | Mar 2005 | A1 |
20050086587 | Balz | Apr 2005 | A1 |
20050114774 | Berryman | May 2005 | A1 |
20050125528 | Burke, II et al. | Jun 2005 | A1 |
20050190994 | Yamanaka | Sep 2005 | A1 |
20050197991 | Wray et al. | Sep 2005 | A1 |
20050198105 | Schmitz et al. | Sep 2005 | A1 |
20050198201 | Bohn et al. | Sep 2005 | A1 |
20050210000 | Michard | Sep 2005 | A1 |
20050246262 | Aggarwal et al. | Nov 2005 | A1 |
20050251805 | Bamba et al. | Nov 2005 | A1 |
20050256819 | Tibbs et al. | Nov 2005 | A1 |
20050256954 | Shapira et al. | Nov 2005 | A1 |
20060004703 | Spivack et al. | Jan 2006 | A1 |
20060015406 | Beyda et al. | Jan 2006 | A1 |
20060088044 | Hammerl | Apr 2006 | A1 |
20060089880 | Merriman et al. | Apr 2006 | A1 |
20060106876 | MacGregor | May 2006 | A1 |
20060112102 | Shafron | May 2006 | A1 |
20060112341 | Shafron | May 2006 | A1 |
20060129937 | Shafron | Jun 2006 | A1 |
20060136843 | Shafron | Jun 2006 | A1 |
20060161513 | Drumm et al. | Jul 2006 | A1 |
20060178918 | Mikurak | Aug 2006 | A1 |
20060190290 | Gomez | Aug 2006 | A1 |
20060212589 | Hayer et al. | Sep 2006 | A1 |
20060218036 | King et al. | Sep 2006 | A1 |
20060242379 | Korgaonkar et al. | Oct 2006 | A1 |
20060259462 | Timmons | Nov 2006 | A1 |
20060277457 | Salkind et al. | Dec 2006 | A1 |
20070038934 | Fellman | Feb 2007 | A1 |
20070078777 | Demartini et al. | Apr 2007 | A1 |
20070078953 | Chai et al. | Apr 2007 | A1 |
20070101146 | Louch et al. | May 2007 | A1 |
20070101291 | Forstall et al. | May 2007 | A1 |
20070101297 | Forstall et al. | May 2007 | A1 |
20070106759 | Willie et al. | May 2007 | A1 |
20070112676 | Konito et al. | May 2007 | A1 |
20070130541 | Louch et al. | Jun 2007 | A1 |
20070192329 | Croft et al. | Aug 2007 | A1 |
20070192339 | Baker et al. | Aug 2007 | A1 |
20070209013 | Ramsey et al. | Sep 2007 | A1 |
20070250618 | Hammond | Oct 2007 | A1 |
20070266093 | Forstall et al. | Nov 2007 | A1 |
20070288518 | Crigler et al. | Dec 2007 | A1 |
20070288858 | Pereira et al. | Dec 2007 | A1 |
20080010133 | Pyhalammi et al. | Jan 2008 | A1 |
20080010319 | Vonarburg et al. | Jan 2008 | A1 |
20080028294 | Sell et al. | Jan 2008 | A1 |
20080034040 | Wherry et al. | Feb 2008 | A1 |
20080034314 | Louch et al. | Feb 2008 | A1 |
20080040426 | Synstelien et al. | Feb 2008 | A1 |
20080040681 | Synstelien et al. | Feb 2008 | A1 |
20080071883 | Alterman | Mar 2008 | A1 |
20080082627 | Allen et al. | Apr 2008 | A1 |
20080091777 | Carlos | Apr 2008 | A1 |
20080097871 | Williams et al. | Apr 2008 | A1 |
20080104496 | Williams et al. | May 2008 | A1 |
20080140775 | Lee et al. | Jun 2008 | A1 |
20080141141 | Moore et al. | Jun 2008 | A1 |
20080141153 | Samson et al. | Jun 2008 | A1 |
20080168245 | De Atley et al. | Jul 2008 | A1 |
20080168391 | Robbin et al. | Jul 2008 | A1 |
20080222232 | Allen et al. | Sep 2008 | A1 |
20080222295 | Robinson et al. | Sep 2008 | A1 |
20080222658 | Allen et al. | Sep 2008 | A1 |
20080319856 | Zito et al. | Dec 2008 | A1 |
20090013058 | Chan | Jan 2009 | A1 |
20090024943 | Adler et al. | Jan 2009 | A1 |
20090037509 | Parekh et al. | Feb 2009 | A1 |
20090070409 | Clayton et al. | Mar 2009 | A1 |
20090094339 | Allen et al. | Apr 2009 | A1 |
20090111448 | Paila | Apr 2009 | A1 |
20090180412 | Albert et al. | Jul 2009 | A1 |
20090204885 | Ellsworth et al. | Aug 2009 | A1 |
20090216634 | Peltonen et al. | Aug 2009 | A1 |
20090265213 | Hyman et al. | Oct 2009 | A1 |
20090288004 | Strandell et al. | Nov 2009 | A1 |
20100030901 | Hallberg et al. | Feb 2010 | A1 |
20100100605 | Allen et al. | Apr 2010 | A1 |
20100100626 | Allen et al. | Apr 2010 | A1 |
20100138295 | Caron et al. | Jun 2010 | A1 |
Number | Date | Country |
---|---|---|
0 996 058 | Oct 1998 | EP |
1942422 | Jul 2008 | EP |
2005-346434 | Dec 2005 | JP |
WO 0186384 | Nov 2001 | WO |
WO 0221404 | Mar 2002 | WO |
WO 2006028488 | Mar 2006 | WO |
WO 2008052013 | May 2008 | WO |
WO 2008060828 | May 2008 | WO |
Number | Date | Country | |
---|---|---|---|
20080222613 A1 | Sep 2008 | US |
Number | Date | Country | |
---|---|---|---|
60893330 | Mar 2007 | US | |
60977544 | Oct 2007 | US |