This invention relates generally to the field of systems and methods for validating and processing payment instruments, and more particularly embodiments of the invention relate to verifying the payment amounts associated with the payments in order to electronically process the payments to reduce failed readings and manage the processing flows associated with the payments.
Processing of checks includes taking an image of a check and determining the payment amount from the image. However, the payment amount determined from the image of the check may be incorrect for a number of reasons.
Embodiments of the present invention address the above needs and/or achieve other advantages by providing apparatuses (e.g., a system, computer program product, and/or other device) and methods that help validate and process payment instruments for different products (e.g. goods and services), such as but not limited to credit card payments. In other embodiments of the invention, the payment may be for a home loan payment, which may comprise a payment for first mortgage, second mortgage, HELOC, assessments due, homeowner's association dues, principal amount, interest amount, escrow amount for taxes, escrow amount for insurance, or the like. In other embodiments of the invention the payment may be for any type of good or service. Regardless of what the payment is for, the payment instrument final amount determined from a payment instrument may be identified from multiple locations on the payment instrument. For example, with respect to a check payment, the payment amount may be determined from the numbers in the check courtesy box, the legal amount spelled out in words in the legal payment area, and/or in the memo line of the check. In addition, the payment instrument final amount may be determined from a remittance document that accompanies the payment instrument, such as a remittance coupon that is mailed along with a check. The amounts in the remittance courtesy box, the minimum amount due (e.g., min pay), the last payment made (e.g., last pay), and the full balance remaining (e.g. full pay) may all be captured from the remittance document. In other embodiments this information may be stored by the institution requesting payment (e.g., a financial institution, or other entity that sends payment notifications to customers) and captured as needed for each payment. One or more confidence scores for the amounts captured from the payment instrument or the remittance document may be determined based on the quality of the images, the handwritten amounts, the typed amounts, or the like. The confidence score may be based on the quality of the image captured of the instrument (e.g., the device and software used to scan and read the paper copy), the handwriting or typeface used in the instrument, the located of the text within areas expected in the instrument, or the like. The better the image is, the clearer the handwriting or text is, and the more information in the image that is found in the proper areas of the instrument all generally result in better confidence scores (e.g., higher scores).
The amounts identified on the payment instrument (e.g., check, or the like) and remittance documents (e.g., remittance coupon, or the like) described above may be cross-checked with each other electronically in order to validate the correct amount for the payment and/or to determine how to route the payment for processing. Moreover, the one or more confidence scores for one or more amounts identified may also be utilized in order to validate the correct amount for the payment and/or to determine how to route the payment for processing. As such, the amounts listed in the fields of the payment instrument and/or remittance documents (or otherwise stored by the institution), the combination of the fields within these documents, and/or the confidence scores that indicate how accurate the amounts in the fields may be, may play a part in determining how each of the payments are routed for validation and posting to customer accounts.
Embodiments of the invention comprise systems, computer program products, and methods for providing validation and processing of a plurality of payments using a plurality of payment instruments and a plurality of remittance documents. One embodiment of the invention comprises identifying a payment instrument final amount for each of the plurality of payment instruments based on an image of each of the plurality of payment instruments. The invention further comprises identifying a remittance courtesy amount and at least one of a remittance full payment amount, a remittance minimum payment amount, or a remittance last payment amount from each of the plurality of remittance documents associated with each of the plurality of payment instruments. The invention also comprises determining if the payment instrument final amount for each of the plurality of payment instruments equals the remittance courtesy amount from each of the plurality of remittance documents associated with each of the plurality of payment instruments. The invention further comprises determining when a payment from the plurality of payment instruments has the payment instrument final amount that is equal to the remittance courtesy amount from the remittance document associated with the payment, and the payment is processed by identifying a remittance courtesy amount confidence score, and routing the payment for verification or further processing based on the remittance courtesy amount confidence score. The invention also comprises determining when the payment from the plurality of payment instruments has the payment instrument final amount that is not equal to the remittance courtesy amount from the remittance document associated with the payment, and the payment is processed by identifying a payment instrument final amount confidence score, and routing the payment for verification or further processing based on the payment instrument final amount confidence score.
In further accord with another embodiment of the invention, the payment instrument final amount is determined from a courtesy box amount and a legal line amount on the payment instrument.
In another embodiment of the invention routing the payment for verification or further processing based on the payment instrument final amount confidence score, comprises routing the payment for verification when the payment instrument final amount confidence score is less than a first threshold payment instrument final amount confidence score; determining the remittance courtesy amount confidence score when the payment instrument final amount confidence score is greater than a second threshold payment instrument final amount confidence score, for further processing based on a first threshold remittance courtesy amount confidence score; and determining the remittance courtesy amount confidence score when the payment instrument final amount confidence score is greater than the first threshold payment instrument final amount confidence score and less than the second threshold payment instrument final amount confidence score, for further processing based on a second threshold remittance courtesy amount confidence score.
In still another embodiment of the invention, further processing based on the first threshold remittance courtesy amount confidence score comprises routing the payment for verification when the remittance courtesy amount confidence score is less than the first threshold remittance courtesy amount confidence score, and routing the payment for posting when the remittance courtesy amount confidence score is greater than the first threshold remittance courtesy amount confidence score.
In yet another embodiment of the invention, further processing based on the second threshold remittance courtesy amount confidence score comprises routing the payment for verification when the remittance courtesy amount confidence score is less than the second threshold remittance courtesy amount confidence score, and routing the payment for posting when the remittance courtesy amount confidence score is greater than the second threshold remittance courtesy amount confidence score.
In further accord with an embodiment of the invention, routing the payment for verification or further processing based on the remittance courtesy amount confidence score comprises routing the payment for verification when the remittance courtesy amount confidence score is greater than a threshold remittance courtesy amount confidence score; determining if there is a three way match when the remittance courtesy amount confidence score is less than the threshold remittance courtesy amount confidence score, wherein the three way match is a determination if the payment instrument final amount equals the remit courtesy amount and at least one of the remittance full payment amount, the remittance minimum payment amount, or the remittance last payment amount; routing the payment for verification when there is the three way match; determining if the payment instrument final amount is equal to any one of the remittance full payment amount, the remittance minimum payment amount, or the remittance last payment amount when there is no three way match; and routing the payment for verification or further processing based on if the payment instrument final amount is equal to any one of the remittance amounts.
In another embodiment of the invention when the payment instrument final amount is equal to the remittance document full payment amount, routing the payment comprises determining the payment instrument final amount confidence score; routing the payment for verification when the payment instrument final amount confidence score is less than a threshold payment instrument final amount confidence score; and routing the payment for posting when the payment instrument final amount confidence score is greater than the threshold payment instrument final amount confidence score.
In still another embodiment of the invention when the payment instrument final amount is equal to the remittance document minimum payment amount, routing the payment comprises determining the payment instrument final amount confidence score; routing the payment for verification when the payment instrument final amount confidence score is less than a threshold payment instrument final amount confidence score; and routing the payment for verification when the payment instrument final amount confidence score is greater than the threshold payment instrument final amount confidence score.
In yet another embodiment of the invention when the payment instrument final amount is equal to the remittance document last payment amount, routing the payment comprises determining the payment instrument final amount confidence score; routing the payment for verification when the payment instrument final amount confidence score is less than a threshold payment instrument final amount confidence score; and routing the payment for verification when the payment instrument final amount confidence score is greater than the threshold payment instrument final amount confidence score.
In further accord with an embodiment of the invention, when the payment from the plurality of payments is routed to validation, the invention further comprises receiving a keyed payment amount and determining if the keyed payment amount is equal to the payment instrument final amount. The invention further comprises that when the keyed payment amount is equal to the payment instrument final amount, the payment is processed based on if the keyed payment amount equals the remittance courtesy amount. The invention also comprises that when the keyed payment amount is not equal to the payment instrument final amount, a determination of the payment instrument final amount confidence score is made, and the payment is routing for escalated keying when the payment instrument final amount confidence score is greater than a threshold payment instrument final amount confidence score. The invention further comprises processing the payment based on if the keyed payment amount equals the remittance courtesy amount when the payment instrument final amount confidence score is less than the threshold payment instrument final amount confidence score.
In another embodiment of the invention, when the keyed payment amount equals the remittance courtesy amount, a determination is made when the keyed payment amount equals the payment instrument final amount, the remittance full payment amount, or the remittance last payment amount. The invention further comprises that when the keyed payment amount equals the payment instrument final amount a determination of the payment instrument final amount confidence score is made. The invention further comprises routing the payment for posting when the payment instrument final amount confidence score is greater than a threshold payment instrument final amount confidence score, and routing the payment for a second keying when the payment instrument final amount confidence score is less than the threshold payment instrument final amount confidence score. Moreover, the invention comprises when the keyed payment amount equals the remittance full payment amount or the remittance last payment amount, route the payment for posting. In addition, the invention comprises when the keyed payment amount does not equal the equal the remittance full payment amount or the remittance last payment amount route the payment for the second keying.
In still another embodiment of the invention, when the keyed payment amount does not equal the remittance courtesy amount a determination of the remittance courtesy confidence score is made. Moreover, the payment is routed for escalated keying when the remittance courtesy confidence score is greater than a threshold remittance courtesy confidence score. Additionally, when the keyed payment amount equals the payment instrument final amount, the remittance full payment amount, or the remittance last payment amount, the payment is sent for further processing when the remittance courtesy confidence score is less than the threshold remittance courtesy confidence score.
The features, functions, and advantages that have been discussed may be achieved independently in various embodiments of the present invention or may be combined in yet other embodiments, further details of which can be seen with reference to the following description and drawings.
Having thus described embodiments of the invention in general terms, reference will now be made to the accompanying drawings, wherein:
Embodiments of the present invention will now be described more fully hereinafter with reference to the accompanying drawings, in which some, but not all, embodiments of the invention are shown. Indeed, the invention may be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will satisfy applicable legal requirements. Like numbers refer to like elements throughout. Although some embodiments of the invention described herein are generally described as involving a “financial institution” or “bank,” one of ordinary skill in the art will appreciate that other embodiments of the invention may involve other businesses or institutions that take the place of or work in conjunction with the financial institution or bank to perform one or more of the processes or steps described herein as being performed by a financial institution or bank. Still in other embodiments of the invention the financial institution or bank described herein may be replaced with other types of businesses or institutions that offer payment services to customers.
Block 100 in
If the contents of the envelope are acceptable, a determination is made as to if the routing number of the remittance document was read during the scan, a determination is made as to if the routing number exists (e.g., it is a routing number for the institution processing the payment), and/or a determination is made as to if the payment instrument has a routing number. If these conditions are not met the documents (e.g., payment instrument, remittance document, envelope, or the like), or images thereof, are sent for reconciliation and/or repair, in which users 9 as described herein (or other users) determine how to process these documents. If the conditions described above are met, the payment instrument validation system 1 matches the account numbers read from the payment instrument and/or remittance document (e.g., read from multiple locations) with the account numbers stored at the institution. If there are no matches the documents (e.g., payment instrument, remittance document, envelope, or the like), or images thereof, are sent for reconciliation and/or repair. If there is at least one match the payment instrument validation system 1 determines if there are any characters in the account number that cannot be read in the images, and also determines a confidence score for the account numbers when all the characters can be read. If there is a character that cannot be read or a confidence score below a threshold level the image reads are discarded and rerun or sent for reconciliation and/or repair. If there are no missing characters and the confidence score is above a specified threshold level then a determination is made that the account number is an account number for the institution (e.g., by determining the first four or other characters for a credit card, mortgage account number, or the like). If the account number is not an account number associated with an account in the institution, the documents (e.g., payment instrument, remittance document, envelop, or the like) and/or the associated images are sent for resolution. If the account number can be read, the payment instrument validation system 1 may validate one or more other characters of the account number, such as the last account number digit. If the one or more other account characters do not match, the documents (e.g., payment instrument, remittance document, envelop, or the like) and/or the associated images are sent for reconciliation and/or repair. If the one or more other account characters do match, one or more characters from the routing and transit number of the payment instrument are validated. If the one or more characters from the payment instrument routing and transit number match, if the coupon MICR confidence score is above a threshold level, and if the coupon scanline confidence score is above a threshold level, the payment is sent for validating the amount of the payment instrument. Otherwise, the documents (e.g., payment instrument, remittance document, envelop, or the like) and/or the associated images are sent for reconciliation and/or repair.
Block 200 of
A detail process flow of the payment amount validation 200 is illustrated in
As illustrated by block 206 in
As illustrated by block 210, when the payment instrument final amount confidence score is greater than an X1 threshold level and less than an X2 threshold level a determination of the remittance courtesy amount confidence score is made. As illustrated by block 210 when the confidence score of the remittance courtesy is less than an X4 threshold level, then as illustrated by block 212 the payment is sent for verification. Returning to block 210, alternatively, when the remittance courtesy amount confidence score is greater than X3, then as illustrated by block 214 the payment is sent for automatic posting.
Returning to block 216 when the payment instrument final amount is equal to the full payment amount, then as illustrated by block 218 the payment instrument final amount confidence score is determined. As illustrated by block 214 if the payment instrument final amount confidence score is greater than an X5 threshold level, then the payment is sent for automatic posting. Returning to block 218 if the payment instrument is less than an X6 threshold level, then as illustrated by block 220 the full payment confidence score is determined. As illustrated by block 214, if the full payment confidence score is greater than an X7 threshold level then the payment is sent for automatic posting. However, returning to block 220 if the full payment confidence score is less than an X8 threshold level, then as illustrated by block 212 the payment is sent for verification.
Returning to block 222 when the payment instrument final amount is equal to the min payment amount, then the payment instrument final amount confidence score is determined as illustrated by block 224. As illustrated by block 226 when the payment instrument final amount confidence score is greater than an X9 threshold level, then the payment is sent for automatic posting. Returning to block 224 when the payment instrument final amount confidence score is less than an X10 threshold level, then the payment is sent for verification, as illustrated by block 228.
As illustrated by block 230, if the payment instrument final amount is equal to the last payment amount, then the payment instrument final amount confidence score is determined as illustrated by block 232. As illustrated by block 226 when the payment instrument final amount confidence score is greater than an X11 threshold level, then the payment is sent for automatic posting. Returning to block 232 when the payment instrument final amount confidence score is less than an X12 threshold level, then the payment is sent for verification, as illustrated by block 228.
As illustrated below, Table 1 provides various ranges and values for the X variables in
Block 300 in
As illustrated by block 304 the payment instrument validation system 1 determines if the first keyed value entered by the user 9 meets the payment instrument final amount. As illustrated by block 306, when the first keyed value equals the payment instrument final amount, a determination is made of the payment instrument final confidence score. As illustrated by block 308, if the payment instrument final amount confidence score is greater than an X13 threshold level then the payment is sent for automatic posting. Returning to block 306 in
Returning to block 304 if the first keyed payment does not equal the payment instrument final amount, then the process moves to block 312. As illustrated by block 312, a determination is made if the first keyed payment amount equals the full payment amount. As illustrated by block 308 if the first keyed payment amount equals the full payment amount then the payment is sent for automatic posting. Returning to block 312, if the first keyed payment amount does not equal the full payment amount then the process proceeds to block 314. As illustrated in block 314, a decision is made if the first keyed payment amount equals the last payment amount. As illustrated by block 308, when the first keyed payment amount equals the last payment amount then the payment is sent to posting. However, as illustrated by block 310 when the first keyed payment does not equal the last payment amount then the payment is sent for a second keying, as previously discussed.
As illustrated in block 400 in
The process flow illustrated in
Returning to block 1202, when the payment instrument final amount does not equal the remittance courtesy amount a determination is made for the remittance courtesy amount confidence score, as illustrated by block 1220. As illustrated by block 1220 when the remittance courtesy amount confidence score is greater than a Y7 threshold level, then the payment is sent for verification, as illustrated by block 1222. Returning to block 1220, when the remittance courtesy amount confidence score is less than a Y8 threshold level, then a determination is made if there is a three way match, as illustrated by block 1224. For example, the three way match may be that the payment instrument final amount equals two of the other payment amounts (e.g., remit courtesy amount, full pay, last pay, and min pay). As illustrated by block 1226, if there is a three way match then the payment is sent for posting.
However, when there is no three way match, then a determination is made if the payment instrument final amount equals any of the amounts on the remittance document, as illustrated by block 1228. As illustrated by block 1230, when the payment instrument final amount equals the full payment amount on the remittance document a payment instrument final amount confidence score is determined as illustrated by block 1232. As illustrated by block 1222, when the payment instrument final confidence score is less than a Y9 threshold level, then the payment instrument is sent for verification. Returning to block 1232, when the payment instrument final amount confidence score is greater than a Z10 threshold level, then the payment is sent for posting, as illustrated by block 1226.
Returning to block 1234, when the payment instrument final amount is equal to the minimum payment amount, then the payment instrument final amount confidence score is determined as illustrated by block 1236. As illustrated by block 1238 when the payment instrument final amount confidence score is greater than a Y11 threshold level, then the payment is sent for automatic posting. Returning to block 1236 when the payment instrument final amount confidence score is less than a Y12 threshold level, then the payment is sent for verification, as illustrated by block 1240.
Returning to block 1242, if the payment instrument final amount is equal to the last payment amount, then the payment instrument final amount confidence score is determined as illustrated by block 1244. As illustrated by block 1238 when the payment instrument final amount confidence score is greater than a Y13 threshold level, then the payment is sent for automatic posting. Returning to block 1244 when the payment instrument final amount confidence score is less than a Y14 threshold level, then the payment is sent for verification, as illustrated by block 1246.
As illustrated below, Table 2 provides various ranges and values for the Y variables in
As illustrated by block 1304 the system determines if the first keyed value entered by the user 9 meets the payment instrument final amount. If the first keyed value does not equal the payment instrument final amount, then the payment instrument final amount confidence score is determined, as illustrated by block 1306. If the payment instrument final amount confidence score is greater than a Z1 threshold value, then a new keying process is undertaken, as illustrated by block 1308. The new keying process may include escalating the investigation of the payment to a user 9 or to a specialized user 9 that has more experience and/or additional access to information (e.g., customer accounts, transactions, or the like) in order to determine additional information for resolving the payment. In other embodiments of the invention, instead of sending the payment for a new keying process, the payment is routed to a second keying process.
Returning to block 1306, when the payment instrument final amount confidence score is less than a Z2 threshold level then a determination is made if the first keyed amount equals the remittance courtesy amount, as illustrated by block 1310. Moreover, returning to block 1304, when the first keyed amount is equal to the payment instrument final amount, the process also continues to block 1310 in which the determination is made if the first keyed amount equals the remittance courtesy amount. As illustrated by block 1312, when the first keyed amount does not equal the remittance courtesy amount a determination of the remittance courtesy amount confidence score is made. When the remittance courtesy amount confidence score is greater than a Z3 threshold level, then the payment is sent for the new keying process as illustrated by block 1308. However, returning to block 1312, when the remittance courtesy amount confidence score is less than a Z4 threshold level, then a determination is made if the first keyed amount equals the payment instrument final amount, as illustrated in block 1314.
As illustrated by block 1314, when the first keyed amount equals the payment instrument final amount, a determination of the payment instrument final amount confidence score is made. Moreover, returning to block 1310, when the first keyed amount does equal the remittance courtesy amount, then a determination of the payment instrument final amount confidence score is made, as illustrated by block 1314.
As illustrated by block 1316, when the payment instrument final amount confidence score is greater than a Z5 threshold level, then the payment is sent for automatic posting, as illustrated by block 1318. Returning to block 1316, when the payment instrument final amount confidence score is less than a Z6 threshold level, then the payment is sent for second keying, as illustrated in block 1320. As previously discussed a second keying may include putting the payment back into the keying queue, submitting the payment directly to another user 9 for keying, escalating the payment to a new keying process as illustrated in block 1308, or another like keying process.
Returning to block 1314, when the first keyed amount does not equal the payment instrument final amount, then a determination is made if the first keyed amount equals the full payment amount, as illustrated by block 1322. As illustrated by block 1318, when the first keyed amount equals the full payment amount, then the payment is sent to posting. Alternatively, when the first keyed amount does not equal the full payment amount, then a determination is made if the first keyed amount equals the last payment amount, as illustrated by block 1324. As such, when the first keyed amount does equal the last payment amount, then the payment is sent for automatic posting, as illustrated by block 1318. However, returning to block 1324, when the first keyed amount does not equal the last payment amount then the payment is sent for a second key, as illustrated by block 1320.
As illustrated below, Table 3 provides various ranges and values for the Z variables in
The processes illustrated in
The embodiments of the present invention provide improvements to processing payments by reducing human interaction, reducing incorrect payments posted on customer accounts, and reducing costs associated with the incorrect payments. For example, large institutions, such as financial institutions, may process hundreds of thousands of payments on a daily basis, which correlates to millions of payments over the span of a year. As such, processing this many payments may result in hundreds or thousands of incorrect payments posted on a monthly basis, and thousands or tens of thousands of incorrect payments posted on a yearly basis. Using the processes described herein, reduces the number of incorrect payments that make it to final posting.
There are a number of features that improve the processing of the payments (e.g., reduces the number of incorrect payments posted) for example, comparing different fields between the payment instruments and remittance documents, identifying and/or altering confidence score thresholds, automatically posting payments based on the compared fields and/or confidence scores, and notifying users 9 when keying values are inconsistent with values read from the payment documents (e.g., payment instrument and/or remittance documents).
In one embodiment of the invention in order to reduce the number of payments that are sent to users 9 for keying verification, the present invention has identified that lowering the confidence threshold value, or removing the threshold altogether, for payments in which the payment instrument final amount (e.g. payment identified from the image of the payment instrument) equals the full payment amount on the remittance document (or otherwise stored by the institution). As such, Table 4 below lists the improvements in the processes achieved between the process illustrated in
Moreover, implementing a process step into the validation processing in which the payments are routed for posting when the payment instrument final amount equals the remit courtesy amount and one of the minimum pay, last pay, or full pay amounts, as illustrated in block 1224 in
A number of additional changes to the process could be made to further reduce the number of incorrect payments that post to the customers' accounts. For example, the confidence levels for processing the payments when the payment instrument final amount equals the remittance courtesy amount may be adjusted to decrease the amount of incorrect payments posted to customers' accounts with a minimal increase in the number of payments that are sent for user keying validation (as illustrated in blocks 206 and 208 in
As illustrated by the results in Table 4, by reducing the payment instrument final confidence score (e.g., reducing 90% to 80% in option #1 and 90% to 70% for option #2), and by increasing the remittance courtesy confidence score (e.g., from 0 to 30% in option #1 and from 0 to 50% in option #2), not only are the incorrect payments posted reduced (e.g., from 7 down to 2 or down to 1), but there is only a minimal increase (e.g., approximately 3,000 and 5,000 payments) in the number of payments sent to a user for verification. A single user 9 may be able to key approximately 900 payments per hour, and as such the increase in payments that are keyed by a user 9 only relates to approximately 3 to 6 hours of user time per 200,000 payments. This increase in hours may be offset by the amount of hours that another user 9 no longer would have to work to correct a payment that was incorrectly posted to a customer account.
The improvements illustrated in the processes of
The improvements illustrated in the processes of
The additional improvements illustrated in the processes in
In other embodiments of the invention other processing steps may be instituted in order to improve customer satisfaction. For example, in one embodiment when an incorrect payment amount is posted to a customer account any additional payments (e.g., the next payment, next three payments, or other like number of payments) from the same customer may be flagged and routed for escalation to a specialized user that has more experience and access to information than the verification users 9. This process routing ensures that additional payments from the customer are not posted with an incorrect amount when the customer has experienced incorrect posting of a payment in the past.
In still other examples, when there is a new user 9 verifying payments, when a particular user 9 has a threshold incorrect payment posted percentage (e.g., has repeat incorrect keying amounts), when payments are received from a particular institution or customer that has repeated images or image recognition issues, the payments associated with these users 9 or customers may automatically be routed for keying by another user 9 or escalated for a more detailed review of the payments.
The network 2 may be a global area network (GAN), such as the Internet, a wide area network (WAN), a local area network (LAN), or any other type of network or combination of networks. The network 2 may provide for wireline, wireless, or a combination of wireline and wireless communication between devices on the network 2.
As illustrated in
The processing device 14 is operatively coupled to the communication device 12 and the memory device 16. The processing device 14 uses the communication device 12 to communicate with the network 2 and other devices on the network 2, such as, but not limited to, the payment instrument reader 20, and the user computer systems 30. As such, the communication device 12 generally comprises a modem, server, or other device for communicating with other devices on the network 2.
As further illustrated in
As further illustrated in
As illustrated in
As further illustrated in
As illustrated in
It is understood that one or more of the systems, devices, applications, or the like described herein can be combined or separated into other and devices described herein in various embodiments of the invention. It is further understood that these embodiments still function in the same or similar way as the embodiments described herein. For example, the applications or parts of the applications described herein may be completely or partially stored on the systems described herein or on other systems not specifically described herein.
Any suitable computer-usable or computer-readable medium may be utilized. The computer usable or computer readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device. More specific examples (a non-exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires; a tangible medium such as a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a compact disc read-only memory (CD-ROM), or other tangible optical or magnetic storage device.
Computer program code/computer-readable instructions for carrying out operations of embodiments of the present invention may be written in an object oriented, scripted or unscripted programming language such as Java, Pearl, Smalltalk, C++ or the like. However, the computer program code/computer-readable instructions for carrying out operations of the invention may also be written in conventional procedural programming languages, such as the “C” programming language or similar programming languages.
Embodiments of the present invention described above, with reference to flowchart illustrations and/or block diagrams of methods or apparatuses (the term “apparatus” including systems and computer program products), will be understood to include that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a particular machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create mechanisms for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer readable memory produce an article of manufacture including instructions, which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions, which execute on the computer or other programmable apparatus, provide steps for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. Alternatively, computer program implemented steps or acts may be combined with operator or human implemented steps or acts in order to carry out an embodiment of the invention.
While certain exemplary embodiments have been described and shown in the accompanying drawings, it is to be understood that such embodiments are merely illustrative of, and not restrictive on, the broad invention, and that this invention not be limited to the specific constructions and arrangements shown and described, since various other changes, combinations, omissions, modifications and substitutions, in addition to those set forth in the above paragraphs, are possible. Those skilled in the art will appreciate that various adaptations, modifications, and combinations of the just described embodiments can be configured without departing from the scope and spirit of the invention. Therefore, it is to be understood that, within the scope of the appended claims, the invention may be practiced other than as specifically described herein.