WO2000007354A9 - Decision network based event pricing system in a component based, object oriented convergent customer care and billing system - Google Patents

Decision network based event pricing system in a component based, object oriented convergent customer care and billing system

Info

Publication number
WO2000007354A9
WO2000007354A9 PCT/US1999/016790 US9916790W WO0007354A9 WO 2000007354 A9 WO2000007354 A9 WO 2000007354A9 US 9916790 W US9916790 W US 9916790W WO 0007354 A9 WO0007354 A9 WO 0007354A9
Authority
WO
WIPO (PCT)
Prior art keywords
event
algorithm
plan
price plan
select
Prior art date
Application number
PCT/US1999/016790
Other languages
French (fr)
Other versions
WO2000007354A1 (en
Inventor
Stuart Boardman
Andreas Ruebesam
Original Assignee
American Management Systems In
Stuart Boardman
Andreas Ruebesam
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by American Management Systems In, Stuart Boardman, Andreas Ruebesam filed Critical American Management Systems In
Priority to AU53204/99A priority Critical patent/AU5320499A/en
Priority to CA002302366A priority patent/CA2302366A1/en
Priority to EP99938799A priority patent/EP1101350A1/en
Publication of WO2000007354A1 publication Critical patent/WO2000007354A1/en
Publication of WO2000007354A9 publication Critical patent/WO2000007354A9/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q40/00Finance; Insurance; Tax strategies; Processing of corporate or income taxes
    • G06Q40/12Accounting
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/28Databases characterised by their database models, e.g. relational or object models
    • G06F16/289Object oriented databases
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0283Price estimation or determination
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0283Price estimation or determination
    • G06Q30/0284Time or distance, e.g. usage of parking meters or taximeters
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/04Billing or invoicing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/06Buying, selling or leasing transactions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/43Billing software details
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/44Augmented, consolidated or itemized billing statement or bill presentation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/49Connection to several service providers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/51Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP for resellers, retailers or service providers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/52Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP for operator independent billing system
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/70Administration or customization aspects; Counter-checking correct charges
    • H04M15/745Customizing according to wishes of subscriber, e.g. friends or family
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/80Rating or billing plans; Tariff determination aspects
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/80Rating or billing plans; Tariff determination aspects
    • H04M15/8044Least cost routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/80Rating or billing plans; Tariff determination aspects
    • H04M15/8083Rating or billing plans; Tariff determination aspects involving reduced rates or discounts, e.g. time-of-day reductions or volume discounts
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M15/00Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP
    • H04M15/90Arrangements for metering, time-control or time indication ; Metering, charging or billing arrangements for voice wireline or wireless communications, e.g. VoIP using Intelligent Networks [IN] or Advanced Intelligent Networks [AIN]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/01Details of billing arrangements
    • H04M2215/0104Augmented, consolidated or itemised billing statement, e.g. additional billing information, bill presentation, layout, format, e-mail, fax, printout, itemised bill per service or per account, cumulative billing, consolidated billing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/01Details of billing arrangements
    • H04M2215/0108Customization according to wishes of subscriber, e.g. customer preferences, friends and family, selecting services or billing options, Personal Communication Systems [PCS]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/01Details of billing arrangements
    • H04M2215/0152General billing plans, rate plans, e.g. charge rates, numbering plans, rate centers, customer accounts
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/01Details of billing arrangements
    • H04M2215/016Billing using Intelligent Networks [IN] or Advanced Intelligent Networks [AIN]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/01Details of billing arrangements
    • H04M2215/0168On line or real-time flexible customization or negotiation according to wishes of subscriber
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/01Details of billing arrangements
    • H04M2215/0184Details of billing arrangements involving reduced rates or discounts, e.g. time-of-day reductions, volume discounts, cell discounts, group billing, frequent calling destination(s) or user history list
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/42Least cost routing, i.e. provision for selecting the lowest cost tariff
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/46Connection to several service providers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/54Resellers-retail or service providers billing, e.g. agreements with telephone service operator, activation, charging/recharging of accounts
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2215/00Metering arrangements; Time controlling arrangements; Time indicating arrangements
    • H04M2215/74Rating aspects, e.g. rating parameters or tariff determination apects
    • H04M2215/745Least cost routing, e.g. Automatic or manual, call by call or by preselection

Definitions

  • the present invention is directed to using a decision network to evaluate a Price Plan and an Event rating for rating customer transactions, and, more particularly, to a system that rates and/or discounts Events based on business rules stored in a Price Plan database.
  • a plan selection rule set is used to select a Price Plan for the Event and an Algorithm rule set is used to select an Algorithm to rate the Event.
  • Conditions are also evaluated as the rule sets are traversed and include a program that determines if an
  • Figure 1 illustrates a plan selection rule set of a decision network.
  • Figure 2 illustrates an Algorithm selection rule set of a decision network.
  • Figure 3 depicts a preferred platform.
  • Figure 4 shows process architecture
  • Figure 5 depicts a process for rating an Event.
  • Figure 6 depicts processing a Price Plan.
  • Figure 7 depicts processing an Algorithm.
  • Figure 8 depicts evaluating a Condition.
  • the present invention introduces the use of decision networks to facilitate complex Price Plan structures used to rate and/or discount Events.
  • Price Plans provide the supplier with the possibility of defining pricing models or structures used to rate Events. Price Plans also provide flexibility in changing a pricing model to meet market demands quickly.
  • An Event represents a transaction between a supplier and a customer. Examples of Events in the telecommunications industry are phone calls, monthly line fees or installation charges.
  • decision networks are used to determine what Price Plan to use for an Event and how to rate the Event based on business rules. These business rules can be implemented or changed without any modifications to code by changing the decision networks. All business rules are stored in the Price Plan database. This Price Plan structure is suitable for real time or batch processing.
  • decision networks to implement Price Plan rules provides the business with the competitive advantage of creating complex pricing models attractive to its customers.
  • the Event-pricing concept can be applied to any business domain where customers are billed for transactions that can be represented as Events. All examples herein are in the telecommunications industry domain. Further examples of business areas where using decision networks to implement Price Plan for Events is applicable include Internet Service Providers, Utilities Companies and Video On-Demand Services. Two types of decision networks are used, a Plan Selection
  • the Plan Selection Rule set essentially guides the Event to Price Plans.
  • the Algorithm Selection Rule Set is within the Price Plan and guides the Event to Algorithms.
  • An Algorithm calculates a price or modifies a price (applies a discount).
  • An Event can be priced by multiple Price Plans.
  • the Plan Selection Rule Set 10 (see Figure 1) is used to determine processing order and select the Price Plans, which should be used to rate and price the Event.
  • the Plan Selection Rule Set 10 effectively manages the dependencies between Price Plans, manages exclusion relationships and enables multiple prices to be applied according to specific rules.
  • Nodes, such as 12 and 14, in the Plan Selection Rule Set decision network are called Plan Selection Rules.
  • a Plan Selection Rule represents either a Condition 16 to be evaluated or a Price Plan 18 to be executed.
  • An example of a Condition is checking whether a telephone call is a fixed wire call or a cellular call.
  • An example of a Price Plan is a pricing structure for all fixed wire calls that discounts international calls to Sweden depending on the time the call is made.
  • Each node in the set 10 contains two pointers to child nodes, one (20) for a positive branch (TRUE) and one (22) for a negative branch (FALSE). Depending on the return value of the Condition or the Price Plan, the next node is selected.
  • TRUE positive branch
  • FALSE negative branch
  • a Price Plan returns TRUE if the Event qualified for the Price Plan, FALSE if the Event didn't qualify for the Price Plan.
  • qualification refers to whether an Event received a rating by a Price
  • Each Price Plan 30 ( Figure 2) contains an Algorithm Selection
  • Algorithm Selection Rule used to determine the appropriate Algorithm(s) to be performed once an Event has reached the Price Plan. This arrangement provides an additional level of nested decision networks.
  • the nodes 32 and 34 in the Algorithm Selection Rule Set 30 decision network are called Algorithm Selection Rules.
  • An Algorithm Selection Rule represents either a Condition 36 to be evaluated or an Algorithm 38 to be applied to the Event.
  • An example of an Algorithm is assigning rates to an Event according to the call duration and depending on the week day the call is made.
  • Each node contains two pointers 40 and 42 to child nodes, one for a positive branch (TRUE) and one for a negative branch (FALSE). Depending on the return value of the Condition, the next node is selected.
  • TRUE positive branch
  • FALSE negative branch
  • Algorithm always returns TRUE because the Algorithm is applied to each Event that is guided to the Algorithm.
  • a node with no successors where the next node Id is set to NULL 44
  • control returns to the calling node in the Plan Selection Rule Set.
  • the number of nodes will depend upon the complexity of the Plan and the manner in which the user formulated the plan.
  • Algorithm Selection Rules 30 are preferably not recursive (i.e., a Plan should not consist of other Plans).
  • Conditions are preferably expressed in textual form using a configuration language.
  • a conventional configuration language can be used, however, it is preferred that the Meta Language as discussed in the related application noted previously be used.
  • the use of a meta-language allows efficient configuration or reconfiguration of the rules for selecting and executing Price Plans.
  • Each Condition contains source code for a small program able to determine if the Event being processed qualifies for that
  • CML Condition or not.
  • Conditions may relate to the attributes indirectly through the use of Sensitivities. Sensitivities are sets of mutually exclusive Conditions referring to one or more attributes in the Event, Service or Customer objects.
  • Sensitivities provide a way of handling multiple and mutually exclusive Conditions. Each Condition is associated with a Domain which is a value assigned to the Event for which the given Condition results true. This way, a Condition using Sensitivities will check for the domain of a Sensitivity instead of specifying all the Conditions that constitute that Sensitivity.
  • the Sensitivity PeakHours could consist of the following three
  • PeakHours IS Off-Peak To determine whether a call has taken place in off peak hours the sensitivity "PeakHours IS Off-Peak" can be used to specify all
  • a memory cache is preferably used to keep the compiled versions of Conditions.
  • Algorithms include Processes or Operations. Each Process corresponds to a Calculation to be performed for a Price Plan and a related
  • a Tariff Model Area is a grouping of rates and associated
  • Tariff Model Sensitivities that collectively can be used in a Price Plan. For example, if local calls cost .10/min., intrastate calls .12/min and interstate calls .15/min., then the collection of these numeric rates and associated sensitivities (in this case call types) is called a Tariff Model Area. This collection (essentially a rate structure) can be reused in many Price Plans, if applicable.
  • the Tariff Model Area provides the calculation option values used to rate an Event depending on Tariff Model Sensitivities.
  • Tariff Model Sensitivities can be used to define zones (area codes), tariff weeks (peek/off- peek times), and bands for tier and taper discounting.
  • a Price Plan may consist of several Algorithms, each one used to rate different types of Events (e.g., a plan contains an Algorithm for rating calling card calls, and a separate
  • a process checks whether a Detail or Summary calculation is required for a Process Step. Detail Calculations are executed immediately. Summary Calculations, e.g., Tier Discount, are performed at the end of the bill period. It is possible that an Event is rated by more than one Process within an Algorithm. This is referred to as a flow of charges. Every process step, when specifying a detail calculation, has an Add/Replace indicator. If the indicator is set to Add, the calculated result is added to the charge for the Event before the calculation was executed. Otherwise, the result of the calculation replaces the previous charge.
  • a rating and summarization engine application of the invention is preferably implemented in a two-tier client server system 60, as depicted in Figure 3.
  • An application server component 64 is preferably implemented using C++ running on a HP-UNIX platform.
  • the system 60 uses an Oracle database system on a database server 66 to store persistent objects.
  • the processes of the present invention can be stored and distributed on a storage medium, such as a disc, and can also be distributed over a network, such as the Internet.
  • Figure 4 depicts the relationship of the present invention to a preferred software architecture.
  • a Rater and Summarizer 80 is responsible for all real-time rating and the accumulation of Event information for end of bill period rating and pricing.
  • the Rater and Summarizer 80 is an Event driven system.
  • An RAS Application process 82 is the main application for the Rater and Summarizer 80. This application 82 handles all the input/output streams in the rating process e.g.- the Event files and the interfaces to the databases.
  • the RAS Application process 82 receives Events that require rating in the form of unrated Events files created by Duplicate Event Check and Assemble Event process 84 and the Recurring Charges process 86. Further, the RAS
  • the Application process 82 receives Events that need to be re-rated from the Re- Rater process 88.
  • the RAS Application process 82 retrieves bill information necessary for the process from a Custom Bill Manager (CBM) application 90.
  • CBM Custom Bill Manager
  • One Event after another is retrieved from the input files and sent to the RAS Guiding process 92.
  • the RAS Guiding process 92 performs the guiding of an
  • the RAS Guiding process 92 retrieves required customer information from the Customer Care Manager application 94 and the Product Service Manager application 96. Once the guiding is complete, the guided Event is sent back to RAS Application process 82, which in turn sends the still unrated Event to an RAS Engine process 98.
  • the RAS Engine process 98 rates and discounts the Event according to the business rules configured in the Product Service Manager application 96. The process of rating an Event is explained in greater detail in figures 5 through 8. Once an Event is rated, the RAS Engine process 98 sends the rated Event and corresponding summary information back to RAS Application process 82.
  • the RAS Application process 82 sends the rated Event to an Event Taxer process 100.
  • the Event Taxer 100 applies the correct tax rate to the Event and sends the taxed Event to RAS Application process 82.
  • the RAS Application process 82 now sends the rated and taxed Event to a Database Event Manager 102 and the summary Events to a Event Summary Database 104.
  • a process 130 performed by the present invention is performed for each Event to be rated by the system.
  • the process 130 once started 132, retrieves 134 the currently effective Plan
  • the first Plan Selection Rule is retrieved 136 from Repository 96 for the Plan Selection Rule Set.
  • the next operation is to evaluate the rule to determine 138 and 140 if it represents a null rule, a Condition or a Price Plan. If the rule represents a Condition, the Condition is retrieved and then evaluated 142 as shown in
  • Figure 8 If the Condition evaluates to TRUE 144, the Plan Selection Rule for the positive branch is retrieved 146. If the Condition evaluates to FALSE, the Plan Selection Rule for the negative branch is retrieved 148. If the rule represents a Price Plan, the Price Plan is retrieved and then processed 150 as described with respect to Figure 6. If the Event qualified for the Price Plan, the Plan Selection Rule for the positive branch is retrieved 146. If the Event did not qualify for the Price Plan, the Plan Selection Rule for the negative branch is retrieved 148. The processing of Plan Selection Rules continues until no further rules are found (i.e., a null is reached). Figure 6 depicts the processing 150 of a Price Plan. This process is executed for each Price Plan found when executing the rate Event Algorithm.
  • This process retrieves 174 the currently effective Algorithm Selection Rule Set for the Price Plan from the Repository 96. Then, the first Algorithm Selection Rule is retrieved 176 for the Algorithm Selection Rule Set from the Repository 96. The next operation is to evaluate 178 and 180 if the rule is null, represents a Condition or an Algorithm. If the rule represents a Condition, the Condition is retrieved and then evaluated 182 as described in more detail with respect to Figure 8. If the Condition evaluates 184 to TRUE, the Algorithm Selection Rule for the positive branch is retrieved 186. If the Condition evaluates to FALSE, the Algorithm Selection Rule for the negative branch is retrieved 188.
  • the Algorithm is retrieved 190 and then processed as described in more detail in Figure 7. For all cases, the Plan Selection Rule for the positive branch is retrieved. The processing of Algorithm Selection Rules continues until no further rules are found.
  • FIG. 7 depicts the process 190 performed for each Algorithm found when processing the Process Price Plan Algorithm of Figure 6.
  • Each Algorithm consists of one or many process steps.
  • the process 190 once started 212, retrieves 214 the first Process Step from the Repository 96. It is then evaluated to determine 216 whether the Process Step represents a Summary or a Calculation. If the Process Step represents a Summary, a selection of Event attributes are added 218 to a corresponding summary record and the applicable summary flags are set on the Event. Attributes that are summarized include the quantity of the Event (how many kilobytes, or packets, or calls, or pages, or whatever, depending upon the unit of measure), the duration of the Event (minutes or seconds, etc.), and any associated charges.
  • the Process Step represents a Calculation
  • the Calculation is executed 220.
  • a simple example of a Calculation is a Single Unit Calculation. In different uses, this provides a charge per unit, where the unit may be any unit of measure. A rate of $.10 per min is a Single Unit Calculation, so is .06 per call, so is .12 per kilobit. Another good example is the Percent Discount Calculation, which gives a 10% discount, or a 20% discount, etc., upon the charge it acts upon.
  • the calculated charge is then added 222 to the existing Event charge or used to replace the existing Event charge. The system then tests 224 to determine if more steps are necessary and returns for more process steps if so.
  • the process 142/182/220 depicted in Figure 8 is performed, like a subroutine, for each Condition found when processing the Rate Event or Process Price Plan Algorithms of Figures 5-7.
  • the process once started 242, retrieves 244 the Evaluator object. Then the CML program associated with the Condition is located and the evaluated 246 to determine if the program requires compilation.
  • the programs associated with Conditions are preferably written using the business specific meta-language mentioned previously although other meta-languages can be used.
  • the meta-language programs are compiled and executed on a virtual machine to enhance execution performance. For performance reasons, previously compiled programs are kept in a cache.
  • the meta-language programs can be modified at run time and no changes to C++ application code are necessary.
  • the program is compiled 250.
  • the values required to evaluate the Condition are retrieved 252 from the Event. If the Condition contains 254 a Sensitivity the Evaluator context is set 256 accordingly and the Algorithm is called recursively. To prevent infinite recursion, Sensitivities preferably do not contain further Sensitivities.
  • the Condition is then evaluated 258 and the result is fetched 260 from the program.
  • Algorithm can be modified without touching any application core code.
  • the modified program will automatically be used by any Plan Selection Rule Set 10 and any Algorithm Selection Rule Set 30 referring to the particular Condition.
  • the Condition, or Sensitivity for that matter, that is used to determine Peak and Off-Peak hours can be modified in the metalanguage program.
  • the logic executed when the Condition is evaluated, as part of a Plan Selection Rule Set 10 and an Algorithm Selection Rule Set 30, is replaced by the modified program.
  • the changing of a Algorithm, Condition or Sensitivity typically involves accessing the meta-language program.
  • the program can be kept as reference data in the database or in files associated with the database.
  • Changing an Algorithm or an Tariff Model Area/Tariff Model Area Sensitivity typically involves the use of SQL scripts.
  • a conventional text editor is used by a designer/programmer to edit the text of the Algorithm, Sensitivity, Condition or SQL script to change the logic or parameters. Changes in a decision network sequence are made by changing the pointers in the network from one node to another node. As can be seen, changes in both the logic of the decision networks and the logic of Conditions, Sensitivities and Algorithms can be accomplished without changing core code.
  • the present invention has been described with respect to a preferred platform.
  • the platform or programming languages used can, of course, be varied.
  • a commercial rules engine could also be used to interpret Price Plan rules.
  • application code can be used instead of meta- language programs.
  • the Event-pricing of the present invention can also be applied to any business domain where customers are billed for transactions that can be represented as Events.

Abstract

A ratings engine system that uses decision networks to select and execute Price Plans to rate an Event. A plan selection rule set is used to select a Price Plan for the Event and an Algorithm rule set is used to select an Algorithm to rate the Event. The Price Plans and rule sets are stored in a database. Conditions are also evaluated as the rule sets are traversed and include a program that determines if an Event qualifies for the Condition. Conditions can have a range or domain of applicability. The changing of the decision network changes the business rules for the Event without changing the Algorithms or Conditions.

Description

Decision Network Based Event Pricing System
In A Component Based, Object Oriented Convergent Customer Care And Billing System
Cross Reference to Related Applications This application is related to and claims priority to U.S. provisional application serial number 60/094,459, filed July 29, 1998, entitled Component Based, Object Oriented Convergent Customer Care And Billing System by Hohmann et. al. and which is incorporated herein by reference. This application is also related to concurrently filed U.S. application entitled Meta-Language For C++ Business Applications by Hohmann and
Duymelinck, having S&H docket number 1330.1049 and which is incorporated herein by reference.
BACKGROUND OF THE INVENTION Field of the Invention
The present invention is directed to using a decision network to evaluate a Price Plan and an Event rating for rating customer transactions, and, more particularly, to a system that rates and/or discounts Events based on business rules stored in a Price Plan database. Description of the Related Art
Flexible pricing plans are becoming ever more important in satisfying the needs of customers. Conventional pricing plans use simple hierarchical pricing structures, such as usage based pricing. Complex Price Plan structures are not suitable for such hierarchical arrangements. What is needed is a system that supports complex Price Plan structures used to rate Events.
SUMMARY OF THE INVENTION It is an object of the present invention to use decision networks to facilitate complex Price Plan structures used to rate and/or discount Events.
It is another object of the present invention to provide a system that supports conditional branching in a Price Plan.
It is a further object of the present invention to provide a business with the competitive advantage of creating complex pricing models attractive to the business customers.
It is an additional object of the present invention to provide a flexible solution for Price Plans that can be used in an environment that requires high performance, such as real time rating of telecommunications Events.
The above objects can be attained by a system that uses decision networks to execute a Price Plan to rate an Event. A plan selection rule set is used to select a Price Plan for the Event and an Algorithm rule set is used to select an Algorithm to rate the Event. Conditions are also evaluated as the rule sets are traversed and include a program that determines if an
Event qualifies for the Condition. These together with other objects and advantages which will be subsequently apparent, reside in the details of construction and operation as more fully hereinafter described and claimed, reference being had to the accompanying drawings forming a part hereof, wherein like numerals refer to like parts throughout.
BRIEF DESCRIPTION OF THE DRAWINGS
Figure 1 illustrates a plan selection rule set of a decision network.
Figure 2 illustrates an Algorithm selection rule set of a decision network.
Figure 3 depicts a preferred platform.
Figure 4 shows process architecture.
Figure 5 depicts a process for rating an Event.
Figure 6 depicts processing a Price Plan. Figure 7 depicts processing an Algorithm.
Figure 8 depicts evaluating a Condition.
DESCRIPTION OF THE PREFERRED EMBODIMENTS
The present invention introduces the use of decision networks to facilitate complex Price Plan structures used to rate and/or discount Events. Price Plans provide the supplier with the possibility of defining pricing models or structures used to rate Events. Price Plans also provide flexibility in changing a pricing model to meet market demands quickly. An Event represents a transaction between a supplier and a customer. Examples of Events in the telecommunications industry are phone calls, monthly line fees or installation charges. In the present invention, decision networks are used to determine what Price Plan to use for an Event and how to rate the Event based on business rules. These business rules can be implemented or changed without any modifications to code by changing the decision networks. All business rules are stored in the Price Plan database. This Price Plan structure is suitable for real time or batch processing. The use of decision networks to implement Price Plan rules provides the business with the competitive advantage of creating complex pricing models attractive to its customers. The Event-pricing concept can be applied to any business domain where customers are billed for transactions that can be represented as Events. All examples herein are in the telecommunications industry domain. Further examples of business areas where using decision networks to implement Price Plan for Events is applicable include Internet Service Providers, Utilities Companies and Video On-Demand Services. Two types of decision networks are used, a Plan Selection
Rule Set 10 and an Algorithm Selection Rule Set 30, examples of which are depicted in Figures 1 and 2, respectively, and which are conventionally traversed or processed. The Plan Selection Rule set essentially guides the Event to Price Plans. The Algorithm Selection Rule Set is within the Price Plan and guides the Event to Algorithms. An Algorithm calculates a price or modifies a price (applies a discount). An Event can be priced by multiple Price Plans.
The Plan Selection Rule Set 10 (see Figure 1) is used to determine processing order and select the Price Plans, which should be used to rate and price the Event. The Plan Selection Rule Set 10 effectively manages the dependencies between Price Plans, manages exclusion relationships and enables multiple prices to be applied according to specific rules. Nodes, such as 12 and 14, in the Plan Selection Rule Set decision network are called Plan Selection Rules. A Plan Selection Rule represents either a Condition 16 to be evaluated or a Price Plan 18 to be executed. An example of a Condition is checking whether a telephone call is a fixed wire call or a cellular call. An example of a Price Plan is a pricing structure for all fixed wire calls that discounts international calls to Sweden depending on the time the call is made. Each node in the set 10 contains two pointers to child nodes, one (20) for a positive branch (TRUE) and one (22) for a negative branch (FALSE). Depending on the return value of the Condition or the Price Plan, the next node is selected. A Price Plan returns TRUE if the Event qualified for the Price Plan, FALSE if the Event didn't qualify for the Price Plan. Qualification refers to whether an Event received a rating by a Price
Plan or not. When an Event is processed by an Algorithm, it is qualified for the plan and the plan will return TRUE on exit. If an Event exits a Price Plan FALSE then the Event was not guided to an Algorithm. A Condition returns TRUE if the Condition evaluated to TRUE, if it evaluates to a false Condition, FALSE is returned. Processing of an Event is complete, when the pointer to the next node in the Plan Selection Rule Set is set to NULL 24. An Event would normally not reach a NULL 24 in the Plan Selection Rule Set without being priced. If such happens, the design of the Plan Selection Rule Set and/or the Price Plans is defective. Each Price Plan 30 (Figure 2) contains an Algorithm Selection
Rule Set used to determine the appropriate Algorithm(s) to be performed once an Event has reached the Price Plan. This arrangement provides an additional level of nested decision networks. The nodes 32 and 34 in the Algorithm Selection Rule Set 30 decision network are called Algorithm Selection Rules. An Algorithm Selection Rule represents either a Condition 36 to be evaluated or an Algorithm 38 to be applied to the Event. An example of an Algorithm is assigning rates to an Event according to the call duration and depending on the week day the call is made. Each node contains two pointers 40 and 42 to child nodes, one for a positive branch (TRUE) and one for a negative branch (FALSE). Depending on the return value of the Condition, the next node is selected. An Algorithm always returns TRUE because the Algorithm is applied to each Event that is guided to the Algorithm. When a node with no successors is encountered (where the next node Id is set to NULL 44) control returns to the calling node in the Plan Selection Rule Set. The number of nodes will depend upon the complexity of the Plan and the manner in which the user formulated the plan. Algorithm Selection Rules 30 are preferably not recursive (i.e., a Plan should not consist of other Plans).
Conditions are preferably expressed in textual form using a configuration language. A conventional configuration language can be used, however, it is preferred that the Meta Language as discussed in the related application noted previously be used. The use of a meta-language allows efficient configuration or reconfiguration of the rules for selecting and executing Price Plans. Each Condition contains source code for a small program able to determine if the Event being processed qualifies for that
Condition or not. An example of a CML Condition program is "Event.network==FIXED" which performs a comparison operation to determine if the network associated with the Event is fixed. The Conditions are based on attributes of the Event object, and/or the Service or Customer associated with the Condition. The values in these attributes can be combined in complex conditional expressions using logical (and, or, not) and comparison (<, >, ==, >=, <=, etc.) operators, defined in the CML grammar. Conditions may relate to the attributes indirectly through the use of Sensitivities. Sensitivities are sets of mutually exclusive Conditions referring to one or more attributes in the Event, Service or Customer objects.
Sensitivities provide a way of handling multiple and mutually exclusive Conditions. Each Condition is associated with a Domain which is a value assigned to the Event for which the given Condition results true. This way, a Condition using Sensitivities will check for the domain of a Sensitivity instead of specifying all the Conditions that constitute that Sensitivity. For example, the Sensitivity PeakHours could consist of the following three
Conditions:
1. Condition = CallStartTime > 08:00 and CallStartTime < 18:00 and
(DayOfWeek o Saturday and DayOfWeek o Sunday and DayOfWeek o
Holiday)
Domain = Peak
2. Condition = (CallStartTime < 08:00 or CallStartTime > 18:00) and
(DayOfWeek o Saturday and DayOfWeek o Sunday and DayOfWeek o
Holiday)
Domain = Off-Peak
3. Condition = DayOfWeek = Saturday or DayOfWeek == Sunday or
DayOfWeek = Holiday
Domain = Low
An example of a Condition using the Sensitivity defined above could be:
"PeakHours IS Off-Peak." To determine whether a call has taken place in off peak hours the sensitivity "PeakHours IS Off-Peak" can be used to specify all
Conditions necessary to formulate the determination logic. This provides reusability of complex Conditions that can be used across multiple Price
Plans. Because textual Conditions are preferably compiled at run-time to minimize the performance penalty associated with this process, a memory cache is preferably used to keep the compiled versions of Conditions.
Algorithms include Processes or Operations. Each Process corresponds to a Calculation to be performed for a Price Plan and a related
Tariff Model Area. A Tariff Model Area is a grouping of rates and associated
Tariff Model Sensitivities that collectively can be used in a Price Plan. For example, if local calls cost .10/min., intrastate calls .12/min and interstate calls .15/min., then the collection of these numeric rates and associated sensitivities (in this case call types) is called a Tariff Model Area. This collection (essentially a rate structure) can be reused in many Price Plans, if applicable. The Tariff Model Area provides the calculation option values used to rate an Event depending on Tariff Model Sensitivities. Tariff Model Sensitivities can be used to define zones (area codes), tariff weeks (peek/off- peek times), and bands for tier and taper discounting. A Price Plan may consist of several Algorithms, each one used to rate different types of Events (e.g., a plan contains an Algorithm for rating calling card calls, and a separate
Algorithm for rating regular direct dialed telephone calls).
A process checks whether a Detail or Summary calculation is required for a Process Step. Detail Calculations are executed immediately. Summary Calculations, e.g., Tier Discount, are performed at the end of the bill period. It is possible that an Event is rated by more than one Process within an Algorithm. This is referred to as a flow of charges. Every process step, when specifying a detail calculation, has an Add/Replace indicator. If the indicator is set to Add, the calculated result is added to the charge for the Event before the calculation was executed. Otherwise, the result of the calculation replaces the previous charge.
A rating and summarization engine application of the invention is preferably implemented in a two-tier client server system 60, as depicted in Figure 3. An application server component 64 is preferably implemented using C++ running on a HP-UNIX platform. The system 60 uses an Oracle database system on a database server 66 to store persistent objects. The processes of the present invention can be stored and distributed on a storage medium, such as a disc, and can also be distributed over a network, such as the Internet. Figure 4 depicts the relationship of the present invention to a preferred software architecture. A Rater and Summarizer 80 is responsible for all real-time rating and the accumulation of Event information for end of bill period rating and pricing. The Rater and Summarizer 80 is an Event driven system. An RAS Application process 82 is the main application for the Rater and Summarizer 80. This application 82 handles all the input/output streams in the rating process e.g.- the Event files and the interfaces to the databases. The RAS Application process 82 receives Events that require rating in the form of unrated Events files created by Duplicate Event Check and Assemble Event process 84 and the Recurring Charges process 86. Further, the RAS
Application process 82 receives Events that need to be re-rated from the Re- Rater process 88. The RAS Application process 82 retrieves bill information necessary for the process from a Custom Bill Manager (CBM) application 90. One Event after another is retrieved from the input files and sent to the RAS Guiding process 92. The RAS Guiding process 92 performs the guiding of an
Event to a particular account, that is, the account corresponding to the Event is identified. The RAS Guiding process 92 retrieves required customer information from the Customer Care Manager application 94 and the Product Service Manager application 96. Once the guiding is complete, the guided Event is sent back to RAS Application process 82, which in turn sends the still unrated Event to an RAS Engine process 98. The RAS Engine process 98 rates and discounts the Event according to the business rules configured in the Product Service Manager application 96. The process of rating an Event is explained in greater detail in figures 5 through 8. Once an Event is rated, the RAS Engine process 98 sends the rated Event and corresponding summary information back to RAS Application process 82. The RAS Application process 82 sends the rated Event to an Event Taxer process 100. The Event Taxer 100 applies the correct tax rate to the Event and sends the taxed Event to RAS Application process 82. The RAS Application process 82 now sends the rated and taxed Event to a Database Event Manager 102 and the summary Events to a Event Summary Database 104.
A process 130 performed by the present invention, as depicted in Figure 5, is performed for each Event to be rated by the system. The process 130, once started 132, retrieves 134 the currently effective Plan
Selection Rule Set from the Price Plan Repository 96. Then, the first Plan Selection Rule is retrieved 136 from Repository 96 for the Plan Selection Rule Set. The next operation is to evaluate the rule to determine 138 and 140 if it represents a null rule, a Condition or a Price Plan. If the rule represents a Condition, the Condition is retrieved and then evaluated 142 as shown in
Figure 8. If the Condition evaluates to TRUE 144, the Plan Selection Rule for the positive branch is retrieved 146. If the Condition evaluates to FALSE, the Plan Selection Rule for the negative branch is retrieved 148. If the rule represents a Price Plan, the Price Plan is retrieved and then processed 150 as described with respect to Figure 6. If the Event qualified for the Price Plan, the Plan Selection Rule for the positive branch is retrieved 146. If the Event did not qualify for the Price Plan, the Plan Selection Rule for the negative branch is retrieved 148. The processing of Plan Selection Rules continues until no further rules are found (i.e., a null is reached). Figure 6 depicts the processing 150 of a Price Plan. This process is executed for each Price Plan found when executing the rate Event Algorithm. This process, once started 172, retrieves 174 the currently effective Algorithm Selection Rule Set for the Price Plan from the Repository 96. Then, the first Algorithm Selection Rule is retrieved 176 for the Algorithm Selection Rule Set from the Repository 96. The next operation is to evaluate 178 and 180 if the rule is null, represents a Condition or an Algorithm. If the rule represents a Condition, the Condition is retrieved and then evaluated 182 as described in more detail with respect to Figure 8. If the Condition evaluates 184 to TRUE, the Algorithm Selection Rule for the positive branch is retrieved 186. If the Condition evaluates to FALSE, the Algorithm Selection Rule for the negative branch is retrieved 188. If the rule represents an Algorithm, the Algorithm is retrieved 190 and then processed as described in more detail in Figure 7. For all cases, the Plan Selection Rule for the positive branch is retrieved. The processing of Algorithm Selection Rules continues until no further rules are found.
Figure 7 depicts the process 190 performed for each Algorithm found when processing the Process Price Plan Algorithm of Figure 6. Each Algorithm consists of one or many process steps. The process 190, once started 212, retrieves 214 the first Process Step from the Repository 96. It is then evaluated to determine 216 whether the Process Step represents a Summary or a Calculation. If the Process Step represents a Summary, a selection of Event attributes are added 218 to a corresponding summary record and the applicable summary flags are set on the Event. Attributes that are summarized include the quantity of the Event (how many kilobytes, or packets, or calls, or pages, or whatever, depending upon the unit of measure), the duration of the Event (minutes or seconds, etc.), and any associated charges. If the Process Step represents a Calculation, the Calculation is executed 220. A simple example of a Calculation is a Single Unit Calculation. In different uses, this provides a charge per unit, where the unit may be any unit of measure. A rate of $.10 per min is a Single Unit Calculation, so is .06 per call, so is .12 per kilobit. Another good example is the Percent Discount Calculation, which gives a 10% discount, or a 20% discount, etc., upon the charge it acts upon. Depending on the type of Process Step the calculated charge is then added 222 to the existing Event charge or used to replace the existing Event charge. The system then tests 224 to determine if more steps are necessary and returns for more process steps if so. The process 142/182/220 depicted in Figure 8 is performed, like a subroutine, for each Condition found when processing the Rate Event or Process Price Plan Algorithms of Figures 5-7. The process, once started 242, retrieves 244 the Evaluator object. Then the CML program associated with the Condition is located and the evaluated 246 to determine if the program requires compilation. The programs associated with Conditions are preferably written using the business specific meta-language mentioned previously although other meta-languages can be used. The meta-language programs are compiled and executed on a virtual machine to enhance execution performance. For performance reasons, previously compiled programs are kept in a cache. The meta-language programs can be modified at run time and no changes to C++ application code are necessary. If the compiled program cannot be found 248 the program is compiled 250. The values required to evaluate the Condition are retrieved 252 from the Event. If the Condition contains 254 a Sensitivity the Evaluator context is set 256 accordingly and the Algorithm is called recursively. To prevent infinite recursion, Sensitivities preferably do not contain further Sensitivities. The Condition is then evaluated 258 and the result is fetched 260 from the program. The meta-language program of a Condition, Sensitivity or an
Algorithm can be modified without touching any application core code. The modified program will automatically be used by any Plan Selection Rule Set 10 and any Algorithm Selection Rule Set 30 referring to the particular Condition. For example, the Condition, or Sensitivity for that matter, that is used to determine Peak and Off-Peak hours, can be modified in the metalanguage program. The logic executed when the Condition is evaluated, as part of a Plan Selection Rule Set 10 and an Algorithm Selection Rule Set 30, is replaced by the modified program. The changing of a Algorithm, Condition or Sensitivity typically involves accessing the meta-language program. The program can be kept as reference data in the database or in files associated with the database. Changing an Algorithm or an Tariff Model Area/Tariff Model Area Sensitivity typically involves the use of SQL scripts. A conventional text editor is used by a designer/programmer to edit the text of the Algorithm, Sensitivity, Condition or SQL script to change the logic or parameters. Changes in a decision network sequence are made by changing the pointers in the network from one node to another node. As can be seen, changes in both the logic of the decision networks and the logic of Conditions, Sensitivities and Algorithms can be accomplished without changing core code.
The present invention has been described with respect to a preferred platform. The platform or programming languages used can, of course, be varied. A commercial rules engine could also be used to interpret Price Plan rules. Additionally, application code can be used instead of meta- language programs. The Event-pricing of the present invention can also be applied to any business domain where customers are billed for transactions that can be represented as Events.
The many features and advantages of the invention are apparent from the detailed specification and, thus, it is intended by the appended claims to cover all such features and advantages of the invention which fall within the true spirit and scope of the invention. Further, since numerous modifications and changes will readily occur to those skilled in the art, it is not desired to limit the invention to the exact construction and operation illustrated and described, and accordingly, all suitable modifications and equivalents may be resorted to, falling within the scope of the invention.

Claims

What is claimed is:
1. An apparatus, comprising: storage for storing a price plan and a corresponding decision network; and a processor obtaining an event to be rated and rating the event by evaluating the price plan using the decision network.
2. An apparatus as recited in claim 1 , wherein said processor evaluates a condition during processing of the price plan.
3. An apparatus as recited in claim 1, wherein said processor evaluates the decision network to determine an applicable price plan to process.
4. An apparatus as recited in claim 3, wherein said processor processes a decision network within a price plan to select a rating algorithm.
5. An apparatus as recited in claim 4, wherein said processor evaluates a condition during processing of a price plan.
6. An apparatus as recited in claim 4, wherein said processor processes a rating algorithm during processing of a price plan.
7. An apparatus as recited in claim 5, wherein said condition comprises an event qualification determination program.
8. An apparatus as recited in claim 1, wherein said processor traverses a plan selection rule set to select a price plan to evaluate and traverses an algorithm selection rule set to select an algorithm to rate the event.
9. An apparatus as recited in claim 1, wherein said processor processes a global decision network to select a price plan, processes a price plan decision network to select a rating algorithm and processes the algorithm to rate the event.
10. An apparatus, comprising: storage for storing a price plan and a corresponding decision network; and a processor obtaining an event to be rated, and rating and summarizing the event by evaluating the price plan using the decision network.
11. A billing apparatus for rating a telecommunications transaction billing event, comprising: storage for storing price plans and decision networks of a telecommunications customer care and billing system; and a processor obtaining the telecommunications transaction billing event to be rated, and rating and summarizing the event by traversing a plan selection rule set and processing conditions within the plan selection rule set to select a price plan, traversing an algorithm selection rule set of the selected price plan and processing conditions within the algorithm selection rule set to select a rating algorithm, and processing the algorithm to rate the event with each condition comprising an event qualification determination program.
12. A computer readable storage medium storing a process for controlling a computer to rate an event by traversing a plan selection rule set to select a price plan to evaluate and traversing an algorithm selection rule set to select an algorithm to rate the event.
13. A process, comprising: obtaining an event to be rated; and rating the event by evaluating a price plan using a decision network.
14. A process as recited in claim 13, wherein said evaluating evaluates the decision network to determine an applicable price plan to process, evaluates a condition during processing of the price plan, processes a decision network within a price plan to select a rating algorithm and processes a rating algorithm during processing of a price plan.
15. A process as recited in claim 13, wherein said condition comprises an event qualification determination program.
16. A process as recited in claim 13, wherein said evaluating traverses a plan selection rule set to select a price plan to evaluate and traverses an algorithm selection rule set to select an algorithm to rate the event.
17. A process as recited in claim 13, wherein said evaluating processes a global decision network to select a price plan, processes a price plan decision network to select a rating algorithm and processes the algorithm to rate the event.
PCT/US1999/016790 1998-07-29 1999-07-26 Decision network based event pricing system in a component based, object oriented convergent customer care and billing system WO2000007354A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
AU53204/99A AU5320499A (en) 1998-07-29 1999-07-26 Decision network based event pricing system in a component based, object oriented convergent customer care and billing system
CA002302366A CA2302366A1 (en) 1998-07-29 1999-07-26 Decision network based event pricing system in a component based, object oriented convergent customer care and billing system
EP99938799A EP1101350A1 (en) 1998-07-29 1999-07-26 Decision network based event pricing system in a component based, object oriented convergent customer care and billing system

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US9445998P 1998-07-29 1998-07-29
US60/094,459 1998-07-29
US09/353,588 US6456986B1 (en) 1998-07-29 1999-07-15 Decision network based event pricing system in a component based, object oriented convergent customer care and billing system
US09/353,588 1999-07-15

Publications (2)

Publication Number Publication Date
WO2000007354A1 WO2000007354A1 (en) 2000-02-10
WO2000007354A9 true WO2000007354A9 (en) 2000-06-08

Family

ID=26788908

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1999/016790 WO2000007354A1 (en) 1998-07-29 1999-07-26 Decision network based event pricing system in a component based, object oriented convergent customer care and billing system

Country Status (5)

Country Link
US (1) US6456986B1 (en)
EP (1) EP1101350A1 (en)
AU (1) AU5320499A (en)
CA (1) CA2302366A1 (en)
WO (1) WO2000007354A1 (en)

Families Citing this family (92)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5604899A (en) 1990-05-21 1997-02-18 Financial Systems Technology Pty. Ltd. Data relationships processor with unlimited expansion capability
US7818212B1 (en) 1999-10-22 2010-10-19 Ewinwin, Inc. Multiple criteria buying and selling model
US7693748B1 (en) 1991-06-03 2010-04-06 Ewinwin, Inc. Method and system for configuring a set of information including a price and volume schedule for a product
FI990604A (en) * 1999-03-17 2000-09-18 Sonera Oyj Pricing of telecommunication connections in a telecommunication system
AU4981400A (en) 1999-05-12 2000-12-05 Ewinwin, Inc. Multiple criteria buying and selling model, and system for managing open offer sheets
US20110213648A1 (en) 1999-05-12 2011-09-01 Ewinwin, Inc. e-COMMERCE VOLUME PRICING
US7689469B1 (en) 1999-05-12 2010-03-30 Ewinwin, Inc. E-commerce volume pricing
US8290824B1 (en) 1999-05-12 2012-10-16 Ewinwin, Inc. Identifying incentives for a qualified buyer
US7181419B1 (en) 2001-09-13 2007-02-20 Ewinwin, Inc. Demand aggregation system
US8732018B2 (en) 1999-05-12 2014-05-20 Ewinwin, Inc. Real-time offers and dynamic price adjustments presented to mobile devices
US8140402B1 (en) 2001-08-06 2012-03-20 Ewinwin, Inc. Social pricing
US7593871B1 (en) 2004-06-14 2009-09-22 Ewinwin, Inc. Multiple price curves and attributes
US8311896B2 (en) 1999-05-12 2012-11-13 Ewinwin, Inc. Multiple criteria buying and selling model
US8626605B2 (en) 1999-05-12 2014-01-07 Ewinwin, Inc. Multiple criteria buying and selling model
US6876991B1 (en) 1999-11-08 2005-04-05 Collaborative Decision Platforms, Llc. System, method and computer program product for a collaborative decision platform
JP2001188841A (en) * 1999-12-28 2001-07-10 Ibm Japan Ltd Data processing system for calculating charge
US6970825B1 (en) 1999-12-30 2005-11-29 Pitney Bowes Inc. Planning engine for a parcel shipping system
US6957197B1 (en) 1999-12-30 2005-10-18 Pitney Bowes Inc. Load planning tables for a parcel shipping system
JP4282882B2 (en) * 2000-08-18 2009-06-24 インターナショナル・ビジネス・マシーンズ・コーポレーション Spending management system, spending management method, and storage medium
JP2002109402A (en) * 2000-09-29 2002-04-12 Fujitsu Ltd Method and devices for setting up supporting fee
MXPA02011693A (en) * 2000-10-10 2004-05-17 American Electric Power Compan A power load-leveling system and packet electrical storage.
US20020082881A1 (en) * 2000-10-20 2002-06-27 Price Marc Steven System providing event pricing for on-line exchanges
EP1337963A4 (en) * 2000-10-30 2005-11-02 Translation Technologies Inc Computational geometry system, interrupt interface, geometric model comparator, and method
US7020869B2 (en) * 2000-12-01 2006-03-28 Corticon Technologies, Inc. Business rules user interface for development of adaptable enterprise applications
US7657470B1 (en) 2000-12-20 2010-02-02 Demandtec, Inc. Financial model engine
US20100010870A1 (en) * 2000-12-20 2010-01-14 Karl Millar System and Method for Tuning Demand Coefficients
US7899691B1 (en) 2000-12-20 2011-03-01 Demandtec, Inc. Econometric engine
US7617119B1 (en) 2000-12-20 2009-11-10 Demandtec, Inc. Price optimization with rule relaxation
US9785953B2 (en) * 2000-12-20 2017-10-10 International Business Machines Corporation System and method for generating demand groups
US7523047B1 (en) 2000-12-20 2009-04-21 Demandtec, Inc. Price optimization system
US9165270B2 (en) * 2000-12-20 2015-10-20 International Business Machines Corporation Predicting likelihood of customer attrition and retention measures
US7660734B1 (en) 2000-12-20 2010-02-09 Demandtec, Inc. System for creating optimized promotion event calendar
US10204349B2 (en) 2000-12-20 2019-02-12 International Business Machines Corporation Analyzing customer segments
US9773250B2 (en) * 2000-12-20 2017-09-26 International Business Machines Corporation Product role analysis
US10496938B2 (en) 2000-12-20 2019-12-03 Acoustic, L.P. Generating product decisions
US7877286B1 (en) 2000-12-20 2011-01-25 Demandtec, Inc. Subset optimization system
US7302410B1 (en) 2000-12-22 2007-11-27 Demandtec, Inc. Econometric optimization engine
US7062447B1 (en) 2000-12-20 2006-06-13 Demandtec, Inc. Imputed variable generator
US8010404B1 (en) 2000-12-22 2011-08-30 Demandtec, Inc. Systems and methods for price and promotion response analysis
US7620574B2 (en) * 2001-01-22 2009-11-17 N2 Broadband, Inc. Cable billing systems and methods enabling independence of service marketing and provisioning from billing and collection of revenue
US6553352B2 (en) * 2001-05-04 2003-04-22 Demand Tec Inc. Interface for merchandise price optimization
US7092896B2 (en) * 2001-05-04 2006-08-15 Demandtec, Inc. Interface for merchandise promotion optimization
US7130811B1 (en) 2001-05-05 2006-10-31 Demandtec, Inc. Apparatus for merchandise promotion optimization
US7124299B2 (en) * 2001-05-18 2006-10-17 Claymore Systems, Inc. System, method and computer program product for auditing XML messages in a network-based message stream
US7936693B2 (en) 2001-05-18 2011-05-03 Network Resonance, Inc. System, method and computer program product for providing an IP datalink multiplexer
US7464154B2 (en) * 2001-05-18 2008-12-09 Network Resonance, Inc. System, method and computer program product for analyzing data from network-based structured message stream
US7451110B2 (en) * 2001-05-18 2008-11-11 Network Resonance, Inc. System, method and computer program product for providing an efficient trading market
US20030061137A1 (en) * 2001-08-21 2003-03-27 Leung Yiu Kau Settlement of transactions subject to multiple pricing plans
SG122743A1 (en) * 2001-08-21 2006-06-29 Micron Technology Inc Microelectronic devices and methods of manufacture
US20030046171A1 (en) * 2001-08-29 2003-03-06 Whale Margo N. Systems and methods for determining special pricing of components for printing device customers
US20030069737A1 (en) * 2001-10-04 2003-04-10 Netscape Communications Corporation Hierarchical rule determination system
US20030097335A1 (en) * 2001-11-21 2003-05-22 International Business Machines Corporation Secure method and system for determining charges and assuring privacy
US7249032B1 (en) 2001-11-30 2007-07-24 Demandtec Inc. Selective merchandise price optimization mechanism
US7249033B1 (en) 2001-11-30 2007-07-24 Demandtec Inc. Apparatus and method for selective merchandise price optimization
US7386519B1 (en) 2001-11-30 2008-06-10 Demandtec, Inc. Intelligent clustering system
US7809581B1 (en) 2001-11-30 2010-10-05 Demandtec, Inc. Rule relaxation and subset optimization system
US7769997B2 (en) * 2002-02-25 2010-08-03 Network Resonance, Inc. System, method and computer program product for guaranteeing electronic transactions
US6874089B2 (en) * 2002-02-25 2005-03-29 Network Resonance, Inc. System, method and computer program product for guaranteeing electronic transactions
US9495707B2 (en) * 2002-06-12 2016-11-15 Goldman, Sachs & Co. Systems and methods to facilitate generation of pricing information via a pricing graph
US7899707B1 (en) 2002-06-18 2011-03-01 Ewinwin, Inc. DAS predictive modeling and reporting function
US6518734B1 (en) * 2002-06-18 2003-02-11 Aep Emtech, Llc System and method of forming capacitor-based electrical energy storage modules
US7133882B1 (en) 2002-08-05 2006-11-07 Demandtec, Inc. Method and apparatus for creating and using a master catalog
US7689463B1 (en) 2002-08-28 2010-03-30 Ewinwin, Inc. Multiple supplier system and method for transacting business
DE10244463B4 (en) * 2002-09-24 2004-11-18 Siemens Ag Method for billing a fee-based use of services offered by a service provider
US6851604B2 (en) * 2002-10-02 2005-02-08 Demand Tec Inc. Method and apparatus for providing price updates
US8832178B2 (en) 2002-11-06 2014-09-09 Noel William Lovisa Service implementation
GB0226488D0 (en) * 2002-11-13 2002-12-18 British Telecomm Dimension-based tariffing
US20040187099A1 (en) * 2003-03-20 2004-09-23 Convergys Information Management Group, Inc. System and method for processing price plans on a device based rating engine
DE50306418D1 (en) * 2003-04-04 2007-03-15 Siemens Ag METHOD FOR CONTROLLING AND CONTROLLING MULTIPLE DECENTRALIZED IP BUDGETS OF A PARTICIPANT IN A PACKET BASED COMMUNICATION NETWORK AT AN ONLINE FEE WITH LIMIT MONITORING OF DATA TRANSMISSIONS
US8036962B2 (en) * 2003-06-13 2011-10-11 Sap Ag Systems and methods for determining payers in a billing environment
EP1639459A2 (en) * 2003-06-13 2006-03-29 Equifax, Inc. Systems and processes for automated criteria and attribute generation, searching, auditing and reporting of data
US7364086B2 (en) 2003-06-16 2008-04-29 Ewinwin, Inc. Dynamic discount card tied to price curves and group discounts
US8590785B1 (en) 2004-06-15 2013-11-26 Ewinwin, Inc. Discounts in a mobile device
US11132183B2 (en) 2003-08-27 2021-09-28 Equifax Inc. Software development platform for testing and modifying decision algorithms
WO2005022348A2 (en) * 2003-08-27 2005-03-10 Equifax, Inc. Application processing and decision systems and processes
GB0406512D0 (en) 2004-03-23 2004-04-28 British Telecomm Method and system for semantically segmenting scenes of a video sequence
US7870091B2 (en) * 2004-06-18 2011-01-11 Sap Ag Methods and systems for receiving data, selecting a condition table, selecting a ruleset based on the condition table, and determining and applying rules to data
US20050283502A1 (en) * 2004-06-18 2005-12-22 Ami Heitner Methods and systems for reconciling data
CN100349403C (en) * 2004-09-27 2007-11-14 英业达股份有限公司 Intelligent website charging treatment system and its method
WO2006043165A1 (en) * 2004-10-22 2006-04-27 Telefonaktiebolaget Lm Ericsson (Publ) Improved subscriber partitioning in a charging system
US20060246788A1 (en) * 2005-04-28 2006-11-02 International Business Machines Corporation Method for representing connections for validation during an automated configuration of a product
US7360071B2 (en) * 2005-04-28 2008-04-15 International Business Machines Corporation Method to establish contexts for use during automated product configuration
US7697672B2 (en) * 2005-11-29 2010-04-13 Accenture Global Services Gmbh Configurable rating system for a telecommunications service provider
US7831027B2 (en) * 2006-01-25 2010-11-09 Accenture Global Services Limited Configurable charging system for a telecommunications service provider
EP1814298A1 (en) 2006-01-25 2007-08-01 Accenture Global Services GmbH Configurable charging system for a telecommunciations service provider
US9785951B1 (en) 2006-02-28 2017-10-10 International Business Machines Corporation Scalable tuning engine
US9858579B1 (en) 2006-02-28 2018-01-02 International Business Machines Corporation Plan tuning engine
US8313005B2 (en) * 2006-08-03 2012-11-20 Kraft Foods Global Brands, Llc Plastic coffee container with pinch grip
US20080172240A1 (en) * 2007-01-17 2008-07-17 Wolfgang Klotzki Method For Optimizing a Fee Tariff System For a User of a Telecommunication System
US8341044B1 (en) * 2007-06-05 2012-12-25 Amdocs Software Systems Limited System, method, and computer program product for rating and re-rating events
WO2009021011A2 (en) * 2007-08-07 2009-02-12 Equifax, Inc. Systems and methods for managing statistical expressions
EP3864604A1 (en) * 2018-10-12 2021-08-18 Telefonaktiebolaget LM Ericsson (publ) Methods and systems for performing rerating of subscriber records through selective processing

Family Cites Families (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4286325A (en) * 1979-08-27 1981-08-25 Pitney Bowes Inc. System and method for computing domestic and international postage
JPH0335352A (en) * 1989-06-30 1991-02-15 Omron Corp On-line price deciding system
US5063506A (en) * 1989-10-23 1991-11-05 International Business Machines Corp. Cost optimization system for supplying parts
US4979207A (en) * 1990-02-01 1990-12-18 Motorola, Inc. Method of processing cellular telephone call detail data for billing multi-line customers for cellular telephone services
US5414624A (en) * 1993-11-08 1995-05-09 Avid Systems Corporation Automated vehicle parking system
CA2183342C (en) * 1994-03-02 1999-10-12 Dale Robert Gordon Pricing method for telecommunication system
US5815560A (en) * 1994-06-08 1998-09-29 Fujitsu Limited Communication service control apparatus
US5570291A (en) * 1994-08-24 1996-10-29 Wallace Computer Services, Inc. Custom product estimating and order processing system
US5659601A (en) * 1995-05-09 1997-08-19 Motorola, Inc. Method of selecting a cost effective service plan
US5852812A (en) * 1995-08-23 1998-12-22 Microsoft Corporation Billing system for a network
US5737710A (en) * 1995-11-07 1998-04-07 Amtech Corporation Automated vehicle parking system for a plurality of remote parking facilities
US5784443A (en) 1996-02-01 1998-07-21 Mci Corporation Integrated revenue domain for telecommunication networks
CA2198798C (en) 1996-05-21 2000-05-23 Hosagrahar Visvesvaraya Jagadish System and method for pricing telecommunication transactions
US5923741A (en) * 1997-04-04 1999-07-13 Wright; Carl A. Flexible system for real-time rating of telecommunications transactions
US6041318A (en) * 1997-08-04 2000-03-21 Schneider National, Inc. Object oriented rating system and method
US6061667A (en) * 1997-08-04 2000-05-09 Schneider National, Inc. Modular rating engine, rating system and method for processing rating requests in a computerized rating system
US6047271A (en) * 1997-08-04 2000-04-04 Schneider National, Inc. Qualification engine, rating system, and method for qualifying rating requests in a computerized rating system
US6078889A (en) * 1997-09-30 2000-06-20 Pitney Bowes Inc. Method and system of implementing a carrier manager librarian
US6018725A (en) * 1997-09-30 2000-01-25 Pitney Bowes Inc. Method and system of implementing a carrier manager registry
US6199047B1 (en) * 1997-12-31 2001-03-06 Csg Systems, Inc. Apparatus and method for an event rating engine
JP3033732B2 (en) * 1998-05-14 2000-04-17 静岡日本電気株式会社 Information terminal with charge management function

Also Published As

Publication number Publication date
AU5320499A (en) 2000-02-21
EP1101350A1 (en) 2001-05-23
US6456986B1 (en) 2002-09-24
WO2000007354A1 (en) 2000-02-10
CA2302366A1 (en) 2000-02-10

Similar Documents

Publication Publication Date Title
US6456986B1 (en) Decision network based event pricing system in a component based, object oriented convergent customer care and billing system
US6199047B1 (en) Apparatus and method for an event rating engine
US6574465B2 (en) System and method for determining optimal wireless communication service plans
US9875505B2 (en) Hierarchical transaction filtering
US8374579B2 (en) System and method for analyzing wireless communication data
US6813488B2 (en) System and method for determining optimal wireless communication service plans based on spectrum licenses
US7664484B2 (en) Pooling groups of wireless communication users
US6681106B2 (en) System and method for analyzing wireless communication records and for determining optimal wireless communication service plans
US20020107754A1 (en) Rule-based system and apparatus for rating transactions
US20070172040A1 (en) Configurable charging system for a telecommunications service provider
US7072639B2 (en) System and method for determining optimal wireless communication service plans based on historical projection analysis
US20070202846A1 (en) Providing a rebate to a user of a telecommunication plan
US6804337B1 (en) Bill image generation
JP6081491B2 (en) A functional model for assessing events
JP2001188841A (en) Data processing system for calculating charge
US8086486B2 (en) Method for managing information and rendering discounts
US7925558B2 (en) System and method for commoditizing browsing time in a self-service store
KR100573475B1 (en) Hotel reservation and accounting system and method thereof
AU2013205629B2 (en) Configurable charging system for a telecommunications service provider
CN106385427A (en) Service processing method based on service object and apparatus thereof
EP1814298A1 (en) Configurable charging system for a telecommunciations service provider
FI115585B (en) The method of billing transactions and the billing system for transactions
US20050137936A1 (en) Methods and systems for pricing products utilizing pricelists based on qualifiers
WO2001091020A1 (en) Apparatus and method of optimizing the total monthly amount due on bills and satisfying customer&#39;s preferences
JP2001094688A (en) Bill generating method, its executing device and recording medium recording its procesing program

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW SD SL SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

ENP Entry into the national phase

Ref document number: 2302366

Country of ref document: CA

Ref country code: CA

Ref document number: 2302366

Kind code of ref document: A

Format of ref document f/p: F

WWE Wipo information: entry into national phase

Ref document number: 1999938799

Country of ref document: EP

121 Ep: the epo has been informed by wipo that ep was designated in this application
AK Designated states

Kind code of ref document: C2

Designated state(s): AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZW

AL Designated countries for regional patents

Kind code of ref document: C2

Designated state(s): GH GM KE LS MW SD SL SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

COP Corrected version of pamphlet

Free format text: PAGES 1-13, DESCRIPTION, REPLACED BY NEW PAGES 1-13; PAGES 14-16, CLAIMS, REPLACED BY NEW PAGES 14-16; PAGES 1/8-8/8, DRAWINGS, REPLACED BY NEW PAGES 1/8-8/8; DUE TO LATE TRANSMITTAL BY THE RECEIVING OFFICE

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
WWP Wipo information: published in national office

Ref document number: 1999938799

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWW Wipo information: withdrawn in national office

Ref document number: 1999938799

Country of ref document: EP