The present invention relates generally to allocating resources in a communications network and, in particular, to allocating asset delivery resources where those resources may be insufficient to support delivery of all desired assets with respect to all asset delivery opportunities of the network.
Communications networks generally have limited resources available for delivering assets such as advertising, public service announcements or other content. In some cases, due to these limitations, it may be necessary or practical to favor some asset delivery opportunities (ADOs) but not others. Which ADOs are supported in such cases may be based on an analysis of the resources and ADOs, on an opportunistic basis (e.g., “first come-first served”), or some other basis. Allocation of resources based on an analysis of the resources and ADOs is generally preferable, provided that sufficient information is available concerning the resources, the ADOs, and some system of valuation for the ADOs. Unfortunately, the information that is available at the time that decisions concerning asset allocation are made is sometimes incomplete or inaccurate.
Those difficulties can be illustrated by considering the example of allocating assets to support targeted or addressable advertising in a broadcast network such as a broadcast television network. In such contexts, limited resources, such as dedicated in-band resources or dedicated asset channels, may be available for delivery of addressable assets. The addressable assets may be substituted for a default asset to better match assets to targeted audience segments. For example, a user equipment device (e.g., a set top box or television) may be controlled to switch to a selected asset channel during a given break of a programming channel to deliver an asset matched to the current user (e.g., viewer) or users. It will be appreciated that there are generally practical limitations on the bandwidth that is available to provide addressable assets. As a result, there may not be sufficient resources available to support all possible ADOs as defined in relation to the programming channels and/or audience segments that could be supported. For example, in a given network, it may be anticipated that potentially overlapping ADOs (e.g., advertising spots) may occur on each of four programming channels during a time window being managed. Further, it may be desired to deliver ten addressable assets in connection with those potentially overlapping ADOs. In this case, if resources are only available to support delivery of six assets to support the ADOs, it is apparent that not all possible assets can be delivered if the ADOs in fact overlap.
Resource allocation is further complicated in certain contexts due to the nature of the assets and the uncertainty concerning when ADOs will occur. Considering again the case of broadcast television networks, the entity/system making decisions regarding resource allocation may not know when a commercial break (generally including one or more asset spots) is going to occur until shortly before the break. Moreover, it is generally unacceptable to interrupt an asset after it has begun, and an asset may typically last for 15 seconds to a minute or more. Consequently, a decision may need to be made concerning resource allocation for a first ADO of a time window (e.g. a time segment being managed for resource allocation purposes) before the total number of ADOs occurring at least in part in the time window is known.
In accordance with the present invention, asset delivery resources can be allocated in a communications network based on intelligent predictions and associated valuations concerning ADOs. Specifically, a resource allocation process may be executed for a time window under consideration. Different size time windows can be employed depending on the nature of the network and the desired management granularity or processing limitations. In the case of broadcast television environments, practical time windows may vary, for example, from relatively coarse time windows on the order of one minute to fine time windows that may be a small fraction of a minute. The time windows may be static windows or can be dynamically defined, for example, to optimize performance in relation to size or value of audience for targeted asset delivery.
The allocation process further involves determining a set of asset delivery resources for consideration. The asset delivery resources are the resources available in the communications network for delivery of assets and can vary depending on the network environment, the size of the time window, and other factors. For example, in the case of a satellite or cable television network, there may be a limited number of sidebar or asset channels, or a limited amount of other bandwidth, available for transmitting assets. In certain streaming contexts, such as multicast streaming for mobile TV, carriers may have bandwidth constraints. It will be appreciated that the asset delivery resources, and units for considering the same, may be different in different network contexts.
A set of resource allocation units is also selected for consideration. The resource allocation units are the units that are considered in relation to resource allocation at a given step in the process. Generally, the resource allocation determination will proceed iteratively with respect to successive units. For example, in the case of a television network having a number of programming channels that have addressable ADOs (e.g., ad spots), and a number (that may vary over time) of asset channels used to provide asset options for the addressable spots, the resource allocation units may include particular programming channels. In other cases, the process may iterate with respect to successive time units.
Probabilities may be calculated concerning the likelihood of an ADO (e.g., an addressable ADO) occurring with regard to each resource allocation unit. In the case where the resource allocation units are individual programming channels, probabilities may be calculated concerning the likelihood that an ADO will occur for each programming channel during a time window (e.g., at least a portion of said ADO overlaps a portion of the time window). It is noted that each of the resource allocation units may have one or more potential ADOs for the time window, e.g., one or more ad spots or one or more audience segments for an ad spot. In this regard, it will be appreciated that only a limited number of content delivery bands (e.g., programming channels) or ADOs (e.g., designated addressable ADOs) may be considered for purposes of resource allocation. In the case of multicast network contexts, e.g., for mobile TV, the resource allocation units may be time intervals and probabilities may be calculated concerning individual streaming or download events where each event defines one or more ADOs. The process may thus involve determining probabilities concerning the likelihood that such events will occur during a time window.
For each of the resource allocation units under consideration, the process further involves calculating a value for delivery of an asset in connection with the ADO. For example, the value may be determined in relation to an estimated audience size or composition, estimated revenues, or other valuation parameter related to delivery of the asset. A set of probabilities and values is thereby generated for the corresponding ADOs.
Based on the set of probabilities and values, the asset delivery resources can be allocated with respect to specific ADOs of specific ones of the asset allocation units. This allocation may result in withholding use of available resources to support an earlier ensuing ADO so that resources will be available for a later ensuing ADO, e.g., because the later ensuing ADO is determined to be statistically preferable due to the probability of the ADO occurring during the window and the estimated value of delivery of an asset in connection with the later ADO.
The resource allocation process may be implemented by a computer-based platform configured with appropriate logic, e.g., software, firmware and/or hardware. The platform can communicate with associated information systems to access information concerning the content delivery bands to be supported, the asset delivery resources available for the time window, historical information concerning ADOs of the content delivery bands, audience size and composition information, delivery values, and the like.
For a more complete understanding of the present invention, and further advantageous thereof, reference is now made to the following detailed description, taken in conjunction with the drawings, in which:
The present invention relates to allocating limited resources available for servicing ADOs in a communications network. This may encompass a variety of different types of ADOs in a variety of network environments. In the following description, a number of network contexts where the invention may be employed are first described in Section 1. Thereafter, certain resource allocation optimization techniques are described in Section 2.
1. Network Contexts
The present invention is useful in a variety of networks including cable television networks, satellite television networks, streaming networks, and hybrid networks. Each of these examples briefly discussed below together with a description of resource constraints that can be addressed by the resource allocation optimization functionality of the present invention. While these examples facilitate understanding of the subsequent description of the resource allocation optimization system and functionality, it will be appreciated that similar resource limitations exist in other network contexts and the invention is not limited to these networks or contexts.
1.1 Cable Television Networks
For purposes of illustration, the invention is described in some instances below in the context of a cable television network implementation. Some major components of a cable television network 100 are depicted in
The headend 104 processes the received content for transmission to network users, e.g., residential or business users. Among other things, the headend 104 may be operative to amplify, convert, format and otherwise process the broadcast content signals as well as to combine the signals for insertion into a common cable for transmission to network users 107 (although graphically depicted as households, as described below, the system of the present invention can be used in implementations where individual users in a household or business users are targeted). It also is not necessary that the target audience be composed of households or household members in any sense. For example, the present invention can be used to create on-the-fly customized presentations to students in distributed classrooms, e.g., thus providing examples which are more relevant to each student or group of students within a presentation being broadcast to a wide range of students. The headend also processes signals from users in a variety of contexts as described below. The headend 104 may thus be thought of as the control center or local control center of the cable television network 100.
Typically, there is not a direct fiber link from the headend 104 to the user equipment device (UED) 108. Rather, this connection generally involves a system of feeder cables and drop cables that define a number of system subsections or branches. This distribution network may include a number of nodes 109. The signal may be processed at these nodes 109 to insert localized content, filter the locally available channels or otherwise control the content delivered to users in the node area. The resulting content within a node area is typically distributed by optical and/or coaxial links 106 to the premises of particular users 107. Finally, the broadcast signal is processed by the UED 108 which may include a television, data terminal, a digital set top box, DVR or other terminal equipment. It will be appreciated that digital or analog signals may be involved in this regard. In addition, while a cable network is shown, cable television content may also be delivered via wireless or data network devices such as phones, tablets, laptops or the like.
Network operators derive revenue, based on delivery of desirable content or programming. The stakeholders in this regard include programming providers, asset providers such as advertisers (who may be the same as or different than the programming providers), network operators and users—or viewers in the case of television networks.
Programming providers include, for example: networks who provide series and other programming, including on a national or international basis; local affiliates who often provide local or regional programming; studios who create and market content including movies, documentaries and the like; and a variety of other content owners or providers.
Asset providers include a wide variety of manufacturers, retailers, service providers and public interest groups interested in, and generally willing to pay for, the opportunity to deliver messages to users on a local, regional, national or international level. As discussed below, such assets include: conventional advertisements; tag content such as ad tags (which may include static graphic overlays, animated graphics files or even real-time video and audio) associated with the advertisements or other content; banners or other content superimposed on or otherwise overlapping programming; product placement; and other advertising mechanisms. In addition, the networks may use spots for internal marketing as discussed above, and the spots may be used for public service announcements or other non-advertising content.
Network operators operate the networks used to deliver content and associated assets (though the content and assets may be delivered via different networks or paths in some cases). Examples of network operators include multichannel video programming distributors (MVPDs), internet service providers and other network service providers. Such operators are generally responsible for delivering content to users and otherwise operating the networks as well as for contracting with the networks and asset providers and billing.
Users are the end consumers of the content. Users may employ a variety of types of UEDs including television, set top boxes, tablets, phones, data terminals, satellite delivered video or audio to an automobile, appliances (such as refrigerators) with built-in televisions, etc.
As described below, all of these stakeholders have an interest in improved delivery of content including targeted asset delivery. For example, users can thereby be exposed to assets that are more likely of interest and can continue to have the costs of programming subsidized or wholly borne by asset providers. Asset providers can benefit from more effective asset delivery and greater return on their investment. Network operators and asset providers can benefit from increased value of the network as an asset delivery mechanism and, thus, potentially enhanced revenues. The present invention addresses all of these interests. While targeted asset delivery is a particular challenge in relation to resource allocation for asset delivery, and is therefore an advantageous application of the present invention, the invention is not limited to targeted or addressable contexts.
It will be noted that it is sometimes unclear that the interests of all of these stakeholders are aligned. For example, it may not be obvious to all users that they benefit by consuming such assets. Indeed, some users may be willing to avoid consuming such assets even with an understanding of the associated costs. Network operators and asset providers may also disagree as to how programming should best be distributed, how asset delivery may be associated with the programming, and how revenues should be shared. As described below, the present invention provides a mechanism for accommodating potentially conflicting interests or for enhancing overall value such that the interests of all stakeholders can be advanced.
Assets can be provided via a variety of distribution modes including real-time broadcast distribution, forward-and-store, cloud-based decisioning, and on-demand delivery such as VOD and streaming. Real-time broadcast delivery involves synchronous delivery of assets to multiple users such as the conventional paradigm for broadcast radio or television (e.g., airwave, cable or satellite). The forward-and-store mode involves delivery of assets ahead of time to UEDs with substantial storage resources, e.g., a DVR or data terminal. The asset is stored for later display, for example, as prompted by the user or controlled according to logic resident at the UED and/or elsewhere in the communications network.
In cloud-based decisioning, decisions regarding asset delivery for particular UEDs are made remotely, e.g., at a cloud-based platform. Decisions are generally made just before an ADO. Assets may be delivered to the UED, for example, via a data network such as the internet and may be preloaded onto the UED or downloaded in response to decision. In such contexts, resource allocation may be required in relation to processing limitations of the cloud-based decisioning platform, bandwidth limitations of the asset delivery network, or other limitations. The on-demand mode involves individualized delivery of content from the network to a user, often on a pay-per-view basis. The present invention can be utilized in connection with any of these distribution modes or others. In this regard, important features of the present invention can be implemented using conventional UEDs without requiring substantial storage resources to enhance even real-time broadcast programming, for analog and digital users.
The amount of programming that can be delivered to users is limited by the available programming space. This, in turn, is a function of bandwidth. Thus, for example, cable television networks, satellite television networks, satellite radio networks, and other networks have certain bandwidth limitations. In certain broadcast networks, the available bandwidth may be divided into bandwidth portions that are used to transmit the programming for individual channels or stations. In addition, a portion of the available bandwidth may be utilized for bi-directional messaging, metadata transmissions and other network overhead. Alternately, such bi-directional communication may be accommodated by any appropriate communications channels, including the use of one or more separate communications networks. The noted bandwidth portions may be defined by dedicated segments, e.g., defined by frequency ranges, or may be dynamically configured, for example, in the case of packetized data networks. As will be described below, in certain implementations, the networks may use available (dedicated or opportunistically available) bandwidth for substantially real time transmission of assets, e.g., for targeted asset delivery with respect to a defined asset delivery spot. In these implementations, bi-directional communications may be accommodated by dedicated messaging bandwidth and by encoding messages within bandwidth used for asset delivery. A DOCSIS path or certain TELCO solutions using switched IP may be utilized for bi-directional communications between the headend and UEDs and asset delivery to the UEDs, including real-time asset delivery, in the systems described below.
The number of asset channels available for targeted asset delivery may be limited by the available bandwidth (e.g., unused channels) of a given network operator. Thus, the operator may have a number of dedicated asset delivery channels available for servicing addressable ADOs. These asset delivery channels may define a pool of channels that are shared by several programming channels that support addressable ADOs. Consequently, decisions may be made concerning what asset channel resources to use, e.g., which ADOs to support or how to otherwise apportion the asset channels. This is discussed in more detail in U.S. Pat. No. 8,108,895, which is incorporated by reference herein in full.
As discussed below, the system may also make use of channels that are opportunistically available, e.g., channels that are used for VOD at night may be available to support asset options during the day, or unused bandwidth within a node filter area may be used for this purpose.
It should be noted that such asset flotillas need not be rectangular as shown in
Referring again to
The four asset channels 201-204 may be utilized to provide multiple asset options for different programming channels. For instance referring to
Unfortunately, the exact time when an ADO will occur generally is not known ahead of time. For example, as shown in
It will be appreciated that the asset channels, in this scenario, present limited resources. It is important to allocate these resources in an optimal fashion. As described below, this involves consideration of which ADOs conflict or overlap and the values associated with such ADOs. Unfortunately, the timing of these ADOs is not known with precision ahead of time. The resource allocation optimization techniques described below address these concerns.
1.2 Satellite Television Networks
The notion of resource limitations for assets and defined asset channels is not limited to cable television networks and may also occur, for example, in satellite networks. Referring to
The illustrated satellite transmission 406 includes a number of MUXs 407. As will be understood from the description below, each of the MUXs 407 may include multiple content channels. Generally, the UED 408 can demultiplex the MUXs and tune to a particular channel within a particular MUX to display the associated content at the UED 408. The UED 408 can typically switch channels within a single MUX by re-tuning without implicating certain analog circuitry and with minimal latency between the command to change channels and execution of the associated channel hop. By contrast, hopping channels between different MUXs 407 takes significant and varying time, e.g., up to multiple seconds, and results in a generally unacceptable latency for purposes of channel hopping to deliver addressable assets. Thus, an important consideration relates to configuring the satellite transmission 406 such that asset options are included in the same MUX 407 as the corresponding programming channel. It will be appreciated in this regard that the desired effect can be achieved by providing the asset options in any bandwidth of the same MUX and references to asset channels are not intended to limit implementation to a specific bandwidth configuration within the MUX.
The illustrated UED 408 includes a display device 418 such as a television screen and a controller 416 for controlling delivery of content to be displayed. The controller 416 operates a number of components including, in the illustrated embodiment, a demultiplexer 410, a switch 412, storage 420 and an optional classifier 414 for determining or receiving audience classification information. The demultiplexer 410 obtains an electronic representation of the satellite transmission 406 from the receiver 404 and demultiplexes the transmission 406 to provide access to the channels within the transmission 406. In this regard, the processor 416 can process the demultiplexed signal to select or tune to a desired channel of the transmission 406.
As noted above, the addressable asset delivery system may or may not make use of historical ADO data in determining how to configure a satellite transmission and insert content.
In the illustrated implementation, the programming channels that include addressable ADOs are assigned to different MUXs 502 based at least in part on a rank. The rankings are shown in table 504. In this case, eight programming channels P1-P8 include addressable ADOs and those programming channels are ranked from 1 to 8 with 1 representing the highest and most valuable ranking. Thus, for example, a programming channel that has the highest ratings or highest potential value of addressable asset delivery for a time window under consideration may be ranked as the highest or most valuable programming channel. In this case, P1 is identified as having the highest rank designated as rank 1. On the other hand, P7 is identified as having the lowest rank.
Table 506 shows asset channel assignments. As noted above, it may be the case that only certain MUXs include asset channels. Moreover, as shown, different MUXs 502 may have a different number of asset channels available, for example, due to bandwidth and business considerations. In the illustrated example, the uppermost MUX 502 includes six asset channels A1-A6; the next MUX 502 includes three asset channels B1-B3; the next MUX 502 includes six asset channels C1-C6; and finally the next MUX 502 includes five asset channels D1-D5.
It may be the case that the highest value or highest rank programming channel should be supported by the most asset channels. Thus, for example, one or more asset providers may wish to provide addressable assets to different audience segments for an ADO associated with a large overall audience share and a network, affiliate or other owner of an ADO may wish to accommodate as many asset channels as possible. However, this will not necessarily be the case. For example, a single asset provider may purchase the entirety of a high value addressable ADO but only wish to place two asset options for that ADO, e.g., based on gender. In the illustrated example, it is assumed that it will generally be desired to provide more asset channels to support addressable ADOs on highly ranked programming channels. Accordingly, as shown in the table 506, the highest rank programming channel, P1, is supported by four asset channels, A1-A4, whereas the lowest rank programming channel, P7, is supported by only two asset channels, A5-A6.
Considerable analysis may be required to develop an optimal configuration of the satellite transmission 500 in this regard. For example, the analysis can be used to determine 1) whether all or only a subset of the programming channels including potentially addressable ADOs will be assigned asset channels, 2) whether more than one such programming channel will be included in one or more of the MUXs 502, 3) when more than one such programming channel will be included in one or more of the MUXs 502, which sets of two or more programming channels should share MUXs, and 4) when more than one such programming channel is included in one or more of the MUXs 502, how the asset channels of that MUX will be apportioned amongst the programming channels.
There are a number of ways that the process of configuring a satellite transmission can be coordinated with contracting for addressable asset delivery. For example, the satellite transmission may be configured prior to contracting with asset providers, e.g., based on historical ratings or pricing information, so that information can be provided to asset providers concerning the likely availability of asset channels for a given ADO. Alternatively, contracting with asset providers may be executed first and then the contract information may be utilized to execute transmission configuration. As a still further alternative, asset providers may contract to purchase a certain number of targeted impressions rather than purchasing specific segments of specific ADOs. In this manner, greater flexibility will be provided to configure satellite transmissions so as to efficiently fulfill campaign specifications.
In the implementation illustrated in
The satellite transmission configuration process illustrated in
However, apportionment of asset channels within a MUX will not necessarily correspond to such rankings. For example, a programming channel with a large overall audience or large potential value may get fewer asset channels than a lower ranked programming channel in the event of conflicting ADOs due to, for example, a lower number of asset options or lower value audience segments. This is described in more detail in U.S. patent application Ser. No. 15/403,847 which is incorporated by reference herein in full.
The discussion above suggests one sequence for satellite signal configuration. First, the number of MUXs in a satellite signal, the number of MUXs that will include asset channels, and the number of asset channels that are available in those MUXs may be determined. This may involve a variety of businesses and technology considerations of the network provider, programming networks, asset providers and other stakeholders. Some of these considerations may have little or nothing to do with addressable asset delivery. However, at least the number of MUXs including asset channels and the number of asset channels available in the various MUXs may be determined based on consideration of the demand for and potential value of addressable ADOs.
Next, the number of programming channels for which addressable ADOs will be supported, and the placement of these programming channels into the available MUXs may be determined. This may involve consideration of average or ADO specific viewership, average or per audience segment values, probability of conflicting ADOs, premiums paid for guaranteed access, etc. Finally, in the event of a conflict, asset channels may be shared or apportioned based on ranking, revenues or other considerations (e.g., priority of an asset provider or need to fulfill specifications of a campaign near expiration). Such appointment may be predetermined in anticipation of potential conflicts or determined at the time a conflict becomes apparent. Moreover, based on analysis of historical ADO data and asset values, asset channels that are available at the initiation of an ADO may be withheld to support an expected, potentially overlapping ADO. It will be appreciated that the resource allocation optimization functionality of Section 2 below can be used to configure the satellite transmission as well as to allocate the asset channels to ADOs.
1.3 Streaming Networks
The resource allocation optimization functionality described below is not limited to broadcast networks (e.g., television or radio), but is also applicable to multimedia streaming networks where content is inserted into and transmitted via data and/or wireless networks. An example of this is mobile TV networks 700 as shown in
The illustrated network includes a content source 702 and a number of routers 704 for routing content from the source 702 to UEDs 706. The illustrated source 702 provides streaming content such as mobile TV content. For example, a network operator may provide on-demand or scheduled programming to subscribers. Accordingly, the source 702 may comprise a set of servers or cloud-based resources that can access live or stored content and format the content for transmission across the network 700.
The content is routed to the end users 706 via a number of routers 704. The routers 704 may be operated to execute a multicast transmission protocol. In the multicast transmission protocol, content is addressed from the source 702 to the end users 706 and transmitted substantially simultaneously to the end users 706 in a one-to-many fashion. The routers 704 may be wired and/or wireless.
In multicast systems, content is typically delivered on-demand. Thus, one or more users may request a content stream. The network operator may aggregate viewing requests to be serviced by a single multicast stream. Additional users who request the same content may be added to the stream. The network generally has certain bandwidth limitations and may specifically have a limited amount of bandwidth (at any given time) that is available for multicast use (e.g., because other bandwidth is reserved for other purposes).
1.4 Hybrid Systems
The network environments where resource allocation can be optimized in accordance with the present invention are not limited to broadcast networks or streaming networks, but may also encompass, among other things, hybrid systems that utilize resources of different networks. An example of this is the hybrid system 900 of
The illustrated system 900 further includes a cloud decisioning system 910 that may be, for example, accessed via the internet. The illustrated cloud decisioning system 910 provides information to the UEDs 902 and 904 to assist in selection of assets for delivery in addressable ADOs, for example, an identification of one or more assets that are appropriate for the UED 902 or 904. More specifically, where the cloud decisioning system 910 is separate from the content distribution network 906, such a process may involve a request from one of the UEDs 902 or 904 requesting identification of assets for an upcoming ADO. For example, such a request may be prompted by messages contained in the content stream of the content distribution network 906, or sent to the UED 902 or 904 separately, indicating an upcoming ADO and possibly providing additional information concerning the ADO. In response (or ahead of time), the cloud decisioning system 910 may access information concerning a household or individual user of the UED 902 or 904, information concerning targeted audiences for various assets, information concerning cost of delivery (e.g., CPM) or campaign fulfillment (e.g., pacing, frequency, etc.), and other information to select one or more assets for the UED 902 or 904 for that ADO. The selected asset(s) are then identified in a message to the UED 902 or 904.
Transmission of assets from the asset distribution network 908 to the UEDs 902 and 904 may be effected in different ways. In one implementation, the UEDs 902 and 904 may request assets from the asset distribution network 908 upon receiving asset identifications from the cloud decisioning system 910. As the identifications are received from the cloud decisioning system 910 only a short time prior to the beginning of an ADO, it will be appreciated that this may require substantial bandwidth for asset delivery, particularly where multiple ADOs (e.g., of multiple television programming channels) occur close to the same time. Thus, resources available to support asset delivery may be intelligently allocated so that the resources are not overwhelmed.
In another implementation, assets may be downloaded from the asset distribution network 908 ahead of time and stored at the UEDs 902 and 904. However, this may implicate substantial storage requirements for assets, particularly where different asset sets are stored to support different ADOs. In any case, many UEDs may need decisions from the cloud decisioning system 910 in a short period of time immediately preceding an ADO or multiple coincident ADOs, thus straining processing resources. Accordingly, it may be important to make intelligent decisions regarding resource allocation in connection with asset distribution and delivery.
2. Resource Allocation Optimization
From the discussion above, it will be understood that resource allocation for distribution of assets is problematic in a variety of network contexts. It is generally desired to maximize some reward or benefit associated with asset delivery, in many cases by maximizing the revenues derived from asset delivery. The problems associated with optimizing resource allocation in this regard include uncertainties as to when ADOs will occur (and thus whether ADOs will overlap), uncertainties regarding the value of asset delivery, particularly in addressable asset delivery contexts, and, in some cases, uncertainty concerning what resources will be available for asset delivery.
These concerns are addressed by the resource allocation system 1000 shown in
For example, in the case of broadcast television networks, asset delivery records may be obtained from a network provider or an addressable asset system provider/operator. In the latter regard, such addressable asset systems may receive reports concerning asset delivery for billing or other purposes. Among other things, such reports may identify the addressable asset that was delivered, the programming network in connection with which the asset was delivered, and the time of delivery. Such reports can be used in connection with schedule and programming information to estimate (e.g., statistically or via machine learning) when ADOs are likely to occur, or the probability of an ADO occurring during a particular time window. Such probabilities may be calculated in relation to particular programming networks, particular times/days of the week, particular programs, particular program types (e.g., live spots, television programs, movies, news, etc.), and/or state of progress of the programming.
In addition, the RAO platform 1002 may receive business data from repository 1016, e.g., for use in calculating values associated with asset delivery. Still considering the case of broadcast television networks, such business data may relate to projected audience size, audience composition, and delivery costs (e.g., CPM) for individual audience segments. Thus, in the case of addressable ADOs, the value of allocating resources to an addressable ADO may be determined by aggregating the revenues (e.g., CPM times audience segment size in thousands) derived for each audience segment serviced. The resource cost in this example (assuming a channel hopping implementation with one asset for one audience segment on each asset channel) may be one asset channel for each audience segment for the duration of the asset plus any allocated timing uncertainty. It will be appreciated that resources may be allocated for an entire ADO or for selected audience segments of an ADO (e.g., available asset channels may be split between ADOs as described above).
Thus, the business data may be obtained from network providers, ratings systems, addressable asset systems, and other sources. The information may define what share of the overall audience each segment is expected to receive and what cost an advertiser is willing to pay for each audience segment. In some cases, how an audience is best segmented may depend on how many segments can be supported by allocated resources (e.g., male and female segments may be utilized if only two asset channels are available, whereas incomes over $100,000, followed by residual males and residual female segments may be utilized if three asset channels are available). In this regard, a particular allocation may be assumed or alternative values may be determined for multiple possible resource allocations. It will be appreciated that the repositories 1014 and 1016 include any sources from which the noted information may be obtained and may encompass databases or other data resident on different platforms (e.g., computers, servers, cloud-based resources) of different entities.
The network 1004 may be any of various networks including cable television, satellite television, streaming, or hybrid networks as discussed above. The illustrated network 1004 includes a collection of assets 1008—e.g., advertisements and associated information such as targeting parameters, constraints, campaign goals, etc.—for delivery to the UEDs 1012. In addition, the network 1004 includes resource information 1006 concerning the resources that are available for asset delivery. Such resources may be defined in relation to bandwidth, asset channels, processing resources or the like and may change over time. Moreover, the resources available may be flexible depending, for example, on the value that can be obtained for delivery of assets. The illustrated network also includes asset insertion equipment 1010. The nature of this equipment 1010 varies depending on the type of network 1004 but may, for example, include headend equipment in the case of a cable network or server resources in the case of a streaming network. The functionality of the RAO platform 1002 will now be described in more detail.
For ease of illustration, the resource allocation optimization functionality is described below primarily in relation to certain new technologies for addressable asset delivery in broadcast cable television networks. It will be appreciated that the functionality is not limited to this context.
The new technologies create systems that multiplex different assets to different viewers who are watching the same programming network, by instructing the individual cable signal converter set-top boxes within each household to transparently select from the available assets those assets specifically addressed to the demographics of that household or viewer(s).
This strategy permits an aggregation model of asset delivery, improving on the conventional linear model. In aggregation, asset providers pick the people who they want to see the asset, rather than coordinating with the networks and distributors to pick ADOs in which the asset will play. The use of aggregation improves the asset delivery efficiency of ADOs, measured by the number of asset impressions (rewards) that are successfully delivered to the correct targeted audience (e.g., demographic), because ads in the linear stream that would otherwise fail to satisfy addressability requirements in some households may be replaced with alternatives that are correctly addressed. Asset providers ultimately pay per impression, so this technique provides the industry with the opportunity to increase revenues/profitability and in return allows for more broad accessibility of programming and advanced technologies.
However, this system imposes a new cost on the cable companies: the loss of some transmission bandwidth to the asset channels. In addition, the number of networks for which the addressable system is enabled may be large and due to capacity constraints, there will be only a limited number of shared resources k (often as few as four sets of three or four asset channels), to support incoming breaks. Eventually, some requests for resources will be declined. An important objective is to optimize the expected revenue which will correspond to the maximum expected number of viewers in serviced network ADOs over some period of time, assuming the same revenues per viewer.
2.1 Greedy Algorithm vs. Sadeghi Mizera (SM) Algorithm
The existing method of resource allocation is a straightforward first-come-first-serve (Greedy) algorithm, which serves networks unconditionally as they place requests until lack of resources forces denial. Such an algorithm is in general suboptimal: if the serving rewards differ and a highly lucrative network has a big probability of having an ADO in the near future, it may be more profitable to reserve the resource for it rather than serving the less rewarding ones. This Greedy algorithm is a base case, and it can be implemented and tested against recorded or synthesized break arrival data, in either a continuous-time or discrete-time version.
The description below sets forth an improved algorithm, Sadeghi Mizera (SM). The concept of the SM algorithm is that it proceeds by determining networks that have the highest expected profit values and then computes whether reserving the resources for these networks would have a higher expected value outcome than assigning through the Greedy algorithm. For simplicity in the following, it is assumed that providing any valid asset to each individual is equally valuable and employ the number of viewers of serviced ADOs as the value to maximize.
The resulting algorithm yields better results when the probabilities of break arrivals (initiation of ADOs) are known. If the probabilities are estimated by the system, experiments on real data show that the SM algorithm outperforms the Greedy algorithm at maximizing the above value.
2.2 Theoretical Result
The SM algorithm is based in part on a mathematical model developed based on experience in the field. The following assumptions are adopted in this mathematical model:
Time discretization by each minute results in localization of decisions and interactions to the individual minute. This model is fully defined by provision of the values for Pi and Ri. Pi is the probability of network i going to break, and the Ri is the value of servicing network i if it goes to break, which is simplified to the number of viewers of that network for these experiments. For the discretized case, these values are given for each minute.
Moreover, in order to form an initial solution, it is assumed that the available resources are down to the last set of resources (k=1). Hence, more than one network going into break in an overlapping minute will cause conflicts in their requests for the last resource. In the mathematical model, it is assumed that the Greedy algorithm works as if resources are allocated randomly (probability of one break coming before the other one is the same as coming after). That is, if out of the n networks, the networks {n1, n2, . . . , nq}, q≤n, go to break in an overlapping minute, then the expected profit will be
which is simply the mean rewards for networks in collision, since there is just one resource to support coming breaks. The SM algorithm is formulated for the case of known probabilities of break arrival per unit of time per network. In this discussion, for simplicity of illustration, rewards are considered to be delivered impressions. That is, it is assumed that every asset has the same revenues per viewer such that revenues or profits directly correspond to delivered impressions. It will be appreciated that the framework can be generalized to account for differences in this regard.
After deriving this mathematical model, the path to improved solution lies in the application of rules of probability calculus. It should be emphasized that the solution is probabilistic, i.e. superior on average; however, it is well-known in probability theory that such an average behavior results in the long run in practically sure superior behavior in practice (an application of so-called law of large numbers).
2.2.1 Basic Notation
The following notation will be used in the description below.
All variables are time dependent, but to ease the notation the time subscript (t) will be dropped. Hence, definitions are per minute. In addition, for any subset, S, of networks, Gk(S) and SPk(S) are defined to be the expected reward of the Greedy algorithm and SM algorithm serving k resources at time t—the latter suppressed in the notation, as well as P and R.
2.2.2 Greedy Algorithm Formulation for One Resource
The expected value of the Greedy algorithm across the span of all networks has a well-defined mathematical formula.
For any subset, S, of networks, G1(S) is defined to be the expected reward of the Greedy algorithm serving 1 resource at time t (again, the latter suppressed in the notation, as well as P and R)
Note that the term l reflects the number of networks going into break in an overlapping minute and 1/l accounts for the random allocation of the resource.
Furthermore, G1(S) can be rewritten just in terms of Pis and Ris. Assuming, S={1, 2, . . . , n} and
G
1(S)=P1R1Δ+I−P1II (2)
Where, il=2, 3, . . . , k, l<k and
2.2.3 One Step SM Algorithm Formulation for One Resource
One step SM is an improved solution over the Greedy algorithm that proceeds by determining a preferred network (network with highest expected profit PiRi) and then computing whether reserving the resource would have a higher expected value outcome than assigning through the Greedy algorithm. This procedure has three steps:
In other words, the SM algorithm at every minute decides either to reserve the only resource for the network with highest predicted expected profit, PiRi, or to just leave it to the Greedy algorithm. The following Theorem proves that the SM algorithm is superior to the Greedy algorithm. Simulation study demonstrates that the SM algorithm outperforms the Greedy algorithm.
Theorem. Under the assumptions of known value and probability of break arrival per minute per network, independence between networks and
we have
Proof. Under the assumption
we get P1II+P1R1−P1ΔR1>I which results in P1R1>P1R1Δ+I−P1II and equivalently P1R1>G1(S).
An illustrative example: Herein, an example to better understand the behavior of the introduced SM algorithm versus the Greedy algorithm is provided. Assuming two networks (n=2) and only one available resource (k=1), the expected profit through the Greedy algorithm would be
Note that in the case of collision, the profit through the Greedy algorithm would be either P1P2R1 or P1P2R2 depending on which network goes to break first and consequently a suboptimal choice will be made in the case that network 2 goes to break first but R1>R2. However, the SM algorithm would reserve the resource for network 1 and decline the request for resource of network 2 since P1R1>P2R2.
2.2.4 Approximation and Quadratic Computation of Expected Greedy Solution for One Resource
From equation (1), it can be seen that the expected Greedy solution for all possible subsets of breaking networks, just for a single resource, k=1, has
terms and the direct calculation has exponential computational complexity. Since this value is required as part of the calculation of the smart predictive algorithm, that algorithm also has exponential computational complexity. To enable practicable calculation when the number of programming networks is large, the expected Greedy solution can either be approximated, which is a tradeoff between accuracy and the complexity of calculation, or the expected Greedy calculation can be reformulated to a recursively defined process with reduced computational complexity.
2.2.4.1 Approximation of the Expected Greedy Solution for One Resource
Due to the fact that
we have following upper bounds for Δ, I, and II
2.2.4.2 Quadratic Computation of the Expected Greedy Solution for One Resource
By using a recursive formulation, the expected value of the Greedy solution can be computed in O(n2) computational complexity. The recursion is performed on the size of the set of networks currently under consideration. Suppose there was a calculated value for expected Greedy for a set of networks Sα. Then, if that could be used in a linear-time calculation for the value of the expected Greedy solution for the set Sβ=Sα∪s for any network s not already in Sα, the process could recurse through the set of networks not yet included and eventually calculate the expected Greedy solution for the entire set of networks. For simplicity, the algorithm is described with the assumption that the networks are numbered {1, 2, . . . , n} and the process recurses by introducing the next numbered network at each step.
Let G1(n−1) be the value for the expected Greedy solution if we include only the first n−1 networks ({1, 2, . . . , n−1}). If the network n is introduced, then either that network goes to break or it does not. If it doesn't, which has probability 1−Pn, then the value for the expected Greedy solution in this case is the same as the previous value, which is already known to be G1(n−1). So, the process only needs to calculate the case for when the new network goes to break, which happens with probability Pn. Clearly, G1(1)=P1R1, so a base case for the recursion is established.
Furthermore, the expected Greedy solution at step n depends on number of networks colliding at step n−1. To that end, let Cn be the size of the set of networks in collision amongst the first n networks, and define Enj to be the amount of rewards when j networks go to break (Cn=j) among the first n networks. In addition, define Bnj=P(Cn=j), 0≤j≤n, n≥1, where Bnj is the Poisson Binomial distribution over the break arrival probabilities P1, P2, . . . , Pn and which has its own quadratic time recursive computation.
Therefore,
By considering Gnj=BnjEnj (with Gn0=0), we have
The recursive calculation of the Poisson Binomial Bnj is:
2.2.5 Formulation of the Greedy Algorithm for an Arbitrary Number of Resources
For any subset, S, of networks, define Gk (S) to be the expected reward of the Greedy algorithm serving k resources at time t.
It is clear that the computational complexity of direct calculation of the Greedy expected value also increases exponentially in the number of programming networks |S| when there is more than one resource k.
2.2.5.1 Quadratic Computation of the Expected Greedy Solution for an Arbitrary Number of Resources
Here the recursive formula is generalized for calculation of the expected Greedy solution for any subset of networks and an arbitrary number of resources k. Considering, Bnj: probability of j networks go to break out of n, Enj: profit when j networks break out of n and Gnj: expected profit when j networks break out of n, we have
2.2.6 One Step and Multi-Step SM Algorithm Formulation for an Arbitrary Number of Resource
The SM algorithm can be generalized to accommodate more than one resource available at a time for any subset, S={1, 2, . . . , n}, of networks and is called “one step SM algorithm.” For instance, in case of two resources at each minute, k=2, and under the condition P1R1>P2R2> . . . >PnRn, here are the possible strategies:
The chosen strategy will be the one maximizing overall expected profit at that minute:
Simulation in the next section demonstrates that this algorithm is superior to the Greedy algorithm. Furthermore, the efficiency of this algorithm can be improved by including a mixed strategy called “multi-step SM algorithm.”
The idea behind this mixed strategy is straightforward. Similar to the one step SM algorithm it still has three possible strategies:
However, the way resources are reserved will be updated. Here are the expected profit based on each potential decision:
Finally, the chosen strategy will be the one maximizing overall expected profit at that minute:
max(EP1,EP2,EP3)
Notice that in part (2) instead of reserving just for the network with highest PiRi+G1(S\i), there is the option to reserve for the first two networks with highest G1({i, j})+G1(S\{i, j}) and then do the Greedy algorithm between them. In the same way, in part (3) there is the option to either reserve both resources for the two highest networks with highest expected profit or reserve for the first four highest networks and then do the Greedy algorithm between them.
In the case k=1, multi-step allows for reserving for the two networks with highest expected profits and doing Greedy between them as well as reserving the single resource for the first network with highest expected profit. An implementation may perform the optimization on more than one resource.
2.3 Method Evaluation
In this section, the methods are evaluated using historical data. To provide a fair assessment, the proposed algorithm is applied such that it does not know about the future but just the past, thereby simulating the real setting in which the algorithm runs. The optimal algorithm is formulated for the case of known probabilities of break arrival per unit of time per network, however, these probabilities are not known but are instead estimated. Hence, the foundation of forming an effective algorithm is in estimating the probability of break arrivals per unit of time per network accurately which requires constructing effective statistical/stochastic models for break placements for each network. It is important to notice that the aim is to create a model of the process as a sequence of conditional density function for any given value. In other words, the process is not directed to point prediction of when the next break happens, but instead the whole distribution of next break arrival. The process is concerned with probability forecasts, so the prediction is a probability, the probability of break arrival in the next minute. There are various methods for probability distribution estimation, like Ensembles of Mixture Density Networks, but what is considered in the following experiments for obtaining probabilities are based on a sequence of conditional density functions for any given interval between breaks, by combining kernel and nearest-neighbor methodology while gaining some strength due to empirical Bayes characteristics.
Due to the time dependency of break arrivals, probabilities are estimated dynamically from historical data. The data set is divided into training and testing sets to ensure realistic simulations. The training set is used to estimate the probability distribution of next break arrivals, from which the probability is estimated of networks going to break within the next minute given there was no break to this time (the hazard function). The testing set is used for evaluation of the methodology. Estimated probabilities from the data and the known reward associated with each network per minute are applied to simulate the decision procedure within the SM algorithm.
2.4 The Data Setting
Here, the historical break data (generally corresponding to ADOs) from the San Francisco area over eighty-three days (Aug. 1-Oct. 22, 2007) combined with viewership data from San Francisco are used for the experiment. The data is divided into the first 61 days which is used for estimation of the probability distribution of the intervals between breaks, and last 22 days that are used for evaluation of the methodology.
A break data contains the actual ad break times (in hours, minutes and seconds) and durations for a particular network on a particular day along with network ID. So, the waiting time between each two breaks can be calculated. Viewership data is represented as a tabulation of viewing by households of television stations and cable programming available in the region by fifteen minute period. The assumption here is that the number of viewers is fixed within each fifteen minutes. So, the value of each break might be evaluated through combining break data and the viewership data. In total, the break data and viewing data of 27 networks are matched.
The performance of the Greedy algorithm versus the SM algorithm (one step and multi-step) based on the approximation and quadratic recursive methods with one and two resources are compared.
From Table 1, the summation of delivered impressions over the 22 days for the Greedy algorithm is 65,234,469 million. Using approximation techniques, the amount of delivered impressions through the SM algorithm is 66,671,599 million, which is very close to the 66,746,608 million calculated based on exact method (quadratic recursive). This shows that the approximation bound is very tight and accurate. In addition, it has the advantage of being fast in terms of computation. Multi-step SM algorithm delivered 70,419,812 million impressions. These results are consistent with the theory, SP1(S)≥G1(S). In terms of improvement, the SM algorithm using the multi-step methodology exhibits the most improvement over the Greedy algorithm (7.94878%) which results in 5,185,343 million more impression deliveries.
Over all of the considered minutes in 22 days, there were 7,822 cases where more than one network asked for resource in an overlapping minute and the maximum number of networks going into break around the same time was 9 networks.
Table 2 summarizes the results of the resource allocation problem considering all 27 networks and two resources available per minute.
It is important to notice that actually four resources (asset channels) are actually being considered, two for even minutes and two for odd minutes. The SM algorithm using the multi-step method exhibits the most improvement over the Greedy algorithm which results in 1,506,651 million more impressions delivered which is equivalent to a 1.5% improvement. Note that in these particular tests, in the case of k>1 there is not much of an improvement over the Greedy algorithm, since for most of the minutes there are enough resources to support the incoming break. The SM algorithm is the most useful when there are collisions. In tests with more networks competing in the system, it is expected that SM provides substantial benefits in k>1 cases.
Over the whole considered minutes in 22 days, there were 3,035 cases where more than two networks asked for resource in an overlapping minute and the maximum number of networks going into break around the same time was 9 networks.
In addition, assuming that Greedy is an instant algorithm in terms of the execution time, following is the summary of execution time of the SM algorithm under different strategies over 27 networks and 22 days of testing data. The scripts are written in the R language, without optimization.
The approximation method to evaluate the SM algorithm is the fastest, followed by one step and multi-step for k=1. In the case of two resources available, k=2, it is obvious that the multi-step takes more execution time but the gained profit over the one step is more significant. In addition, the amount of processing time required in all cases is well within the computational capabilities of live systems.
2.5 Conclusion
The efficacy of the new probabilistic algorithm for resource allocation in networks has been demonstrated for the exemplary context of addressable advertising in traditional TV networks with application in Mobile TV networks. Its O(n2) implementation together with an approximate and exact recursive solutions have also been developed. The performance of the proposed methods were assessed on real historical data from the TV industry which resulted in significant improvement in terms of advertising over the current method in use in the industry. In fact, the multi-step SM algorithm improved the revenue by 7.94878% in case of single resource (k=1) and increased the profitability by 1.5% in the case of k=2. In addition, the processing times for all proposed methods are assessed and are well within the computational capabilities of live systems. It is noted that transmitting addressable advertising over a mobile TV platform via LTE broadcast has relevant structural similarities to delivering this advertising over traditional television systems, and so it is expected that these results from the one area transfer to the other.
While a specific example has been provided above in the context of the addressable asset delivery in a cable television network, the resource allocation optimization process can be more generally summarized by reference to the flowchart of
The illustrated process further involves determining (1104) the resources that are available for asset delivery. In many cases, this will be a function of bandwidth, though storage or processing resources may also be considered. Bandwidth resources may be dedicated resources for asset delivery or general resources, and may be provided in defined bands (e.g., asset channels) or undifferentiated. Moreover, the amount of resources available for asset delivery may change over time. For example, additional asset channels may be opportunistically available or additional streaming bandwidth may be made available for multicasting during periods of lower traffic.
While the time window and asset delivery resources define boundaries for allocation optimization, the process further involves some unit related to asset delivery that can be used to iterate towards a solution. Thus, the illustrated process 1100 involves selecting (1106) a resource allocation unit. This will depend on the network environment. In the case of broadcast television networks, such a unit may be a programming channel, an ADO, or a portion of an ADO such as an audience segment or segments. In streaming contexts, it may involve a stream or portion of a stream such as an ADO embedded in a stream.
The process 1100 then proceeds to calculate (1108) the probability that an ADO will occur within a window under consideration and calculate (1110) a delivery value for asset. Probabilities may be calculated based on historical data for ADOs that are deemed to be similar in some respect (e.g., same time or day of the week, same television program or type of program, same programming channel, etc.). It will be appreciated that historical data may be processed to account for changes or trends, or machine learning may be employed to estimate probabilities based on training data or otherwise. Delivery values may be based on any appropriate parameters for the network environment such as audience size and composition. Again, historical data may be used intelligently to estimate values for upcoming ADOs, including accounting for changes and trends. This may be repeated (1112) for the full set of resource allocation units. The result of these steps may include compiling (1114) a set of probabilities and associated values.
The probabilities and values can then be used (1116) to allocate asset delivery resources. In many cases, this will involve foregoing use of resources for an earlier ensuring ADO to support a later expected opportunity. For example, this may occur if the earlier opportunity has a lower asset delivery value than the later expected ADO, and the later expected ADO has a probability sufficient to warrant deferring use of the resources. Various strategies can be employed in this regard, including strategies that involve consideration of the difference in delivery values of the ADOs as well as the probability. Once the asset delivery values have thus been allocated, the assets can be delivered (1118), e.g., inserted into the network, distributed to the UED, and delivered to the user via the UED. This process can then be repeated (1120) for additional time windows.
The foregoing description of the present invention has been presented for the purpose of illustration and description. Furthermore, the description is not intended to limit the invention to the form disclosed herein. Consequently, variations and modifications commensurate with the above teachings, and skill and knowledge of the relevant art are within the scope of the present invention. The embodiments described herein above are further intended to explain best modes known of practicing the invention and to enable others skilled in the art to utilize the invention in such or other embodiments and with various modifications required by the particular application(s) or use(s) of the present invention. It is intended that the appended claims be construed to include alternative embodiments to the extent permitted by the prior art.
This application is a continuation of U.S. patent application Ser. No. 18/169,089, entitled, “RESOURCE ALLOCATION IN COMMUNICATIONS NETWORKS USING PROBABILITY FORECASTS,” filed Feb. 14, 2023, which is a continuation of U.S. patent application Ser. No. 17/167,954, entitled, “RESOURCE ALLOCATION IN COMMUNICATIONS NETWORKS USING PROBABILITY FORECASTS,” filed Feb. 4, 2021, now U.S. Pat. No. 11,581,968, issued Feb. 14, 2023 which is a continuation of U.S. patent application Ser. No. 16/517,406, entitled, “RESOURCE ALLOCATION IN COMMUNICATIONS NETWORKS USING PROBABILITY FORECASTS,” filed Jul. 19, 2019, now U.S. Pat. No. 10,951,335, issued Mar. 16, 2021, which is a continuation of U.S. patent application Ser. No. 15/833,647, entitled, “RESOURCE ALLOCATION IN COMMUNICATIONS NETWORKS USING PROBABILITY FORECASTS,” filed Dec. 6, 2017, now U.S. Pat. No. 10,404,390, issued Sep. 3, 2019, which claims priority to U.S. Provisional Application No. 62/430,725, entitled, “RESOURCE ALLOCATION IN COMMUNICATIONS NETWORKS USING PROBABILITY FORECASTS,” filed on Dec. 6, 2016. The contents of the above-noted applications are incorporated herein by reference as if set forth in full and priority to these applications are claimed to the full extent allowable under U.S. law and regulations.
Number | Name | Date | Kind |
---|---|---|---|
6735630 | Gelvin | May 2004 | B1 |
6789123 | Li | Sep 2004 | B2 |
6826123 | Herring | Nov 2004 | B1 |
6826607 | Gelvin | Nov 2004 | B1 |
6832251 | Gelvin | Dec 2004 | B1 |
6859831 | Gelvin | Feb 2005 | B1 |
7403993 | John et al. | Jul 2008 | B2 |
7546619 | Anderson | Jun 2009 | B2 |
7624125 | Feinsmith | Nov 2009 | B2 |
7729984 | Nappi | Jun 2010 | B1 |
7890301 | Warrior | Feb 2011 | B2 |
8108895 | Anderson et al. | Jan 2012 | B2 |
8850473 | Sheehan et al. | Sep 2014 | B2 |
8856473 | Van Riel | Oct 2014 | B2 |
8924269 | Seubert | Dec 2014 | B1 |
9154824 | Wiser et al. | Oct 2015 | B2 |
9270733 | Ruppert et al. | Feb 2016 | B2 |
9278284 | Ruppert et al. | Mar 2016 | B2 |
9396475 | Cristofalo et al. | Jul 2016 | B2 |
9922381 | Isaacson | Mar 2018 | B2 |
9930373 | Zucchetta | Mar 2018 | B2 |
10002396 | Isaacson | Jun 2018 | B2 |
10075754 | Sheehan et al. | Sep 2018 | B2 |
10205736 | Rieki | Feb 2019 | B2 |
10404390 | Sadeghi et al. | Sep 2019 | B2 |
10492068 | Konotopskyi | Nov 2019 | B1 |
10511580 | Isaacson | Dec 2019 | B2 |
10621653 | Isaacson | Apr 2020 | B2 |
10643266 | Isaacson | May 2020 | B2 |
10666673 | Rieke et al. | May 2020 | B2 |
10666904 | Anderson et al. | May 2020 | B2 |
10673565 | Fredriksson | Jun 2020 | B2 |
10686620 | Gould | Jun 2020 | B2 |
10735450 | Smith | Aug 2020 | B2 |
10791348 | Roth et al. | Sep 2020 | B2 |
10832310 | Isaacson | Nov 2020 | B2 |
10841322 | Giani | Nov 2020 | B2 |
10951335 | Sadeghi et al. | Mar 2021 | B2 |
11049207 | Weldon et al. | Jun 2021 | B1 |
11581968 | Sadeghi | Feb 2023 | B2 |
20040090952 | Kubler | May 2004 | A1 |
20040148625 | Eldering et al. | Jul 2004 | A1 |
20050080869 | Bender | Apr 2005 | A1 |
20050081080 | Bender | Apr 2005 | A1 |
20060287915 | Boulet et al. | Dec 2006 | A1 |
20170070880 | Hahn | Mar 2017 | A1 |
20180019984 | Isaacson | Jan 2018 | A1 |
20180124067 | John | May 2018 | A1 |
20180199079 | Wilson et al. | Jul 2018 | A1 |
20190007381 | Isaacson | Jan 2019 | A1 |
20190230070 | Isaacson | Jul 2019 | A1 |
20190306137 | Isaacson | Oct 2019 | A1 |
20200120482 | Parkvall | Apr 2020 | A1 |
Number | Date | Country |
---|---|---|
2004310448 | Jun 2006 | AU |
3046341 | Jun 2018 | CA |
102137088 | Jul 2011 | CN |
2014122372 | Aug 2014 | WO |
Number | Date | Country | |
---|---|---|---|
20240348358 A1 | Oct 2024 | US |
Number | Date | Country | |
---|---|---|---|
62430725 | Dec 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 18169089 | Feb 2023 | US |
Child | 18388045 | US | |
Parent | 17167954 | Feb 2021 | US |
Child | 18169089 | US | |
Parent | 16517406 | Jul 2019 | US |
Child | 17167954 | US | |
Parent | 15833647 | Dec 2017 | US |
Child | 16517406 | US |