Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
METHOD OF TIME-TO-TALK CALCULATION
Document Type and Number:
WIPO Patent Application WO/2000/013402
Kind Code:
A1
Abstract:
A method of calculating the maximum talk time. Determining the rate for the period of time when the call begins (08). Calculating the maximum number of time units remaining in the time period (20). Calculating the maximum number of units before reaching system maximum talk time (136). Calculating the maximum units before available funds are exhausted (138). Determining the minimums of the above mentioned calculations as the talk time available and subtracting the amount from a copy of the pre-paid card balance (118). If the maximum time units available in the time period is the minimum of all three calculation steps then repeat the above steps and add the amount of talk time (132).

Inventors:
HUDSON DAN
Application Number:
PCT/US1998/017620
Publication Date:
March 09, 2000
Filing Date:
August 26, 1998
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
HARRIS CORP (US)
International Classes:
H04M15/00; H04M17/00; H04W88/02; (IPC1-7): H04M15/00
Foreign References:
US5440621A1995-08-08
US5546448A1996-08-13
US4776000A1988-10-04
US4706275A1987-11-10
Attorney, Agent or Firm:
Rogers III, Lawton L. (VA, US)
Download PDF:
Claims:
WHAT IS CLAIMED IS :
1. In a prepaid telephone system, a method for providing account information to a subscriber comprising : (a) receiving a call from the subscriber requesting the account information ; (b) obtaining a personal identification number (PIN) from the subscriber ; (c) retrieving a copy of the subscriber's account balance from a database using the PIN ; (d) determining a time period in which the call is initiated ; (e) determining the applicability of a first cost for a first segment of the time period ; (f) if applicable, subtracting the first cost from the copy of the subscriber's account balance ; (g) determining a remaining system maximum allowable talk time ; (h) determining a number of additional time segments remaining in the time period ; (i) calculating a number of additional time segments for the time period that the subscriber can afford using the account balance information ; (j) using the minimum value from steps (gi) and a billing rate associated with the additional time segments of the time period to determine a cost of the call during the time period ; (k) subtracting the cost of the call from the copy of the account balance ; (1) repeating steps (gk) until either the account can no longer afford additional time segments or the remaining system maximum talk time is exhausted ; (m) adding the costs of the call for each time period ; and, (n) providing the result to the subscriber.
2. A method for calculating the amount of time available for a subscriber to talk in a prepaid telephone system, the improvement comprising the amount of time available for the call as a function of the caller's account balance, a set system parameter for the maximum amount of time a caller may talk for single call, and the monetary rates associated with the time of day during which the call takes place.
3. A method of calculating the maximum talk time available to a subscriber comprising : (a) determining a time period when the call begins ; (b) determining a cost of the call for the time period using one of : a maximum number of time units remaining in the time period, a system maximum number of time units, and a maximum number of time units for the time period available based on subscriber funds ; (c) subtracting the cost of the call from a copy of the subscriber's account balance ; (d) repeating steps (bc) for subsequent time periods until the subscriber's account balance cannot afford anymore time units ; and (e) totaling the costs of the call for each time period.
Description:
METHOD OF TIME-TO-TALK CALCULATION BACKGROUND OF THE INVENTION Voice response units ("VRUs") are well known. They allow - a caller to enter and retrieve information by using the telephone keypad to respond to a voice menu. They can provide, for example, the playback of prerecorded, or voice synthesization of, successive digits in a telephone number in response to a request for directory assistance.

In prepaid telephone systems, VRUs are used to provide the subscriber with account information such as the time available to talk and billing information. This information may be obtained in a variety of ways. Some prior art systems charge a constant price per unit of time and thereby simply requiring the account balance to be divided by the price to obtain the available talk time (i. e., number of time units which can be purchased). These systems, while offering a straightforward approach for talk time calculations, are unable to support multiple rate time periods.

Other prior art systems providing multiple rate periods often use extensive looping in determining the available talk time. The systems subtract the cost of a unit of time unit from the account balance, check to see if the balance is less than zero, and if it isn't, add the time unit to the talk time.

The systems then add the time unit to the current time, perform a check to see if a rate change is required for the"new" current time, and acquire the new rate if necessary. This process is repeated until the account funds are exhausted. The extensive looping required by these systems to obtain the available talk time/billing calculations results in degraded system performance.

Accordingly, it is an object of the present invention to provide a novel method and system for providing multiple rate periods while achieving near constant execution time regardless- of the account balance.

It is another object of the present invention to provide a novel method and system which supports multiple rates during the course of a call while minimizing system performance degradation due to excessive looping.

It is yet another object of the present invention to provide a novel system and method for calculating the available talk time down to a one second granularity.

It is still another object of the present invention to provide a novel method and system for achieving constant execution regardless of the account balance and the system maximum talk time, while maintaining the ability to handle multiple rate periods without the algorithm being sensitive to clock changes.

These and many other objects and advantages of the present invention will be readily apparent to one skilled in the art to which the invention pertains from a perusal of the claims, the appended drawings, and the following detailed description of the preferred embodiments.

BRIEF DESCRIPTION OF THE DRAWINGS Figure 1 is a functional block diagram showing the basic organization of the enhanced services system of the present invention in the embodiment of a prepaid telephone system.

Figure 2 is a functional block diagram of an embodiment of- the present invention showing the voice response unit (VRU) embedded within the switching platform.

Figure 3 is a flow chart illustrating a typical exchange between a caller and a prepaid system.

Figure 4 is a flowchart illustrating the process used in determining the TIME-TO-TALK for one embodiment of the present invention.

Figure 5 is a chart illustrating the time periods and rates for one embodiment of the present invention.

Figure 6 is a flowchart illustrating the process used in determining the cost of a call for one embodiment of the present invention.

Figure 7 is a chart illustrating the time periods and rates for one embodiment of the present invention.

DESCRIPTION OF PREFERRED EMBODIMENTS Figure 1, illustrating an enhanced services platform in the embodiment of a prepaid telephone system, shows a suitable conventional telephone switch 10 such as the Harris Corporation 20/20 switch in a conventional public switched telephone network (PSTN) connected to large numbers of subscriber telephones such as the caller telephones 12 and the called party telephones 14. Also connected to the switch 10 may be a bank of voice response units (VRUs) 15 on which the prepaid call processing application 18 resides.

Alternatively as shown in Figure 2, the VRUs 15 may be embedded within the architecture of an integrated network server (IN Server) 16 which is physically mounted on the back plane of the telephone switch 10. The embedding of the VRU in the switch platform effects seamless transfer of information and may be accomplished by means of an adaptor card with the elimination of the T1 and El circuits.

The management of a prepaid system is generally under the control of a call processing application resident within the VRU. The call processing application, in association with peripheral equipment, determines the action to be taken (e. g., determining the correctness of a PIN entry, the prompting of users for destination numbers or desired services, outdialing to a requested telephone number, etc. ) during the processing of a call request.

Figure 3 illustrates a typical exchange between a caller and a prepaid system. The caller 12 dials into the prepaid telephone system (200) and upon connection is offered a choice of languages in which to proceed with the interaction (202).

After the caller selects the desired language by keypad entry, vocal response, etc. (204), the caller's personal identification number ("PIN") is requested and provided (206, 208). Upon PIN validation, the account balance of the caller may be provided and the call destination is requested by the prepaid system (210). After the caller has entered the call destination, the prepaid system determines the amount of time available for the call and provides the information to the caller (214). During the call, voice messages pertaining to time warnings/call termination may be provided to the caller (218).

The amount of time available for the call ("TIME-TO-TALK")- in accordance with one embodiment of the present invention is a function of the caller's account balance, a set system parameter for the maximum amount of time a caller may talk within a given call ("SYSTEM-MAX"), and the monetary rates associated with the time of day during which the call takes place.

Figure 4 illustrates the process used to calculate the TIME-TO-TALK for one embodiment of the present invention.

First the SYSTEM-MAX ("B2") is determined (100). As mentioned, the System Maximum Talk Time is a set parameter limiting the amount of time a caller may talk within a single call. The parameter is set and modifiable by the system administrator.

The system then initializes the TIME-TO-TALK, the PERIOD-TIME- TO-TALK, and the REMAINING-SYSTEM-MAX (B4) parameters (101).

Next, a copy of the caller's account information ("ACCOUNT- BALANCE ") is obtained from the prepaid system database using the caller's personal identification number ("PIN") (102) and the time period in which the call is initiated is determined (104). In determining the time period, the system aligns the start time of the call ("Call-Start- Time ") with the next occurring time unit boundary (106), then determines the time period within which the time unit is contained.

When a call is initiated, a first segment of the call ("FIRST-SEGMENT") may be billed at a different rate than later segments ("ADDITIONAL-SEGMENTS") with the number of time units (e. g., minutes) within the segments and the associated rates set and modifiable by the system administrator. Once the time period has been determined, the system calculates the cost of the FIRST-SEGMENT plus any/all applicable surcharges and compares the cost to ACCOUNT-BALANCE (108,110). If ACCOUNT- BALANCE is insufficient to cover the FIRST-SEGMENT cost, call processing is terminated (112). Otherwise, the cost of the FIRST-SEGMENT is subtracted from ACCOUNT-BALANCE (114) and the length of the FIRST-SEGMENT is added to TIME-TO-TALK (116) and subtracted from REMAINING-SYSTEM-MAX (118).

The system then calculates the number of ADDITIONAL- SEGMENTS remaining within the time period ("Bl") (122) and the number of ADDITIONAL-SEGMENTS the PIN/account can afford ("B3") using the ADDITIONAL-SEGMENTS rate for the time period and the account balance information (126). If the account can not afford to purchase any additional segments (i. e., B3=0), the available talk time calculation is complete and the value stored as TIME-TO-TALK is provided to the caller (124,140).

If the account can afford additional time segments, the system then compares B1, B3, and B4 and uses the lowest value as the PERIOD-TIME-TO-TALK (122).

The cost of the PERIOD-TIME-TO-TALK is then calculated using the ADDITIONAL-SEGMENTS rate for the time period (128) and deducted from ACCOUNT BALANCE (130). Then, the PERIOD- TIME-TO-TALK is added to the TIME-TO-TALK (132) and subtracted from the REMAINING-SYSTEM-MAX (136). If REMAINING-SYSTEM-MAX is zero, the system maximum talk time has been reached ending the calculation of the available talk time and the accumulated TIME-TO-TALK value is provided to the caller (140). While an exit criteria of REMAINING-SYSTEM-MAX=0 is used for illustrative purposes, the REMAINING-SYSTEM-MAX does not have to equal zero, but may simply fall below a desired threshold value, to force the exit from the algorithm. For example, a REMAINING-SYSTEM-MAX falling below a six second threshold may force the exit although the granularity for one embodiment of the present invention will allow an accounting down to the second for both cost and time calculations.

If REMAINING-SYSTEM-MAX does not fall below the exit threshold value, the system considers the next time period.

Since only one FIRST-SEGMENT exists for a given call with the remaining call time (ADDITIONAL-SEGMENTS) spread over one or more time periods, in considering subsequent time periods, the system uses only the ADDITIONAL-SEGMENTS calculations and associated rates (i. e., loop back to 111).

Figure 5 illustrates the calculation of the TIME-TO-TALK for one embodiment of the present invention. In Figure 5, there are four time periods (MORNING, AFTERNOON, EVENING, NIGHT) each consisting of 6 hours and having associated calling rates for the FIRST-SEGMENT and the ADDITIONAL-SEGMENTS.

In Figure 5, the TIME-TO-TALK is determined for a call initiated at 4 PM with the caller having an account balance of $40 and with a SYSTEM-MAX = 3 hours, FIRST-SEGMENT = 5 minutes, and ADDITIONAL-SEGMENTS = 1 minute each. First, the cost of the FIRST-SEGMENT is calculated (5 min x 20/min = $1) for the AFTERNOON time period. Since the account can afford the FIRST- SEGMENT (surcharges would also be included if applicable), call processing continues by deducting the $1 FIRST-SEGMENT cost from ACCOUNT-BALANCE ACCOUNT-BALANCE=$39, adding the 5 minute- FIRST-SEGMENT time length to TIME-TO-TALK TIME-TO-TALK=5 minutes], and subtracting the 5 minute FIR. ST-SEGMENT time length from the REMAINING-SYSTEM-MAX [REMAINING-SYSTEM-MAX=175 minutes.

Next the system calculates B1 (the number of ADDITIONAL- SEGMENTS remaining in the time period) and B3 (the number of ADDITIONAL-SEGMENTS the PIN/account can afford) for the AFTERNOON time period. Since there are two hours minus the 5 minute FIRST-SEGMENT left in the AFTERNOON time period (4 : 05- 6:00PM), B1=115 "additional" minutes.

Further, at the ADDITIONAL-SEGMENTS rate of 15¢/min with ACCOUNT BALANCE=$39, the PIN/account could afford B3=260 "additional" minutes. Since B3 is non-zero (i. e., the account can afford additional time), the TIME-TO-TALK calculation continues.

Using the minimum value of Bl, B3, and B4 as the AFTERNOON-TIME-TO-TALK (i. e., B1=115 minutes), the cost of the AFTERNOON-TIME-TO-TALK is determined by multiplying B1 by the ADDITIONAL-SEGMENTS rate of the AFTERNOON period, 15¢/min, yielding $17. 25. Subtracting this amount from the ACCOUNT BALANCE of $39 yields $21. 75 to be applied to the next time period. The AFTERNOON-TIME-TO-TALK is added to the TIME-TO- TALK yielding an accumulated TIME-TO-TALK = 120 minutes.

Repeating the B1, B3, and B4 calculations for the EVENING time period using the ADDITIONAL-SEGMENTS rate yields Bl=360 minutes (i. e., 60 minutes/hr x 6 hrs), B3=217. 5 minutes (i. e., $21. 75 - $0. 10/min), and B4=60 minutes (REMAINING-SYSTEM-MAX - AFTERNOON-TIME-TO-TALK = 175-115). Selecting the minimum value- of Bl, B3, and B4 for the EVENING time period as the EVENING- TIME-TO-TALK (B4=60 minutes), and adding the EVENING-TIME-TO- TALK to the TIME-TO-TALK yields an accumulated TIME-TO-TALK=180 minutes. Since the REMAINING-SYSTEM-MAX was used for the EVENING-TIME-TO-TALK, deducting the EVENING-TIME-TO-TALK from the REMAINING-SYSTEM-MAX parameter results in a zero value forcing an exit from the algorithm with a final TIME-TO- TALK=180 minutes.

As shown in the embodiment of Figure 6, the process illustrated in Figure 4 may be altered slightly for billing purposes. In a billing application, only the B1 value is used while the ACCOUNT BALANCE is replaced with the CALL DURATION.

As indicated, the system determines the CALL DURATION (200) and the time period in which the call is initiated (202). The system calculates the FIRST-SEGMENT cost including applicable surcharges (203) and adds this cost to the total cost for the call ("COST-OF-CALL") (204).

The length of the FIRST-SEGMENT is then subtracted from CALL-DURATION. If the remaining CALL-DURATION is less than or equal to zero, COST-OF-CALL reflects the total cost for the call and is subtracted from the actual account balance.

Otherwise, the system determines the ADDITIONAL-SEGMENTS rate for the time period, calculates B1 (the number of ADDITIONAL- SEGMENTS remaining within the time period), and compare Bl with CALL-DURATION (206,208). If B1 is greater than or equal to CALL DURATION (i.. e., the call ended during this time period), the COST-OF-PERIOD-TIME-TALKED is calculated using CALL DURATION and the ADDITIONAL-SEGMENTS rate for the time period (216,218). The COST-OF-PERIOD-TIME-TALKED is added to the total COST-OF-CALL which is then subtracted from the actual account balance (220,230).

If B1 is less than CALL DURATION, Bl is used to calculate the COST-OF-PERIOD-TIME-TALKED which is added to the total COST-OF-CALL and CALL DURATION is reduced by B1 (yielding the amount of time left to apply to next time period) (210,212).

The system then repeats the ADDITIONAL-SEGMENTS calculations for the subsequent time periods until the time period in which the call terminated is reached (214).

An example of the above process for one embodiment of the invention is illustrated by Figure 7. The call, initiated in the AFTERNOON time period at 4PM, had a CALL DURATION of 180 minutes. Calculating the cost of a FIRST-SEGMENT = 5 minutes at a rate of 20¢/min yields a $1 FIRST-SEGMENT cost (assuming no applicable surcharges) which is added to COST-OF-CALL [COST- OF-CALL=$1. Subtracting the length of FIRST-SEGMENT from CALL-DURATION yields a remaining CALL-DURATION = 175 minutes.

Next, the number of ADDITIONAL-SEGMENTS remaining in the AFTERNOON time period, Bl=115 minutes, is determined. Since B1 is less than the CALL DURATION, B1 is used to reduce the CALL DURATION to 60 minutes and to calculate the COST-OF-AFTERNOON- TIME-TALKED = $17. 25 (115 min x 15¢/min) which is added to COST-OF-CALL COST-OF-CALL=$18. 25. Next, the EVENING time period is considered. The ADDITIONAL-SEGMENTS billing rate (10¢/min) and Bl=360 minutes are determined for the EVENING TIME PERIOD. Since Bl is greater than the CALL DURATION, the call was terminated during this time period. The CALL DURATION is used to calculate the COST-OF-EVENING-TIME-TALKED=$6 (60 minutes x 10¢/min) which is added to COST-OF-CALL to yield a total cost for the call of $24. 25.

While preferred embodiments of the present invention have been described, it is to be understood that the embodiments described are illustrative only and the scope of the invention is to be defined solely by the appended claims when accorded a full range of equivalence, many variations and modifications naturally occurring to those of skill in the art from a perusal hereof.