The disclosed technology relates generally to systems for vehicle repair workflows, and more particularly, some embodiments relate to automation of those workflows.
A claimed solution rooted in computer technology overcomes problems specifically arising in the realm of computer technology.
In general, one aspect disclosed features a system, comprising: a hardware processor; and a non-transitory machine-readable storage medium encoded with instructions executable by the hardware processor to perform a method comprising: providing one or more images of a damaged vehicle as first input to a computer vision machine learning model, wherein the computer vision machine learning model has been trained with images of other damaged vehicles and corresponding vehicle repair operations; receiving first output of the computer vision machine learning model responsive to the first input, wherein the first output represents a plurality of the vehicle repair operations; providing the first output of the computer vision machine learning model to a natural language processing (NLP) machine learning model, wherein the NLP machine learning model has been trained with vehicle repair content comprising a plurality of vehicle repair procedures; and receiving second output of the NLP machine learning model responsive to the second input, wherein the second output comprises a recommended one of the plurality of the vehicle repair procedures.
Embodiments of the system may include one or more of the following features. In some embodiments, the method further comprises: generating a vehicle repair estimate based on the recommended one of the plurality of the vehicle repair procedures. In some embodiments, the method further comprises: providing the vehicle repair estimate as third input to the NLP machine learning model; and receiving third output of the NLP machine learning model responsive to the third input, wherein the third output comprises an accuracy score for the estimate. In some embodiments, the accuracy score indicates whether a line of the estimate is accurate or not accurate. In some embodiments, the accuracy score indicates whether a line of the estimate is necessary. In some embodiments, the accuracy score indicates whether a cost of a line of the estimate is above a corresponding predetermined threshold. In some embodiments, the third output of the NLP machine learning model comprises a vehicle repair procedure.
In general, one aspect disclosed features a non-transitory machine-readable storage medium encoded with instructions executable by a hardware processor of a computing component, the machine-readable storage medium comprising instructions to cause the hardware processor to perform a method comprising: providing one or more images of a damaged vehicle as first input to a computer vision machine learning model, wherein the computer vision machine learning model has been trained with images of other damaged vehicles and corresponding vehicle repair operations; receiving first output of the computer vision machine learning model responsive to the first input, wherein the first output represents a plurality of the vehicle repair operations; providing the first output of the computer vision machine learning model to a natural language processing (NLP) machine learning model, wherein the NLP machine learning model has been trained with vehicle repair content comprising a plurality of vehicle repair procedures; and receiving second output of the NLP machine learning model responsive to the second input, wherein the second output comprises a recommended one of the plurality of the vehicle repair procedures.
Embodiments of the non-transitory machine-readable storage medium may include one or more of the following features. In some embodiments, the method further comprises: generating a vehicle repair estimate based on the recommended one of the plurality of the vehicle repair procedures. In some embodiments, the method further comprises: providing the vehicle repair estimate as third input to the NLP machine learning model; and receiving third output of the NLP machine learning model responsive to the third input, wherein the third output comprises an accuracy score for the estimate. In some embodiments, the accuracy score indicates whether a line of the estimate is accurate or not accurate. In some embodiments, the accuracy score indicates whether a line of the estimate is necessary. In some embodiments, the accuracy score indicates whether a cost of a line of the estimate is above a corresponding predetermined threshold. In some embodiments, the third output of the NLP machine learning model comprises a vehicle repair procedure.
In general, one aspect disclosed features a computer-implemented method comprising: providing one or more images of a damaged vehicle as first input to a computer vision machine learning model, wherein the computer vision machine learning model has been trained with images of other damaged vehicles and corresponding vehicle repair operations; receiving first output of the computer vision machine learning model responsive to the first input, wherein the first output represents a plurality of the vehicle repair operations; providing the first output of the computer vision machine learning model to a natural language processing (NLP) machine learning model, wherein the NLP machine learning model has been trained with vehicle repair content comprising a plurality of vehicle repair procedures; and receiving second output of the NLP machine learning model responsive to the second input, wherein the second output comprises a recommended one of the plurality of the vehicle repair procedures.
Embodiments of the computer-implemented method may include one or more of the following features. Some embodiments comprise generating a vehicle repair estimate based on the recommended one of the plurality of the vehicle repair procedures. Some embodiments comprise providing the vehicle repair estimate as third input to the NLP machine learning model; and receiving third output of the NLP machine learning model responsive to the third input, wherein the third output comprises an accuracy score for the estimate. In some embodiments, the accuracy score indicates whether a line of the estimate is accurate or not accurate. In some embodiments, the accuracy score indicates whether a line of the estimate is necessary. In some embodiments, the accuracy score indicates whether a cost of a line of the estimate is above a corresponding predetermined threshold.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee.
The present disclosure, in accordance with one or more various embodiments, is described in detail with reference to the following figures. The figures are provided for purposes of illustration only and merely depict typical or example embodiments.
The figures are not exhaustive and do not limit the present disclosure to the precise form disclosed.
With the advent of high-power, cost effective computing systems came the increased automation of numerous facets of our contemporary society. In the insurance and other casualty and loss industries, for example, computerized claims estimating, processing, tracking and payment systems have long been in use to streamline processes and to expedite claims handling and closure.
Despite these advances, vehicle repair remains a long and tedious process, requiring input and review from multiple parties involved in the estimating and repair workflow, often involving the review of lengthy original equipment manufacturer documents such as vehicle specifications that may number in the tens of thousands of pages. In some cases, such reviews lead to flawed repair procedures, which may include vague instructions, unnecessary steps, and the like. And in some cases this process produces flawed estimates, for example including excessive costs for certain lines of the estimate. These flaws are often spotted by skilled reviewers such as insurance adjusters.
In this description, various embodiments are disclosed for vehicle repair workflow automation. However, embodiments of the disclosed technology apply to other processes as well. For example, embodiments may apply to generating estimates for medical procedures, and the like. These and other applications will be apparent to one skilled in the relevant art after reading this description. Before describing embodiments of the disclosed technology in detail, it is useful to describe an example environment in which the disclosed technology may be implemented.
The system 100 may include a vehicle repair workflow automation tool 102, which may be implemented as one or more software packages executing on one or more server computers 104. Each user may employ a respective client device 122, 124, 126, 128 to access the tool 102 over a network 130 such as the Internet.
The system 100 may include one or more machine learning models (MLL) 108. For example, the machine learning models 108 may include a computer vision machine learning model 132, a natural language processing machine learning model 134, and the like. The system 100 may include one or more databases 106, which may store vehicle repair procedures, completed estimates, estimates in process, data regarding parts, part costs, labor, labor costs, and the like. The databases 106 may include one or more natural language processing (NLP) databases 136. The natural language processing databases 136 may include rules, documents, and the like for use with the natural language processing machine learning model 134.
Next, a vehicle damage assessment is performed, at 210. For example, a staff appraiser of an insurance company may visit the damaged vehicle to take photos of the damage. Alternatively, the owner may send photos of the damaged vehicle to the insurance company. Next, the process may include the generation of vehicle repair procedures, vehicle repair estimates, and the like, at 212. This step may employ one or more machine learning models, for example as described in detail below.
During review of the vehicle repair estimate, a “delta” may occur, at 214. That is, one or more of the reviewers, for example such as an estimator, may disagree with some or all of the repair estimate. When a delta occurs, the process 200 may return to the generation of vehicle repair procedures, vehicle repair estimates, and the like, at 212, and may include generating a supplement estimate. When no additional deltas occur, at 214, the repair of the vehicle may take place, at 216, and the repaired vehicle may be delivered to the vehicle owner, at 218.
Referring again to
Referring again to
The process 300 may include receiving output of the NLP machine learning model responsive to the input, at 308. In some embodiments, the output may comprise a recommended procedure. In some embodiments, the NLP machine learning model may determine the recommended vehicle repair operation according to all or part the process that follows.
The NLP machine learning model may determine a confidence metric based on the values output by the computer vision model. Determining the confidence metric may include obtaining a difference between the two highest values in the set of values output by the model. Continuing the example of
The NLP machine learning model may compare the confidence metric with a confidence threshold value. When the confidence metric falls below the confidence threshold value the NLP machine learning model may not select a recommended vehicle repair operation. In the example of
Referring again to
In some embodiments, the NLP machine learning model may be used to review specific vehicle repair procedures contained in the vehicle repair estimate. Referring again to
In some embodiments, the accuracy score may indicate whether a line of the estimate is necessary. For example, while the estimate indicates a test drive need not be performed after the replacement of a front radar sensor of a vehicle, the accuracy score may indicate the test drive is necessary. In some embodiments, the accuracy score may indicate whether a cost of a line of the estimate is above a corresponding predetermined threshold.
In some embodiments, the output of the NLP machine learning model may include a vehicle repair procedure. The vehicle repair procedure output by the NLP machine learning model may differ from the corresponding vehicle repair procedure ingested by the NLP machine learning model. For example, the vehicle repair procedure output by the NLP machine learning model may clarify vague instructions, omit unnecessary steps, and the like.
Various embodiments may train one or more of the disclosed machine learning models using supervised machine learning, unsupervised machine learning, and combinations thereof. In supervised machine learning, given some data collected over the past, one can predict an output from an algorithm given an input. This can be written as:
f(X)=y,
where f is the learning (algorithm) function. The algorithm learns the distribution of X data that maximizes the probability of y. However, in a real world production environment X data changes over time, and changes because of the learning algorithm.
Machine learning may include reinforcement learning (RL). RL features an Environment, which in the disclosed embodiments is the real world. RL also features an Agent which acts in the Environment. The Environment provides a reward signal that the Agent uses to maximize some objective reward function. In supervised learning, the Environment and Agent are used, but the reward function is not used.
Embodiments of the disclosed technology may provide several advantages compared with previous solutions. For example, the disclosed technology may improve the accuracy of vehicle repair estimates, resulting in fewer disagreements among reviewers of the estimate, thereby providing a more streamlined vehicle repair workflow. As another example, the disclosed technology may improve the clarity of vehicle repair procedures for repair technicians, thereby improving the quality of the repairs, while also reducing the required time and costs of the repairs.
The computer system 700 also includes a main memory 706, such as a random access memory (RAM), cache and/or other dynamic storage devices, coupled to bus 702 for storing information and instructions to be executed by processor 704. Main memory 706 also may be used for storing temporary variables or other intermediate information during execution of instructions to be executed by processor 704. Such instructions, when stored in storage media accessible to processor 704, render computer system 700 into a special-purpose machine that is customized to perform the operations specified in the instructions.
The computer system 700 further includes a read only memory (ROM) 708 or other static storage device coupled to bus 702 for storing static information and instructions for processor 704. A storage device 710, such as a magnetic disk, optical disk, or USB thumb drive (Flash drive), etc., is provided and coupled to bus 702 for storing information and instructions.
The computer system 700 may be coupled via bus 702 to a display 712, such as a liquid crystal display (LCD) (or touch screen), for displaying information to a computer user. An input device 714, including alphanumeric and other keys, is coupled to bus 702 for communicating information and command selections to processor 704. Another type of user input device is cursor control 716, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to processor 704 and for controlling cursor movement on display 712. In some embodiments, the same direction information and command selections as cursor control may be implemented via receiving touches on a touch screen without a cursor.
The computing system 700 may include a user interface module to implement a GUI that may be stored in a mass storage device as executable software codes that are executed by the computing device(s). This and other modules may include, by way of example, components, such as software components, object-oriented software components, class components and task components, processes, functions, attributes, procedures, subroutines, segments of program code, drivers, firmware, microcode, circuitry, data, databases, data structures, tables, arrays, and variables.
In general, the word “component,” “engine,” “system,” “database,” data store,” and the like, as used herein, can refer to logic embodied in hardware or firmware, or to a collection of software instructions, possibly having entry and exit points, written in a programming language, such as, for example, Java, C, C++, and Python. A software component may be compiled and linked into an executable program, installed in a dynamic link library, or may be written in an interpreted programming language such as, for example, BASIC, Perl, or Python. It will be appreciated that software components may be callable from other components or from themselves, and/or may be invoked in response to detected events or interrupts. Software components configured for execution on computing devices may be provided on a computer readable medium, such as a compact disc, digital video disc, flash drive, magnetic disc, or any other tangible medium, or as a digital download (and may be originally stored in a compressed or installable format that requires installation, decompression or decryption prior to execution). Such software code may be stored, partially or fully, on a memory device of the executing computing device, for execution by the computing device. Software instructions may be embedded in firmware, such as an EPROM. It will be further appreciated that hardware components may be comprised of connected logic units, such as gates and flip-flops, and/or may be comprised of programmable units, such as programmable gate arrays or processors.
The computer system 700 may implement the techniques described herein using customized hard-wired logic, one or more ASICs or FPGAs, firmware and/or program logic which in combination with the computer system causes or programs computer system 700 to be a special-purpose machine. According to one embodiment, the techniques herein are performed by computer system 700 in response to processor(s) 704 executing one or more sequences of one or more instructions contained in main memory 706. Such instructions may be read into main memory 706 from another storage medium, such as storage device 710. Execution of the sequences of instructions contained in main memory 706 causes processor(s) 704 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions.
The term “non-transitory media,” and similar terms, as used herein refers to any media that store data and/or instructions that cause a machine to operate in a specific fashion. Such non-transitory media may comprise non-volatile media and/or volatile media. Non-volatile media includes, for example, optical or magnetic disks, such as storage device 710. Volatile media includes dynamic memory, such as main memory 706. Common forms of non-transitory media include, for example, a floppy disk, a flexible disk, hard disk, solid state drive, magnetic tape, or any other magnetic data storage medium, a CD-ROM, any other optical data storage medium, any physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, NVRAM, any other memory chip or cartridge, and networked versions of the same.
Non-transitory media is distinct from but may be used in conjunction with transmission media. Transmission media participates in transferring information between non-transitory media. For example, transmission media includes coaxial cables, copper wire and fiber optics, including the wires that comprise bus 702. Transmission media can also take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
The computer system 700 also includes a communication interface 718 coupled to bus 702. Network interface 718 provides a two-way data communication coupling to one or more network links that are connected to one or more local networks. For example, communication interface 718 may be an integrated services digital network (ISDN) card, cable modem, satellite modem, or a modem to provide a data communication connection to a corresponding type of telephone line. As another example, network interface 718 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN (or a WAN component to communicate with a WAN). Wireless links may also be implemented. In any such implementation, network interface 718 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
A network link typically provides data communication through one or more networks to other data devices. For example, a network link may provide a connection through local network to a host computer or to data equipment operated by an Internet Service Provider (ISP). The ISP in turn provides data communication services through the world wide packet data communication network now commonly referred to as the “Internet.” Local network and Internet both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals on network link and through communication interface 718, which carry the digital data to and from computer system 700, are example forms of transmission media.
The computer system 700 can send messages and receive data, including program code, through the network(s), network link and communication interface 718. In the Internet example, a server might transmit a requested code for an application program through the Internet, the ISP, the local network and the communication interface 718.
The received code may be executed by processor 704 as it is received, and/or stored in storage device 710, or other non-volatile storage for later execution.
Each of the processes, methods, and algorithms described in the preceding sections may be embodied in, and fully or partially automated by, code components executed by one or more computer systems or computer processors comprising computer hardware. The one or more computer systems or computer processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as a “software as a service” (SaaS). The processes and algorithms may be implemented partially or wholly in application-specific circuitry. The various features and processes described above may be used independently of one another, or may be combined in various ways. Different combinations and sub-combinations are intended to fall within the scope of this disclosure, and certain method or process blocks may be omitted in some implementations. The methods and processes described herein are also not limited to any particular sequence, and the blocks or states relating thereto can be performed in other sequences that are appropriate, or may be performed in parallel, or in some other manner. Blocks or states may be added to or removed from the disclosed example embodiments. The performance of certain of the operations or processes may be distributed among computer systems or computers processors, not only residing within a single machine, but deployed across a number of machines.
As used herein, a circuit might be implemented utilizing any form of hardware, or a combination of hardware and software. For example, one or more processors, controllers, ASICs, PLAs, PALs, CPLDs, FPGAs, logical components, software routines or other mechanisms might be implemented to make up a circuit. In implementation, the various circuits described herein might be implemented as discrete circuits or the functions and features described can be shared in part or in total among one or more circuits. Even though various features or elements of functionality may be individually described or claimed as separate circuits, these features and functionality can be shared among one or more common circuits, and such description shall not require or imply that separate circuits are required to implement such features or functionality. Where a circuit is implemented in whole or in part using software, such software can be implemented to operate with a computing or processing system capable of carrying out the functionality described with respect thereto, such as computer system 700.
As used herein, the term “or” may be construed in either an inclusive or exclusive sense. Moreover, the description of resources, operations, or structures in the singular shall not be read to exclude the plural. Conditional language, such as, among others, “can,” “could,” “might,” or “may,” unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey that certain embodiments include, while other embodiments do not include, certain features, elements and/or steps.
Terms and phrases used in this document, and variations thereof, unless otherwise expressly stated, should be construed as open ended as opposed to limiting. Adjectives such as “conventional,” “traditional,” “normal,” “standard,” “known,” and terms of similar meaning should not be construed as limiting the item described to a given time period or to an item available as of a given time, but instead should be read to encompass conventional, traditional, normal, or standard technologies that may be available or known now or at any time in the future. The presence of broadening words and phrases such as “one or more,” “at least,” “but not limited to” or other like phrases in some instances shall not be read to mean that the narrower case is intended or required in instances where such broadening phrases may be absent.