BACKGROUND OF THE INVENTION
1. Technical Field
The present invention relates to a system and associated method for ordering outbound marketing events for offering to a candidate.
2. Related Art
Selling a plurality of services to a customer typically requires a complicated series of steps. Therefore there exists a need for a simple procedure to sell a plurality of services to a customer.
SUMMARY OF THE INVENTION
The present invention provides a database system, comprising:
a first database structure storing a first list identifying marketing events, wherein each marketing event from said first list comprises a marketing offer and an identified channel means for communicating said marketing offer;
a second database structure storing a second list of candidates; and
a database manager software application stored on a computer readable medium, wherein said database manager software application comprises an optimization tool, and wherein said optimization tool is for optimizing and sorting, said marketing events from said first list with for a first candidate from said second list.
The present invention provides a selection method, comprising:
providing a database system comprising a database manager software application, a first database structure storing a first list identifying marketing events, and a second database structure storing a second list of candidates, wherein said database manager software application is stored on a computer readable medium, wherein said database manager software application comprises an optimization tool, and wherein each marketing event from said first list comprises a marketing offer and an identified channel means for communicating said marketing offer;
optimizing by said optimization tool, said marketing events from said first list for a first candidate from said second list; and
sorting by said optimization tool, said marketing events from said first list for said first candidate from said second list.
The present invention provides a process for integrating computing infrastructure, comprising integrating computer-readable code into a computing system, wherein the code in combination with the computing system comprises database system comprising a database manager software application, a first database structure storing a first list identifying marketing events, and a second database structure storing a second list of candidates, wherein said database manager software application is stored on a computer readable medium, wherein said database manager software application comprises an optimization tool, and wherein each marketing event from said first list comprises a marketing offer and an identified channel means for communicating said marketing offer, and wherein the code in combination with the computing system is adapted to implement a method for performing the steps of:
optimizing by said optimization tool, said marketing events from said first list for a first candidate from said second list; and
sorting by said optimization tool, said marketing events from said first list for said first candidate from said second list.
The present invention provides a computer program product, comprising a computer usable medium having a computer readable program code embodied therein, said computer readable program code comprising an algorithm adapted to implement a method for ordering a list identifying marketing events within a database system, said database system comprising a database manager software application, a first database structure storing a first list identifying marketing events, and a second database structure storing a second list of candidates, wherein said database manager software application is stored on a computer readable medium, wherein said database manager software application comprises an optimization tool, and wherein each marketing event from said first list comprises a marketing offer and an identified channel means for communicating said marketing offer, said method comprising the steps of:
optimizing by said optimization tool, said marketing events from said first list for a first candidate from said second list; and
sorting by said optimization tool, said marketing events from said first list for said first candidate from said second list.
The present invention advantageously provides a system and associated method to implement a simple procedure to sell a plurality of services to a customer.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 illustrates a block diagram view of a database system for dynamically ordering a plurality of outbound marketing events for offering marketing offers to a candidate, in accordance with embodiments of the present invention.
FIG. 2 illustrates a flowchart comprising an algorithm used by database system of FIG. 1 for dynamically ordering a plurality of outbound marketing events for offering to marketing offers to a candidate, in accordance with embodiments of the present invention.
FIG. 3 illustrates a computer system used for implementing the database system for dynamically ordering a plurality of marketing events for offering marketing offers to a candidate, in accordance with embodiments of the present invention.
DETAILED DESCRIPTION OF THE INVENTION
FIG. 1 illustrates a block diagram view of a database system 2 for dynamically ordering a list identifying a plurality of outbound marketing events for offering marketing offers to a candidate, in accordance with embodiments of the present invention. Each marketing event from the list comprises a marketing offer and an identified channel means for communicating the marketing offers to a candidate. For example, a marketing event may comprise a 1.9% APR introductory interest rate for a 12 month period on a credit card, delivered to the candidate through direct mail. A marketing event may either comprise a growth (new marketing offer) marketing event or a retention (existing product like an existing credit card to be retained) marketing event. A marketing offer is defined herein as an offer from an entity (e.g., a business) for a product or service to be extended to a customer or potential customer (i.e., candidate). The product or service may comprise an incentive to entice the customer or potential customer to accept the offer. For example, the marketing offer may comprise a credit card offer that will provide an APR that is lower than the normal for a specified period of time as an incentive, such as, inter alia, 1.9% APR for the first 12 months if the credit card is accepted. A candidate may be an existing customer of the entity and a potential customer for the marketing offer. For example, an individual, a business, etc. A channel is a means to contact the candidate. For example, e-mail, direct mail, text message, telephone, etc. An outbound marketing event comprises a marketing event where an initial contact is made by an entity to offer the marketing event to a candidate. The database system 2 is used by an entity (e.g., a business such as a bank) comprising an existing customer database to sequentially order and optimize outbound marketing events (herein referred to marketing events) for offering to candidates from the existing customer database. The database system 2 comprises database structures 10, 12, 14, 15, 18, and 21 and a database manager software application 19. The database manager software application 19 is a single database manager software application (i.e., one software application as opposed to multiple software applications). The database manager software application 19 may comprise any type of database management software application including, inter alia, DB2 database management system by IBM, etc. The database manager software application 19 comprises a computing tool 6 and an optimization tool 8 (i.e., software components). Using a single database manager software application (i.e., database manager software application 19) comprising multiple software components (i.e., computing tool 6 and an optimization tool 8) is advantageous over using a plurality of individual database manager software applications (e.g., a first individual database manager software application comprising a computing tool and a second individual database manager software application comprising an optimization tool) because communications between components of single database manager software application (e.g., computing tool 6 and an optimization tool 8) are faster and more efficient than communications between multiple individual database manager software applications. Communications between components of a single database manager software application are faster and more efficient than communications between multiple individual database manager software applications because data (for manipulation) only has to be moved within a single software application and does not have to be moved from one software application to another software application. Therefore functions performed on the data (e.g., calculations, optimizations, etc) are performed faster and more efficiently by a single database manager software application than by multiple database manager software applications. Each of database structures 10, 12, 14, 15, 18, and 21 may be individual database structures within the database system 2. Alternatively, each of database structures 10, 12, 14, 15, 18, and 21 may be tables or sections within a single database structure (e.g., as illustrated in FIG. 1). Database structure 10 comprises customer (i.e., candidate) data including, inter alia, a list of candidates, data models using any customer past history data (e.g., credit card balances, past spending habits, etc.), etc. The customer (i.e., candidate) data comprises information about all of the entity's customers, current or prospective. This data may be compiled from any standard source including, inter alia, an existing marketing database containing data regarding active customers of the entity. The customer data primarily comprises behavioral data (e.g., purchasing history, returned-items history, payment history, etc), promotional (i.e., marketing events) history (e.g., past marketing events offered to a candidate including information regarding which marketing events were accepted by the candidate), and demographic data regarding the candidate. Database structure 10 additionally comprises a predetermined total budget for each candidate regarding an amount of money that the entity offering the marketing events is willing to spend to offer a plurality of marketing events to the candidate. Database structure 12 comprises the marketing offers. Database structure 12 additionally comprises a predetermined value score associated with each marketing offer. A value score is a numerical score (e.g., in dollars) representing an expected profit gain to be produced by a marketing offer from a candidate accepting and executing the marketing offer. Database structure 12 additionally comprises drop date data for each of the marketing offers. A drop date is an origin date for offering the marketing offer. Database structure 14 comprises constraint data regarding the marketing offer(s) as applied to a candidate. Constraint data comprises constraints that are associated with offering a marketing offer to a candidate. For example, constraint data may include, inter alia, an amount of money regarding execution costs for offering the marketing offer to a candidate (i.e., an amount that the entity has determined that they are willing is to spend to offer the marketing event to the candidate), a maximum number of offerings for a marketing event (e.g., how many times a marketing event is offered to a candidate), timing between offers, etc. Execution costs comprise costs associated with using each of the channels in the channels database structure 18. Execution costs may comprise, inter alia, costs for promotional materials, mailing costs, telemarketing costs, infrastructure costs, etc. Database structure 18 comprises data regarding channels that may be used to communicate the marketing offer to a candidate (e.g., e-mail, direct mail, text message, telephone, etc.). The computing tool 6 applies the data from database structure 18 to the marketing offers from database structure 12 to create a plurality of marketing events stored in database structure 21. The computing tool 6 uses data supplied from the database structures 10 and 12 to compute response probability scores and ranking scores for each of the marketing events from database structure 21 with respect to each of the candidates. The response probability scores are for determining a probability that a candidate(s) will respond to each of the marketing events. In other words, the response probability scores determine a probability that a candidate will respond to and accept a marketing event within a specified time frame. The response probability scores are calculated using the data models comprising any candidate past history data (e.g., credit card balances, past spending habits, etc.). The ranking score is computed as a function of a value score with respect to a response probability score (e.g., by multiplying a value score for a marketing event with a response probability score for a candidate). Each ranking score is associated with a marketing event for a specific candidate. The ranking scores are used to order the marketing events from highest rank to lowest rank to determine an order in which to offer the plurality of marketing events to the specific candidate. The optimization tool 8 sorts the ranking scores for the marketing events from database structure 21 (e.g., from highest rank to lowest rank) for the candidate and a ranking list is created. The optimization tool 8 uses data from the database structure 14 to apply constraint data (e.g., timing constraints, budget constraints, etc.) to each of the ranking scores on the ranking list for a candidate. The optimization tool 8 applies timing constraints to each of the ranking scores for each of the candidates. The timing constraints eliminate any marketing events that comprise timing conflicts between marketing events. For example, the optimization tool 8 will take the highest ranked marketing event (first marketing event) and compare it to the next highest ranked marketing event (second marketing event). If the two marketing events comprise a same type of marketing event (e.g., both marketing events comprise a credit card offer), then the optimization tool looks for a timing conflict. For example if the first marketing event is to be offered to the candidate every 30 days and the second marketing event is to be offered every 30 days then the second marketing event is eliminated from the ranking list because the two marketing events are same type of marketing event and should not be received by the candidate at the same time. The optimization tool 8 will continue to apply the timing constraints to each of the marketing events on the ranking list. Marketing events comprising timing conflicts are eliminated from the ranking list. The optimization tool 8 then applies monetary (i.e., budget) constraints to the value scores that remain on the ranking list and subtracts the monetary constraints from the predetermined budgeted execution costs for offering the marketing event to the candidate. The predetermined budgeted amount comprises an amount of money for execution costs that the entity has determined that they are willing is to spend to offer a plurality of marketing events to the candidate. For example, each time a marketing event is offered to a candidate, the execution costs are deducted from the budgeted amount, and once the budget is exceeded, the optimization tool 8 will eliminate any remaining marketing events from the ranking list. The final ranking list comprises marketing events that have not been eliminated and a specified order for offering the marketing events to the associated candidate. The final ranking list comprising the optimized and sorted marketing events is stored in the database structure 15.
Table 1 illustrates an example of sorted ranking scores with constraint data applied and subtracted from the budget.
TABLE 1
|
|
Ranking score
Constraint data
Budget
|
|
$50
$10
$30
|
$40
$5
$20
|
$30
$10
$15
|
$20
$5
$5
|
$10
$10
$0
|
|
The first row comprises the highest ranked marketing event ($50 rank). The total budget is $30 and the associated constraint data is $10. The constraint data ($10) is subtracted from the budget ($30) for the highest ranked marketing event leaving $20 in the budget for offering more marketing events to the candidate. The second row comprises the next ranked marketing event ($40 rank). The constraint data ($5) is subtracted from the budget ($20) for the next ranked marketing event ($40 rank) leaving $15 in the budget offering more marketing events to the candidate. The optimization tool goes through each ranked marketing event until there is no more money left in the budget (See row 5) thereby eliminating any more offerings for marketing events. The first four rows comprise the marketing events to be offered sequentially to the candidate. The fifth row comprises an eliminated marketing event due to an exhausted budget ($0).
An example of an implementation for the database system 2 of FIG. 1 for dynamically ordering marketing events for a candidate is described as follows. This example comprises six marketing offers and four channels.
Marketing Offers
- 1. A Mortgage Offer
- 2. A Credit Card offer
- 3. A Household insurance offer
- 4. An Auto insurance offer
- 5. A Platinum Credit Card
- 6. A low rate loan offer
Channels
- 1. Mail
- 2. Email
- 3. Outbound telephone call
- 4. Text message
The 6 marketing offers are multiplied by the 4 channels to produce 24 marketing events. Each marketing event comprises a drop date and therefore a calendar of events. A first candidate is scored for each of the 24 marketing events with propensity to respond (i.e., a response probability score) to each of the marketing events. All 24 response probability scores are calculated in parallel and each score comprises a range between 0 and 1 with 1 comprising the highest propensity to respond to a marketing event and 0 comprising the lowest propensity to respond to a marketing event. Each of the marketing events comprises an expected profit gain (i.e., value score). For example, if the marketing offer is a mortgage offer, the expected profit margin (i.e., value score) may be calculated based on an annual return of repayments vs. infrastructure costs balanced against the risk of the candidate defaulting on the mortgage vs. prepayment of mortgage before the term is up (although the mortgage may be loaded with a prepayment penalty clause to protect a revenue stream). A ranking score for each of the 24 marketing events is calculated as a function of a value score for each marketing event with respect to a response probability score for the associated marketing event with respect to the first candidate. The aforementioned process is performed by a computing tool (e.g., computing tool 6 in FIG. 1). An optimization tool (e.g., optimization tool 8 in FIG. 1) sorts the 24 marketing events from highest ranking scores to lowest ranking scores. The optimization tool applies constraint data including timing constraints and monetary constraints (i.e., verses budget) to the 24 marketing events. The constraint data is applied to the 24 marketing events starting with the highest ranked marketing event to the lowest ranking marketing event and ultimately an optimized execution list is produced comprising a stream of marketing events that the first candidate will receive. As an alternative, the marketing events may be ordered and optimized by the optimization tool 8 without using value scores, response probability scores, and ranking scores. Additionally, the marketing events may be ordered and optimized by the optimization tool 8 using any combination of the value scores, response probability scores, and ranking scores.
FIG. 2 illustrates a flowchart comprising an algorithm used by database system 2 of FIG. 1 for dynamically ordering a plurality of marketing events for offering to a candidate, in accordance with embodiments of the present invention. In step 22, the computing tool 6 retrieves candidate data for a first candidate and marketing offers to offer to the first candidate and applies channel data to create a plurality of marketing events for the first candidate. In step 23, the computing tool 6 calculates value scores and response probability scores associated with the marketing events as described with respect to FIG. 1, supra. In step 24, ranking scores for the marketing events are calculated and sorted (i.e., the ranking scores for the marketing events are sorted from a highest rank to lowest rank for the first candidate) by the computing tool 6. The ranking scores are calculated by multiplying each value score with an associated response probability score as described with respect to FIG. 1, supra. In step 25, the optimization tool 8 generates and stores a ranking list. In step 26, the optimization tool 8 determines a date for offering each of the marketing events as described with respect to FIG. 1, supra. In step 27, the optimization tool 8 applies timing constraints to each of the ranking scores for the first candidate. The timing constraints eliminate any marketing events that comprise timing conflicts. In step 28, the optimization tool 8 determines if any of the marketing events comprise a same type of marketing offer as described with respect to FIG. 1, supra. In step 29, the optimization tool 8 removes any marketing events (i.e., based on results of step 27 and step 28) from the ranking list that comprise timing conflicts as described with respect to FIG. 1, supra. In step 32, the optimization tool 8 applies monetary constraints to the value scores that remain after the timing constraints have been applied and subtracts the monetary constraints from the predetermined budgeted execution costs for offering the marketing event to the first candidate. In step 34, the optimization tool 8 removes marketing events and associated ranking scores from the ranking list based on results of step 32 as described with respect to FIG. 1, supra. In step 37, the optimization tool 8 ranks any remaining ranking scores described with respect to FIG. 1, supra. In step 40, a final ranking list is created as a result of execution of steps 27, 28, 29, 32, 34, and 37. Note that steps 27, 28, 29, 32, 34, and 37 may be performed in any order. The final ranking list comprises marketing events that have not been eliminated (i.e., by timing and monetary constraints). The final ranking list comprises a specified order for offering the marketing events to the first candidate. Ranking a plurality of marketing events for the first candidate may be done in parallel. Additionally, ranking a plurality of marketing events for a plurality of candidates may be done in simultaneously in parallel.
FIG. 3 illustrates a computer system 90 used for implementing the database system 2 of FIG. 1 for dynamically ordering a plurality of marketing events for offering to a candidate, in accordance with embodiments of the present invention. The computer system 90 comprises a processor 91, an input device 92 coupled to the processor 91, an output device 93 coupled to the processor 91, and memory devices 94 and 95 each coupled to the processor 91. The input device 92 may be, inter alia, a keyboard, a mouse, etc. The output device 93 may be, inter alia, a printer, a plotter, a computer screen, a magnetic tape, a removable hard disk, a floppy disk, etc. The memory devices 94 and 95 may be, inter alia, a hard disk, a floppy disk, a magnetic tape, an optical storage such as a compact disc (CD) or a digital video disc (DVD), a dynamic random access memory (DRAM), a read-only memory (ROM), etc. The memory device 95 includes a computer code 97. The computer code 97 includes an algorithm for dynamically ordering a plurality of marketing events for offering to a candidate. The processor 91 executes the computer code 97. The memory device 94 includes input data 96. The input data 96 includes input required by the computer code 97. The output device 93 displays output from the computer code 97. Either or both memory devices 94 and 95 (or one or more additional memory devices not shown in FIG. 3) may comprise the database system 2 of FIG. 1 and may be used as a computer usable medium (or a computer readable medium or a program storage device) having a computer readable program code embodied therein and/or having other data stored therein, wherein the computer readable program code comprises the computer code 97. Generally, a computer program product (or, alternatively, an article of manufacture) of the computer system 90 may comprise said computer usable medium (or said program storage device).
Thus the present invention discloses a process for deploying or integrating computing infrastructure, comprising integrating computer-readable code into the computer system 90, wherein the code in combination with the computer system 90 is capable of performing a method used for dynamically ordering a plurality of marketing events for offering to a candidate.
While FIG. 3 shows the computer system 90 as a particular configuration of hardware and software, any configuration of hardware and software, as would be known to a person of ordinary skill in the art, may be utilized for the purposes stated supra in conjunction with the particular computer system 90 of FIG. 3. For example, the memory devices 94 and 95 may be portions of a single memory device rather than separate memory devices.
While embodiments of the present invention have been described herein for purposes of illustration, many modifications and changes will become apparent to those skilled in the art. Accordingly, the appended claims are intended to encompass all such modifications and changes as fall within the true spirit and scope of this invention.