An aspect includes a vehicle that includes rail inspection sensors configured for capturing transducer data describing the rail, and a processor configured for receiving and processing the transducer data in near-real time to determine whether the captured transducer data identifies a suspected rail flaw. The processing includes inputting the captured transducer data to a machine learning system that has been trained to identify patterns in transducer data that indicate rail flaws. The processing also includes receiving an output from the machine learning system, the output indicating whether the captured transducer data identifies a suspected rail flaw. An alert is transmitted to an operator of the vehicle based at least in part on the output indicating that the captured transducer data identifies a suspected rail flaw. The alert includes a location of the suspected rail flaw and instructs the operator to stop the vehicle and to perform a repair action.
|
10. A method for inspecting a rail, the method comprising:
receiving transducer data from rail inspection sensors mounted on a vehicle that is located on the rail; and
processing the transducer data to identify locations of suspected rail flaws in the rail, the processing comprising:
inputting the transducer data as a stream of overlapping sequences in a form suitable for a machine learning system that has been trained to identify patterns in the transducer data that indicate rail flaws, the machine learning system comprising a deep learning convolutional neural network to perform image pattern recognition that is combined with a long short-term memory recurrent neural network to identify rail flaws of the rail of indeterminate length;
receiving an output from the machine learning system, the output including a list of suspected rail flaws and their corresponding locations on the rail;
auditing at least one of the deep learning convolutional neural network or the long short-term memory recurrent neural network to identify at least one of a false positive or a false negative, the auditing comparing the output from the machine learning system to output from a human analyst;
adjusting the at least one of the deep learning convolutional neural network on the long short-term memory recurrent neural network based on the at least one of the false positive or the false negative; and
initiating a repair action based on the list of suspected rail flaws.
20. A computer program product for inspecting a rail, the computer program product comprising a non-transitory computer readable storage medium having program instructions embodied therewith, the program instructions executable by a processor to cause the processor to perform operations comprising:
receiving transducer data from rail inspection sensors mounted on a vehicle that is located on the rail; and
processing the transducer data to identify locations of suspected rail flaws in the rail, the processing comprising:
inputting the transducer data as a stream of overlapping sequences in a form suitable for a machine learning system, that has been trained to identify patterns in the transducer data that indicate rail flaws, the machine learning system comprising a deep learning convolutional neural network to perform image pattern recognition that is combined with a long short-term memory recurrent neural network to identify rail flaws of the rail of indeterminate length; and
receiving an output from the machine learning system, the output including a list of suspected rail flaws and their corresponding locations on the rail;
auditing at least one of the deep learning convolutional neural network or the long short-term memory recurrent neural network to identify at least one of a false positive or a false negative, the auditing comparing the output from the machine learning system to output from a human analyst;
adjusting the at least one of the deep learning convolutional neural network on the long short-term memory recurrent neural network based on the at least one of the false positive or the false negative; and
initiating a repair action based on the list of suspected rail flaws.
19. A system for inspecting a rail, the system comprising:
a non-transitory memory having computer readable instructions; and
one or more processors for executing the computer readable instructions, the computer readable instructions controlling the one or more processors to perform operations comprising:
receiving transducer data from rail inspection sensors mounted on a vehicle that is located on the rail;
processing the transducer data to identify locations of suspected rail flaws in the rail, the processing comprising:
inputting the transducer data as a stream of overlapping sequences in a form suitable for a machine learning system that has been trained to identify patterns in the transducer data that indicate rail flaws, the machine learning system comprising a deep learning convolutional neural network to perform image pattern recognition that is combined with a long short-term memory recurrent neural network to identify rail flaws of the rail of indeterminate length; and
receiving an output from the machine learning system, the output including a list of suspected rail flaws and their corresponding locations on the rail;
auditing at least one of the deep learning convolutional neural network or the long short-term memory recurrent neural network to identify at least one of a false positive or a false negative, the auditing comparing the output from the machine learning system to output from a human analyst;
adjusting the at least one of the deep learning convolutional neural network on the long short-term memory recurrent neural network based on the at least one of the false positive or the false negative; and
initiating a repair action based on the list of suspected rail flaws.
1. A vehicle for inspecting a rail, the vehicle comprising:
rail inspection sensors configured for capturing transducer data describing the rail; and
a processor configured for:
receiving the transducer data; and
processing the captured transducer data to determine whether the captured transducer data identifies a suspected rail flaw, the processing comprising:
inputting the captured transducer data as a stream of overlapping sequences in a form suitable for a machine learning system that has been trained to identify patterns in the transducer data that indicate rail flaws, the machine learning system comprising a deep learning convolutional neural network to perform image pattern recognition that is combined with a long short-term memory recurrent neural network to identify rail flaws of the rail of indeterminate length; and
receiving an output from the machine learning system, the output indicating whether the captured transducer data identifies the suspected rail flaw;
auditing at least one of the deep learning convolutional neural network or the long short-term memory recurrent neural network to identify at least one of a false positive or a false negative, the auditing comparing the output from the machine learning system to output from a human analyst;
adjusting the at least one of the deep learning convolutional neural network on the long short-term memory recurrent neural network based on the at least one of the false positive or the false negative; and
transmitting an alert to an operator of the vehicle based at least in part on the output indicating that the captured transducer data identifies a suspected rail flaw, the alert including a location of the suspected rail flaw and instructing the operator to stop the vehicle and to perform a repair action,
wherein the stream of overlapping sequences comprises a sequence of overlapping 2-dimensional images.
2. The vehicle of
3. The vehicle of
4. The vehicle of
5. The vehicle of
generating a flaw suspect list table comprising:
a test segment indicator that indicates a data acquisition recording run on the rail of the suspected rail flaw;
a rail identifier that identifies whether the suspected rail flaw is in a left rail or a right rail;
a rail pulse count indicator that indicates a distance along the rail from a start of a recording;
a code identifier that identifies a code corresponding to a type of the suspected flaw; and
a confidence identifier that indicates a level of confidence of the machine learning system.
6. The vehicle of
7. The vehicle of
8. The vehicle of
9. The vehicle of
11. The method of
12. The method of
13. The method of
14. The method of
15. The method of
16. The method of
17. The method of
18. The method of
|
The subject matter disclosed herein relates to a system and method for inspecting a rail, and in particular to a system and method for inspecting a rail using machine learning.
Railroad inspection typically involves the use of ultrasonic scanners, induction sensors, eddy current sensors, camera sensors or a combination thereof. Railroad inspection is used to detect features in a rail that could be indicative of a rail flaw. Ultrasonic techniques typically use ultrasonic transducers mounted in pliable wheels of a rail vehicle that rides over the upper surface of the rail. The wheels are filled with a coupling fluid so that the transducers mounted inside can send ultrasonic signals into the rail. The return signals are processed and used to map the locations of flaws in the rail. Once detection data is recorded, it is analyzed to identify patterns in the signals that correspond to rail flaws. These patterns are labeled to differentiate them from signals that do not relate to rail flaws such as bolt holes, rail ends, welds, and noise in the signal.
One issue with the current labeling process is that it is highly labor intensive and it requires many hours of human analysis to identify patterns that correspond to rail flaws. Human analysis is expensive and could potentially result in errors if flaws are missed due to analyst fatigue or lack of experience with a variation of a flaw type. To address these issues, human assessment is often combined with rules-based recognizer software developed to highlight transducer patterns that may indicate a rail flaw. These rule-based systems are typically tuned to accept a large number of false positives rather than risk missing a rail flaw. To remove the false positives, the results output from the rule-based system still have to be assessed by a human analyst resulting in only a moderate reduction in time.
Accordingly, while existing rail inspection systems are suitable for their intended purpose the need for improvement remains, particularly in providing a system and method of inspecting a rail using machine learning.
According to an aspect of the disclosure, a vehicle for inspecting a rail is provided. The vehicle includes rail inspection sensors configured for capturing transducer data describing the rail and a processor. The processor is configured for receiving and processing the transducer data in near-real time to determine whether the captured transducer data identifies a suspected rail flaw. The processing includes inputting the captured transducer data to a machine learning system that has been trained to identify patterns in transducer data that indicate rail flaws. The processing also includes receiving an output from the machine learning system, the output indicating whether the captured transducer data identifies a suspected rail flaw. An alert is transmitted to an operator of the vehicle based at least in part on the output indicating that the captured transducer data identifies a suspected rail flaw. The alert includes a location of the suspected rail flaw and instructs the operator to stop the vehicle and to perform a repair action.
According to other aspects of the disclosure, methods, systems, and computer program products for inspecting a rail are provided. A non-limiting example method includes receiving transducer data from rail inspection sensors mounted on a vehicle that is located on the rail. The transducer data is processed to identify locations of suspected rail flaws in the rail. The processing includes inputting the transducer data in a form suitable for a machine learning system that has been trained to identify patterns in the transducer data that indicate rail flaws. Output that includes a list of suspected rail flaws and their corresponding locations on the rail is received from the machine learning system. A repair action is initiated based on the list of suspected rail flaws.
These and other advantages and features will become more apparent from the following description taken in conjunction with the drawings.
The subject matter, which is regarded as the disclosure, is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other features, and advantages of the disclosure are apparent from the following detailed description taken in conjunction with the accompanying drawings in which:
The detailed description explains embodiments of the disclosure, together with advantages and features, by way of example with reference to the drawings.
Embodiments of the present invention are directed to a system and method for inspecting rails, such as those used with railroad tracks, using machine learning. Embodiments of the present invention provide advantages in providing automated detection of rail flaws at the accuracy level of a human analyst. The automated detection of rail flaws is performed at greater speed than human analysts and without the potential to suffer from fatigue. Embodiments of the present invention use a branch of machine learning known as deep learning neural networks to build a recognizer by training it on many thousands of examples of correctly identified flaws from human analysts. Deep learning tools that can be utilized by embodiments include, but are not limited to, convolution neural networks (CNN) to perform image recognition of segments of data, and recurrent neural networks (RNN) including “long short term memory” (LSTM) modules which can improve recognition by providing context to the segments of data.
By using machine learning tens of thousands of hours of training and experience of human analysts are embedded into computer programs, which are run at high speed and in parallel to process bulk quantities of recording runs. In an embodiment, the machine learning system produces rail flaw identifications in the same format as a human operator's results file. It is therefore easy to have it audited for accuracy in the same manner as human operators to determine that the machine learning system is performing to the same standard. The machine learning system can receive additional training at any time by being shown further examples of rail flaws. This would happen, for example, if there were new flaw types or new transducer arrangements to learn.
Embodiments of the present invention may run on a cloud computing platform where the machine learning system receives recording data and returns identification files at a high speed. Embodiments of the present invention also include embedded systems working in real-time on vehicles to aid an operator in situations where it is desired to have the operator immediately stop and verify flaw detections with additional tests. Additional embodiments of the present invention include other machine learning technologies other than neural networks such as, but not limited to: clustering; representation learning; and Bayesian networks. Further additional embodiments of the present invention include different combinations of sensors to provide the input data from which the rail flaw patterns are recognized.
Examples of rail flaws include, but are not limited to: bolt hole cracks, head and web separation, transverse defects, and vertical split heads. Signal patterns that indicate rail flaws are distinguished by exemplary embodiments of the present invention from signals that do not relate to rail flaws such as bolt holes, rail ends, welds, and noise in the signal. Rail flaws are often not detectable by the human eye, for example, bolt hole cracks are often hidden behind a plate holding the bolt holes together. In addition rail flaws can include cracks that are on the underside or internal to the rail.
Referring now to
In one embodiment, the instrument vehicle 22 has two carriages 26. In an embodiment, one of the carriages 26 includes magnetic induction detector system 32 that includes at least a pair of brushes 34 that is in contact with the rail 30. It should be appreciated that in the exemplary embodiment, there are two pairs of brushes 34 in the system 20 with one pair being associated with one rail of the pair of rails 30. The brushes 34 establish a magnetic field around the rail 30 in the area between the brushes 34. An induction sensor unit 36 is positioned just above the rail 30 and is used to sense perturbations in the magnetic field. Signals from the induction sensor unit are sent to a data processing system where the signals the associated perturbations are analyzed and compared with known defect profiles.
The system 20 further includes an ultrasonic sensor system 38 that includes one or more roller search units (RSUs) 40. Each RSU 40 includes a fluid-filled wheel 42 formed of a pliant material that deforms to establish a contact surface when the wheel 40 is in contact with and pressed against the rail 30. The fluid filled wheel 40 is mounted on an axle 44 attached to the RSU frame 46 so that the fluid filled wheel 42 contacts the rail 30 as the carriage 26 is pulled along the rail track 30. The RSU 40 includes at least one ultrasonic transducer 48 mounted inside the fluid filled wheel 42. The ultrasonic transducer 48 is configured and positioned for transmitting ultrasonic beams 50 through the fluid in the wheel 34 and through the contact surface into the rail 30 and for receiving a reflected or return beam from the rail 30. The transducers 48 generate return signals that are transmitted to a data processing system. Based on a signal generated in response to the return ultrasonic beam, defects or undesired conditions in the rail 30 may be identified.
It should be appreciated that the vehicles 22, 24 may be combined into a single vehicle 52, such as that shown in
Embodiments of the present invention are described herein use ultrasound trace data as the detection data that is input and analyzed for rail flaws. Embodiments are not limited to data generated by ultrasonic scanners, and can include data generated by any other sensors used to detect rails flaw such as, but not limited to induction sensors and eddy current sensors. In addition, embodiments are also not limited to detection data from a single type of sensor.
One reason that it is difficult for rules-based recognizers to identify a rail flaw because for every example of a rail flaw that fits the rules there will be examples of rail flaws that may be missed because they do not fit the rules (false negatives). There will also be examples of sensor signals that satisfy the criteria of the rules but are not real flaws (false positives). Because of this, rules-based systems are typically tuned to accept large numbers of potentially false positives rather than risk missing a flaw (false negative). Thus, the results still have to be assessed by a human analyst.
Human analysts require many hours of training and then many month/years of experience to become reliable at spotting the numerous types of rail flaws. The analysts must build up the skills or muscle memory through experience to recognize all the variations of rail flaw types. Even highly skilled and experienced analysts can potentially suffer from fatigue and so data is often reviewed by multiple analysts to ensure this does not happen as it could lead to missing potential rail flaws. In addition, small flaw signals can be hidden under noise signals, which can be difficult to detect in high volume situations.
Referring now to
Referring now to
As shown in
In one or more embodiments of the present invention, the neural network inference engine 302 implements a deep learning convolution neural network (DLCNN) to perform the image pattern recognition. The neural network inference engine 302 can also use a model based on a long short-term memory (LTSM) recurrent neural network to identify rail flaws of indeterminate length. These two approaches can be combined to allow detailed image recognition but provide contextual information from the recurrent neural network. In one or more embodiments of the present invention, instead of, or in addition to, a neural network, a simpler statistical or rules-based technology is utilized as good results may be possible with enhancements of the existing rules based approach for some types of detection. An example of this might be to mark sections of high noise as unsuitable for analysis. In one or more embodiments of the present invention, full coverage of the various rail flaw types involves the combination of different technologies for identifying rail flaws. For example bolt hole cracks and transverse defects are often of limited length and can be detected by DLCNN alone. Head and web separation and vertical split heads can be of indeterminate length and respond better to recurrent neural networks such as LTSMs. A combination of the two combines detailed pattern recognition with contextual information.
Once the neural network is trained to a desired level of accuracy and has been tested against previously unseen data, the training components are removed and the neural network can be used as a recognizer.
There are a variety of times when retraining of the neural network can be useful, for example, after a new transducer layout, after the addition of transducers (e.g. adding induction sensor inputs to the ultrasound input), and new types of suspected rail flaws appearing on the rails.
Referring now to
In accordance with one or more embodiments of the present invention, the transducer data is recorded and the processing described with reference to
Referring now to
As shown in
As shown in
As shown in
Referring now to
In an embodiment, the list of suspected rail flaws 602 is downloaded and added to a database of suspected rail flaws in the same format as the output generated by human labelers of rail flaws. In addition, as shown in
In accordance with one or more embodiments of the present invention neural network output is validated on a periodic or aperiodic basis by comparing it with human output (e.g. labels). Where false positives and false negatives are found these are added to the network training process by being randomly assigned either to a training set or to a validation set. In this way the training data increases and leads to a more accurate neural network. In addition, adding to the validation set can result in a more statistically significant measure of the accuracy of the neural network. The auditing process can be automated so that the neural networks continually improve their learning. In accordance with an alternate embodiment of the present invention, a new neural network is implemented with no training and it relies on feedback from human detections to gradually teach it new detections. The new neural network is run in the background and not used for rail flaw detection until it reaches the required levels of accuracy.
Referring now to
The system 700A shown in
Exemplary embodiments of the training module 710 shown in
The detecting module 712 shown in
The auditing module 714 can be implemented by the components and processing described in
Also shown in
The end user system 702 shown in
The cloud networks 706 may include one or more of any type of known networks including, but not limited to, a wide area network (WAN), a local area network (LAN), a global network (e.g. Internet), a virtual private network (VPN), and an intranet. The cloud networks 706 may include a private network in which access thereto is restricted to authorized members. The cloud networks 706 may be implemented using wireless networking technologies or any kind of physical network implementation known in the art. The components shown in
It will be understood by one of ordinary skill in the art that other network configurations may be utilized for realizing the advantages of embodiments of the present invention. The configuration shown in
As indicated above, the storage devices 718, 720, and 722 are accessible through cloud networks 706. The storage devices 718, 720, and 722 may be implemented using a variety of devices for storing electronic information. It is understood that one or more of the storage devices may be implemented using memory contained in the host computer 704 or may be separate physical devices, as illustrated in
The host computer 704 depicted in
Referring now to
Referring now to
Referring now to
Referring now to
Referring now to
Referring now to
In an exemplary embodiment, as shown in
The I/O devices 1447, 1445 may further include devices that communicate both inputs and outputs, for instance disk and tape storage, a network interface card (NIC) or modulator/demodulator (for accessing other files, devices, systems, or a network), a radio frequency (RF) or other transceiver, a telephonic interface, a bridge, a router, and the like.
The processor 1405 is a hardware device for executing hardware instructions or software, particularly those stored in memory 1412. The processor 1405 may be a custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the computer system 1400, a semiconductor based microprocessor (in the form of a microchip or chip set), a microprocessor, or other device for executing instructions. The processor 1405 can include a cache such as, but not limited to, an instruction cache to speed up executable instruction fetch, a data cache to speed up data fetch and store, and a translation look-aside buffer (TLB) used to speed up virtual-to-physical address translation for both executable instructions and data. The cache may be organized as a hierarchy of more cache levels (L1, L2, etc.).
The memory 1412 may include one or combinations of volatile memory elements (e.g., random access memory, RAM, such as DRAM, SRAM, SDRAM, etc.) and nonvolatile memory elements (e.g., ROM, erasable programmable read only memory (EPROM), electronically erasable programmable read only memory (EEPROM), programmable read only memory (PROM), tape, compact disc read only memory (CD-ROM), disk, diskette, cartridge, cassette or the like, etc.). Moreover, the memory 1412 may incorporate electronic, magnetic, optical, or other types of storage media. Note that the memory 1412 may have a distributed architecture, where various components are situated remote from one another but may be accessed by the processor 1405.
The instructions in memory 1412 may include one or more separate programs, each of which comprises an ordered listing of executable instructions for implementing logical functions. In the example of
Additional data, including, for example, instructions for the processor 1405 or other retrievable information, may be stored in storage 1427, which may be a storage device such as a hard disk drive or solid state drive. The stored instructions in memory 1412 or in storage 1427 may include those enabling the processor to execute one or more aspects of the dispatch systems and methods of this disclosure.
The computer system 1400 may further include a display controller 1425 coupled to a display 1430. In an exemplary embodiment, the computer system 1400 may further include a network interface 1460 for coupling to a network 1465. The network 1465 may be an IP-based network for communication between the computer system 1400 and an external server, client and the like via a broadband connection. The network 1465 transmits and receives data between the computer system 1400 and external systems. In an exemplary embodiment, the network 1465 may be a managed IP network administered by a service provider. The network 1465 may be implemented in a wireless fashion, e.g., using wireless protocols and technologies, such as WiFi, WiMax, etc. The network 1465 may also be a packet-switched network such as a local area network, wide area network, metropolitan area network, the Internet, or other similar type of network environment. The network 1465 may be a fixed wireless network, a wireless local area network (LAN), a wireless wide area network (WAN) a personal area network (PAN), a virtual private network (VPN), intranet or other suitable network system and may include equipment for receiving and transmitting signals.
Systems and methods for inspecting a rail using machine learning as described herein can be embodied, in whole or in part, in computer program products or in computer systems 1400, such as that illustrated in
Technical effects and benefits of some embodiments include providing a system for inspecting a rail, such as that used in railroads, using machine learning. Further technical effects and benefits include providing automated detection of rail flaws at a greater speed and at the accuracy level of a human analyst.
Technical effects and benefits of some embodiments also include the ability to use neural networks deep learning convolution neural networks and/or recurrent neural networks which can provide more accurate results when compared to contemporary approaches that utilize simpler neural networks.
Technical effects and benefits of some embodiments also include the ability to use transducer signals directly, which can result in more accurate predictions when compared to contemporary approaches that utilize statistics as inputs to the training of the neural network. The ability to carry out pattern recognition directly on two-dimensional and three-dimensional representations of sensor results as described herein is not performed by contemporary techniques. In contrast, contemporary approaches vastly simplify the many of thousands of pixels in transducer signals into a handful of statistics that are fed into a simple, non-convolutional, one-dimensional neural network with typically one hidden layer.
Technical effects and benefits of some embodiments further include the ability to train the neural network using tens of thousands of example data points (i.e., labeled data), which can result in more accurate predictions when compared to contemporary approaches that typical train using a few hundred example data points. Data can be mined from a vast library of historic recording logs to provide tens of thousands of data examples to train the neural network. This ability to harvest example data from existing manual recognition processes, and the continual comparison of the neural network results to the manually labeled examples can result in more accurate predictions. The results of the comparison can be sorted into true-positive, false-positive, and false-negative and fed back into the neural network to improve training, to audit the neural network, and to keep the neural network current.
Technical effects and benefits of some embodiments include the ability to run as easily on a stand-along computer as on a powerful cloud based computer. This makes it practical to do the highly computationally intense training process on the cloud, and the recognizer functions in a less computationally intense manner in a number of situations (e.g., performing post-processing transducer data on an office computer or a cloud computer, and performing live processing on a data acquisition vehicle).
Throughout the specification and claims, the following terms take the meanings explicitly associated herein, unless the context clearly dictates otherwise. The term “connected” means a direct connection between the items connected, without any intermediate devices. The term “coupled” means either a direct connection between the items connected, or an indirect connection through one or more passive or active intermediary devices. The term “circuit” means either a single component or a multiplicity of components, either active and/or passive, that are coupled together to provide or perform a desired function. The term “signal” means at least one current, voltage, or data signal. The term “module” means a circuit (whether integrated or otherwise), a group of such circuits, a processor(s), a processor(s) implementing software, or a combination of a circuit (whether integrated or otherwise), a group of such circuits, a processor(s) and/or a processor(s) implementing software.
The term “about” is intended to include the degree of error associated with measurement of the particular quantity based upon the equipment available at the time of filing the application. For example, “about” can include a range of ±8% or 5%, or 2% of a given value.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the disclosure. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, element components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiments were chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
The present invention may be a system, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: 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 static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Python, Java, Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood 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 readable program instructions.
These computer readable 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 machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
While the disclosure is provided in detail in connection with only a limited number of embodiments, it should be readily understood that the disclosure is not limited to such disclosed embodiments. Rather, the disclosure can be modified to incorporate any number of variations, alterations, substitutions or equivalent arrangements not heretofore described, but which are commensurate with the spirit and scope of the disclosure. Additionally, while various embodiments of the disclosure have been described, it is to be understood that the exemplary embodiment(s) may include only some of the described exemplary aspects. Accordingly, the disclosure is not to be seen as limited by the foregoing description, but is only limited by the scope of the appended claims.
Patent | Priority | Assignee | Title |
11763428, | Jun 22 2021 | Saudi Arabian Oil Company | System and method for de-noising an ultrasonic scan image using a convolutional neural network |
11802380, | Nov 04 2016 | PLASSER & THEURER EXPORT VON BAHNBAUMASCHINEN GESELLSCHAFT M B H | Track maintenance machine having a track position measuring system |
Patent | Priority | Assignee | Title |
5777891, | May 07 1991 | Harsco Technologies Corporation | Method for real-time ultrasonic testing system |
6523411, | Mar 21 2000 | INTERNATIONAL ELECTRONIC MACHINES CORP | Wheel inspection system |
6600999, | Oct 10 2000 | SPERRY RAIL HOLDINGS, INC | Hi-rail vehicle-based rail inspection system |
6768298, | Jul 17 2001 | Transportation Technology Center, Inc. | Transverse crack detection in rail head using low frequency eddy currents |
8736419, | Dec 02 2010 | ZONAR SYSTEMS, INC | Method and apparatus for implementing a vehicle inspection waiver program |
9689760, | Nov 10 2011 | The Regents of the University of California | Stress detection in rail |
20020099507, | |||
20120062743, | |||
20150373039, | |||
20160035150, | |||
20170106885, | |||
20170267264, | |||
20170286805, | |||
20170313332, | |||
20180173243, | |||
20180268255, | |||
20180308231, | |||
20190019589, | |||
CN107290428, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Nov 30 2017 | SPERRY RAIL HOLDINGS, INC. | (assignment on the face of the patent) | / | |||
Nov 30 2017 | GILBERT, DAVID HENRY | SPERRY RAIL HOLDINGS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 044256 | /0180 | |
May 17 2024 | SPERRY RAIL HOLDINGS, INC | BANK OF AMERICA, N A , AS THE LENDER | SECURITY INTEREST SEE DOCUMENT FOR DETAILS | 067474 | /0564 |
Date | Maintenance Fee Events |
Nov 30 2017 | BIG: Entity status set to Undiscounted (note the period is included in the code). |
Date | Maintenance Schedule |
Aug 03 2024 | 4 years fee payment window open |
Feb 03 2025 | 6 months grace period start (w surcharge) |
Aug 03 2025 | patent expiry (for year 4) |
Aug 03 2027 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 03 2028 | 8 years fee payment window open |
Feb 03 2029 | 6 months grace period start (w surcharge) |
Aug 03 2029 | patent expiry (for year 8) |
Aug 03 2031 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 03 2032 | 12 years fee payment window open |
Feb 03 2033 | 6 months grace period start (w surcharge) |
Aug 03 2033 | patent expiry (for year 12) |
Aug 03 2035 | 2 years to revive unintentionally abandoned end. (for year 12) |