Embodiments of the present invention generally relate to equipment monitoring, and specifically, to remotely monitoring heavy duty machinery.
Industrial machinery, such as drilling equipment, requires maintenance to maintain machine uptime. As machines increase in size, complexity, and cost, failure to maintain the machine results in greater impact to production and cost. Information on why a machine failed is often not captured, thereby making it difficult to identify and troubleshoot any problems that led to the failure. Furthermore, even if the information is captured, it is usually stored onboard the machine, which requires that the information be accessed and pulled from the machine. These issues hinder root cause analysis and condition-based maintenance initiatives and make remote maintenance monitoring difficult or impossible.
Therefore, embodiments of invention provide systems and methods for capturing information related to machine performance and making the information accessible to remote maintenance staff. The information can be used to generate alarms, determine a state of the machine, determine performance statistics for the machine, and identify problems with the machine that may require attention (e.g., identifying when a particular part of the machine should be replaced). The information can be presented to remote maintenance staff on a computer-generated dashboard and can be presented in various forms, including graphical displays, color-coded displays, summary report, trends, graphs, charts, lists, waveforms, etc.
The systems and methods provide a better way to obtain details of the machinery state and cycles. The information can be provided in a state message and the data can be packaged as XML data or in a string format. These messages can be structured according to industry standards that abide by Object Linking and Embedding (OLE) for Process Control (OPC) Specifications and can be used by many external production monitoring systems.
In some embodiments, the invention provides a method of monitoring a mining machine. The method includes determining that the mining machine is operating in a first operation state of a plurality of defined operation states of the mining machine and detecting a transition of the mining machine from the first operation state to a second operation state of the plurality of defined operation states. The method includes monitoring mining machine parameters of the mining machine. The method further includes generating a state exit message indicating an end of the first operation state and generating a state start message indicating a start of the second operation state. The state exit message includes a first set of the mining machine parameters associated with the first operation state, while the state start message includes a second set of the mining machine parameters associated with the second operation state.
In some embodiments, the invention provides a mining machine monitor for monitoring a mining machine. The mining machine monitor includes a monitoring module that monitors mining machine parameters of the mining machine. The mining machine monitor further includes a state machine module and a message generating module. The state machine module determines that the mining machine is operating in a first operation state of a plurality of defined operation states of the mining machine, and detects a transition of the mining machine from the first operation state to a second operation state of the plurality of defined operation states. The message generating module generates a state exit message indicating an end of the first operation state and generates a state start message indicating a start of the second operation state. The state exit message includes a first set of the mining machine parameters associated with the first operation state, while the state start message includes a second set of the mining machine parameters associated with the second operation state.
In some embodiments, the invention provides a method of monitoring a mining drill. The method includes drilling a hole with the mining drill and monitoring mining machine parameters of the mining drill. The method further includes determining when the mining drill reaches a plurality of progress thresholds while drilling the hole, each progress threshold representing a depth of the hole. In response, the method includes generating a drill context message each time the mining drill is determined to reach one of the progress thresholds. The drill context message including a first set of the mining machine parameters associated with the mining drill.
In some instances, the method further includes determining that the mining drill has completed drilling the hole; and generating a hole end message indicating that the hole has been drilled. The hole end message includes a second set of the mining machine parameters different than the first set of the mining machine parameters. In some instances, the method further includes determining that the mining drill is operating in a new operation state; and generating a state start message indicating a start of the new operation state. The state start message includes third set of the mining machine parameters associated with the new operation state.
In some embodiments, the invention provides a mining machine monitor for monitoring a mining drill. The mining machine monitor includes a monitoring module that monitors mining machine parameters of the mining drill; a state machine module that determines that the mining drill is operating in a drill state; and a message generating module. The message generating module monitors progress of the mining drill in drilling the hole; determines when the mining drill reaches a plurality of progress thresholds while drilling the hole, each progress threshold representing a depth of the hole; and generates a drill context message each time the mining drill is determined to reach one of the progress thresholds, the drill context message including a first set of the mining machine parameters associated with the mining drill.
In some instances, the state machine module further determines that the mining drill has completed drilling the hole; and the message generating module further generates a hole end message indicating that the hole has been drilled. The hole end message includes a second set of the mining machine parameters different than the first set of the mining machine parameters. In some instances, the state machine module determines that the mining drill is operating in a new operation state; and the message generating module generates a state start message indicating a start of the new operation state. The state start message includes a third set of the mining machine parameters associated with the new operation state.
In some embodiments, the invention provides a method of monitoring a mining machine. The method includes monitoring mining machine parameters of the mining machine and the operation state of the mining machine. The method further includes determining that the mining machine is operating in a first operation state of a plurality of defined operation states of the mining machine. The method further includes generating a first state message indicating the first operation state and including a first set of the mining machine parameters associated with the first operation state. The method further includes determining that the mining machine is operating in a second operation state of the plurality of defined operation states and generating a second state message indicating a the second operation state including a second set of the mining machine parameters associated with the second operation state.
In some instances, the method further includes detecting a state transition from the first operation state to the second operation state and, in response, generating a third state message indicting the second operation state and including a third set of mining machine parameters associated with the transition.
In some embodiments, the invention provides a mining machine monitor for monitoring a mining machine. The mining machine monitor includes a monitoring module that monitors mining machine parameters of the mining machine. The mining machine monitor further includes a state machine module that determines the operating state of the mining machine and a message generating module that generates and outputs messages with state-specific parameters. The state machine module determines that the mining machine is operating in a first operation state of a plurality of defined operation states of the mining machine. Accordingly, the message generating module generates a first state message indicating the first operation state and including a first set of the mining machine parameters associated with the first operation state. The state machine later determines that the mining machine is operating in a second operation state of the plurality of defined operation states. Accordingly, the message generating module generates a second state message indicating a the second operation state including a second set of the mining machine parameters associated with the second operation state.
In some instances, the state machine module further includes detecting a state transition from the first operation state to the second operation state. In response, the message generating module generates a third state message indicting the second operation state and including a third set of mining machine parameters associated with the transition.
Before any embodiments of the invention are explained in detail, it is to be understood that the invention is not limited in its application to the details of construction and the arrangement of components set forth in the following description or illustrated in the following drawings. The invention is capable of other embodiments and of being practiced or of being carried out in various ways. Also, it is to be understood that the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including,” “comprising” or “having” and variations thereof herein is meant to encompass the items listed thereafter and equivalents thereof as well as additional items. The terms “mounted,” “connected” and “coupled” are used broadly and encompass both direct and indirect mounting, connecting and coupling. Further, “connected” and “coupled” are not restricted to physical or mechanical connections or couplings, and can include electrical connections or couplings, whether direct or indirect. Also, electronic communications and notifications may be performed using any known means including direct connections, wireless connections, etc.
It should also be noted that a plurality of hardware and software based devices, as well as a plurality of different structural components may be used to implement the invention. In addition, it should be understood that embodiments of the invention may include hardware, software, and electronic components or modules that, for purposes of discussion, may be illustrated and described as if the majority of the components were implemented solely in hardware. However, one of ordinary skill in the art, and based on a reading of this detailed description, would recognize that, in at least one embodiment, the electronic based aspects of the invention may be implemented in software (e.g., stored on non-transitory computer-readable medium) executable by one or more processors. As such, it should be noted that a plurality of hardware and software based devices, as well as a plurality of different structural components may be utilized to implement the invention. Furthermore, and as described in subsequent paragraphs, the specific mechanical configurations illustrated in the drawings are intended to exemplify embodiments of the invention and that other alternative mechanical configurations are possible. For example, “controllers” described in the specification can include standard processing components, such as one or more processors, one or more computer-readable medium modules, one or more input/output interfaces, and various connections (e.g., a system bus) connecting the components.
The shovel 100 also includes taut suspension cables 150 coupled between the base 110 and dipper shaft 130 for supporting the dipper shaft 130; a hoist cable 155 attached to a winch (not shown) within the base 110 for winding the cable 155 to raise and lower the dipper 140; and a dipper door cable 160 attached to another winch (not shown) for opening the door 145 of the dipper 140. In some instances, the shovel 100 is a P&H® 4100 series shovel produced by P&H Mining Equipment Inc., although the shovel 100 can be another type or model of electric mining equipment.
When the tracks 105 of the mining shovel 100 are static, the dipper 140 is operable to move based on three control actions, hoist, crowd, and swing. The hoist control raises and lowers the dipper 140 by winding and unwinding hoist cable 155. The crowd control extends and retracts the position of the handle 135 and dipper 140. In one embodiment, the handle 135 and dipper 140 are crowded by using a rack and pinion system. In another embodiment, the handle 135 and dipper 140 are crowded using a hydraulic drive system. The swing control swivels the handle 135 relative to the swing axis 125. During operation, an operator controls the dipper 140 to dig earthen material from a dig location, swing the dipper 140 to a dump location, release the door 145 to dump the earthen material, and tuck the dipper 140 to cause the door 145 to close, and swing to the same or another dig location.
The shovel 100 further includes an AC power supply (not shown) for driving various motors and components. The AC power supply may be transformed, rectified, inverted, filtered, and otherwise conditioned to power various AC and DC motors and components of the shovel 100. For instance, the shovel 100 may use the AC power supply to drive motors for propelling the shovel 100 via tracks 105 and for driving the hoist, crowd, and swing motors. Additionally, the shovel 100 may further include an internal combustion engine, such as a diesel engine, to drive hydraulic pumps for various hydraulic systems of the shovel 100.
The drill 170 includes tracks 172 for propelling the drill 170 forward and backward, and for turning the drill 170 (i.e., by varying the speed and/or direction of the left and right tracks relative to each other). The tracks 172 support a platform 174 including a cab 176 and a mast 178. The platform 174 includes four jacks 180 that may be selectively raised and lowered via a hydraulic system. When lowered and set, the four jacks 180 prevent movement of the drill 170 for drilling. The mast 178 supports a drill bit 182 that is rotationally driven and selectively raised and lowered to bore into an area below the platform 174.
The drill 170 further includes an AC power supply (not shown) for driving various motors and components. The AC power supply may be transformed, rectified, inverted, filtered, and otherwise conditioned to power various AC and DC motors and components of the drill 170. For instance, the drill 170 may use the AC power supply to drive motors for propelling the drill 170 via tracks 172, and for rotationally driving the drill bit 182. Furthermore, the AC power supply, post-conditioning, may drive a DC electric motor to raise and lower the drill bit 182, for instance, using a chainless rack and pinion configuration. Additionally, the drill 170 includes an internal combustion engine, such as a diesel engine, to drive hydraulic pumps for various hydraulic systems of the drill 170. For instance, the hydraulic system may be used to selectively raise and lower the jacks 180 to properly level and stabilize the drill 170 before drilling. Additionally, the hydraulic system may be used to adjust the angle of the mast 178 to provide straight or angled drilling.
The control system 200 includes a controller 205, operator controls 210, equipment controls 215, sensors 220, and a user-interface 225. The controller 205 includes a processor 235 and memory 240. The memory 240 stores instructions executable by the processor 235 and various inputs/outputs for, e.g., allowing communication between the controller 205 and the operator or between the controller 205 and sensors 220. In some instances, the controller 205 includes one or more of a microprocessor, digital signal processor (DSP), field programmable gate array (FPGA), application specific integrated circuit (ASIC), or the like.
The controller 205 receives input from the operator controls 210. For instance, in the shovel 100, the operator controls 210 include a crowd control, a swing control, a hoist control, and a door control. The crowd control, swing control, hoist control, and door control include, for instance, operator controlled input devices such as joysticks, levers, foot pedals, and other actuators. The operator controls 210 receive operator input via the input devices and output motion commands, such as analog or digital signals, to the controller 205. The motion commands include, for example, hoist up, hoist down, crowd extend, crowd retract, swing clockwise, swing counterclockwise, dipper door release, left track forward, left track reverse, right track forward, and right track reverse.
In the drill 170, the operator controls 210 include a drill feed control, drill torque/rotation speed control, mast angle control, tracks control, and jack(s) control, which may be, for instance, operator controlled input devices such as joysticks, levers, foot pedals, and other actuators. The operator controls 210 receive operator input via the input devices and output motion commands, such as analog or digital signals, to the controller 205. For the drill 170, the motion commands include, for example, drill feed up, drill feed down, drill rotation speed increase, drill rotation speed decrease, jack(s) up, jack(s) down, mast up, mast down, left track forward, left track reverse, right track forward, and right track reverse.
The above-described operator controls are exemplary. Other operator controls may be conveyed to the shovel 100, the drill 170, and other mining machines as well.
Upon receiving a motion command, the controller 205 generally controls the equipment 215 as commanded by the operator. In the shovel 100, the equipment 215 includes one or more crowd motors, swing motors, hoist motors, door latch motors, and track motors. For instance, if the operator indicates via swing control to rotate the handle 135 counterclockwise, the controller 305 will generally control the swing motor to rotate the handle 135 counterclockwise.
In the drill 170, the equipment 215 includes one or more drill rotational motors, drill feed motors, jack hydraulics, mast angle motors, and tracks motors. For instance, if the operator indicates via drill feed control to lower the drill bit 182, the controller 205 will generally lower the drill bit 182, absent, for example, an overriding safety mechanism.
The controller 205 is also in communication with a number of sensors 220 to monitor the location, movement, and status of the equipment 215. For example, for the shovel 100, the controller 205 is in communication with one or more crowd sensors, one or more swing sensors, one or more hoist sensors, and one or more door latch sensors. The crowd sensors indicate to the controller 205 the level of extension or retraction of the dipper 140. The swing sensors indicate to the controller 205 the swing angle of the handle 135. The hoist sensors indicate to the controller 205 the height of the dipper 140 based on the hoist cable 155 position. The door latch sensors indicate whether the dipper door 145 is open or closed. The door latch sensors may also include weight sensors, acceleration sensors, and inclination sensors to provide additional information to the controller 205 about the load contained within the dipper 145.
For the drill 170, the controller 205 is in communication with one or more drill rotational sensors, one or more drill feed sensors, one or more jack sensors, and one or more mast sensors. The drill rotational sensors indicate to the controller 205 the speed, torque, and acceleration of the drill bit 182. The drill feed sensors indicate to the controller 205 the position and movement of the drill feed. The jack sensors indicate the positions of the jacks (e.g., height) and movement of the jacks 180. The mast sensors indicate the position (e.g., angle) and movement of the mast 178.
The user-interface 225 provides information to the operator about the status of the mining machines, such as the shovel 100 or drill 170, and other systems communicating with the mining machines. The user-interface 225 includes one or more of the following: a display (e.g. a liquid crystal display (LCD)); one or more light emitting diodes (LEDs) or other illumination devices; a heads-up display (e.g., projected on a window of the cab 115); speakers for audible feedback (e.g., beeps, spoken messages, etc.); tactile feedback devices such as vibration devices that cause vibration of the operator's seat or operator controls 210; or another feedback device. The user-interface 225 and operator controls 210 may be positioned within a cab of the mining machine, such as the cab 115 or cab 176.
The controller 205 may also communicate with a remote device 245 via a network 247. The network 247 may include one or more servers, local area networks (LANs), wide area networks (WANs), the Internet, wireless connections, wired connections, etc. In some instances, the network 247 represents a direct, ad-hoc wireless connection between the controller 205 and the remote device 245. The remote device 245 may be, for instance, a server, a smart phone, a laptop, a personal computer, a tablet computer, etc. In the case where the remote device 245 is a server, the server may be accessible by one or more client devices (not shown), such as a smart phone, a laptop, a personal computer, a tablet computer, etc. The remote device 245 may include a processing device and a memory device, which may include a database storing mining data provided by the control system 200.
One or more state machines are defined for the mining machines, such as the shovel 100 and drill 170. The state machines define a plurality of states in which the mining machines may be. Each state definition includes an enter portion, an in-state portion, and an exit portion. The enter portion for a particular state defines the values of flags and conditions (collectively, parameters) that cause the mining machine to enter the state. The exit portion for a particular state defines the values of parameters that cause the mining machine to exit the state. The in-state portion defines parameters and/or actions of the mining machine while in a particular state.
For example,
In the typical drill cycle 312, the drill 170 may proceed through the cycles of
Each machine state has a defined set of states to which the machine may be transitioned. The defined set of states may be illustrated in a transition map for each state. Two such transition maps are illustrated in
The monitoring module 250 includes a state machine module 252, a current machine state 254, a previous machine state 256, parameters 258, a message generating module 260, and a data pre-processor 262. The state machine module 252 determines and tracks the state of the mining machine based on parameters 258, the current machine state 254, and the previous machine state 256. The current machine state 254 indicates the current state of the mining machine. The previous machine state 256 indicates the previous state of the mining machine. The current machine state 256 and previous machine state 256 may be data stored in a memory, such as memory 240.
The parameters 258 include flags, sensor data obtained from sensors 220 (e.g., depth of drill, speed of tracks 105/172, revolutions per second of various motors, and torque values), and other parameters used by the state machine module 252. The parameters 258, also referred to as mining machine parameters, may be stored in a memory, such as the memory 240.
The state tracking of the state machine module 252 is based on detecting state transitions, rather than continuously detecting the present state. Accordingly, once in a particular state, the machine will stay in that state until the state machine module 252 determines that transition criteria, i.e., exit parameters and entrance parameters, are met. The new state that is entered is based on the enter parameters of the particular state being met. A transition between one state to another may reflect transitioning between states of two state machines, or between states of one state machine. For example, when transitioning between the propel state to the level state, the drill 170 remains in the positioning state machine 308. However, transitioning from the level state to the pre-drill state reflects a transition from the positioning state machine 308 to the drilling state machine 310.
The message generating module 260 generates simple events and associated messages for output to the remote device 245 via the network 247. The simple event and associated message may be referred to collectively as a simple event message or a contextual message. The message generating module 260 receives an indication from the state machine module 252 when the mining machine has entered or exited a state. In response, the message generating module 260 generates and outputs a simple event message. For example, a simple event message may be generated and output upon exiting a pre-drill state and upon entering a drill state. Thus, two simple event messages, an enter drill state message and an exit pre-drill state message, may be output from a single state transition. In some embodiments, rather than a separate enter and exit message, a single simple event message (a transition message) is generated that is particular to the transition that occurred, such as a pre-drill to drill state message.
Additionally, the message generating module 260 determines to generate a simple event message without prompting from the state machine 252. The message generating module 260 may monitor parameters 258 and, upon determining certain conditions are met, generate and output a simple event message. For example, the message generating module 260 may trigger based on reaching various progress thresholds during operation. For instance, while the drill 170 drills a hole in the drill state, the message generating module 260 will trigger a simple event on each foot of drilling, with each foot of hole-depth being a separate progress threshold. Accordingly, the message generating module 260 will generate and output a simple event message regarding the drill 170 and its current operation for each foot drilled. In other embodiments, different progress thresholds are used, such as six inches, five feet, or ten feet.
In some embodiments, the message generating module 260 uses time-based thresholds to generate simple event messages periodically while within a state. For instance, a simple event message may be generated while in a particular state every ten seconds, minute, five minutes, etc. The time between generating simple event messages may vary by state. For instance, a state that lasts several minutes may have a longer elapsed time between simple event messages than a state that lasts less than a minute.
Simple event messages generated by the message generating module 260 include an indication of the simple event (e.g., a simple event name), one or more of the current machine state 254, previous machine state 256, and all or a select portion of the parameters 258. In some instances, the simple event messages or portions thereof are displayed on the user-interface 225 instead of or in addition to providing the messages to the remote device 245.
A simple event message is used to notify maintenance staff of errors and warnings that generally do not require operator intervention. The information added via an associated message makes the simple event more valuable to maintenance staff and other machine operators. In addition, the simple event can be subscribed to using an OPC Alarm and Event server, which allows the events and associated messages to be received and processed by external systems (e.g., the remote device 245) and operators. In some embodiments, the simple events and/or the associated messages are structured as extensible markup language (“XML”) data. XML is an open standard specification produced by the World Wide Web Consortium (“W3C”) that is known for its structured data that can be used to store and transfer data. Therefore, additional information about the machine can be packaged as XML and passed as a message with a simple event.
The information provided with the simple event can be used by various production monitoring systems. For example, the parameters 258 may be packaged into an XML data structure provided with the simple event, which can then be used as desired by a original equipment manufacturer (“OEM”) receiving the simple even message. For instance, the OEM may use some of the parameters 258 to calculate specific energy or efforts required to drill a portion of a hole (e.g., each foot of a hole). Additionally, various mines use various methods to calculate the specific energy and blasting index. By using the above described systems, third-party software can obtain the XML message provided by the message generating module 260 and can use all or a subset of the parameters 258 contained in the message to perform a calculation of energy or effort. In this regard, the standard information that is minimally required to perform such a calculation are included in the XML structure and the third-party software can use all or a subset of the information to perform a predetermined calculation.
For example, in some embodiments, the efforts required to drill each foot of a hole can be calculated using some of the parameters 258 such as rate of penetration (“ROP”), pull down pressure, torque, RPM, weight on bit, and bit air pressure. These parameters can be included in the message associated with a simple event.
As noted above, the simple event message can include structured XML, but the message may also include delimited text (e.g., text delimited by a semi-colon, comma, or another identifiable character). The third-party monitoring system can use the data included in the simple event message and customer- or location-specific information, such as the diameter of the hole being drilled, the diameter of the drill bit 182 being used, and soil information, to calculate a specific energy or effort required to drill a particular hole. The calculated energies or efforts can then be used to monitor the performance of the drill 170 and associated equipment. For example, the energy required for each drilled hole can be tracked over time to identify when a particular drill bit 182 should be replaced to maintain efficiency.
The simple event messages generated for the mining machines (e.g., the shovel 100 and dipper 170) are particular to the state of that mining machine. For example, a simple event message generated for the drill 170 while in the drill state is different than a simple event message generated for the drill 170 while in the propel state. More specifically, in a drill state, the simple event message includes a portion of the parameters 258 that are of more interest for review and analysis when the drill 170 is in the drill state. In the propel state, the simple event message includes a different portion of the parameters 258 that are of more interest for review and analysis when the drill 170 is in the propel state. Generation of the simple event message may include packaging an identification of the context of the mining machine (i.e., the state) and the pertinent portion of the parameters 258 in an XML format.
For example, on transition from the level state to the pre-drill state, the simple event message may include the hoist resolver reading (i.e., hoist position) and global positioning satellite (GPS) coordinates of the drill 170 or the bit 182. While pre-drilling, the simple event message may include the feedrate, RPM, and vibration of the bit 182. The simple event message may not leave out the GPS position because the absolute position of the drill 170 and bit 182 may be derived from a current hoist resolver reading and the previously-sent GPS coordinates and hoist resolver reading. Furthermore, on transition from the pre-drill state to the drill state, the simple event message may include the hoist resolver position, the time of day, and set points of the drill 170, if in autodrill mode, or the manual settings of the drill 170, if in manual drill mode.
With respect to the shovel 100, a simple event message upon completion of a dig state may include parameters 258 obtained during the dig cycle including payload data, start position of the crowd and hoist, end position of the crowd and hoist, max hoist height, max crowd extension, root-mean-square (RMS) load current supplied to the crowd and hoist motors. In contrast, a simple event message upon completion of the tuck state may include the distance and speed data from crowd, hoist, and swing motors, but not include payload data or RMS current load data. Since the dipper 140 should be empty in a tuck state, an OEM or third party analyzing obtained data from the shovel 100 may be less concerned with the payload and motor current during a tuck operation, but more concerned with the speed and efficiency of the operator's technique to return from a dump site to the next dig cycle. A simple event message upon completion of a swing state may include data indicating when braking started during the swing operation, the change in swing angle, the RMS current load of the swing motor, and the starting and ending position of the swing motor. Accordingly, the portion of the parameters 258 included in a simple event message is different depending on the context (i.e., state) of the mining machine.
Accordingly, rather than sending all of the parameters 258 each time a simple event occurs, a portion of the parameters 258 specific to the simple event are included in a simple event message. This technique reduces the amount of data communicated, reducing the data traffic on the network 247. Additionally, in instances where the remote device 245 includes a database storing the simple event messages, the amount of data that is stored in the database is reduced and the amount of data necessary to be read from the database for performing analysis may be reduced. Accordingly, the complexity and size of the database may be reduced, while the speed of database communications (reads/writes) is increased.
A simple event message may include one or more of a simple event name, a type portion to indicate that the message is of the simple event type, a text message portion, an XML portion, and a string delimiter portion. Described below are three example simple event messages: a hole start message, a hole state message, and a hole end message.
The hole start message occurs when the drill 170 enters the drill state, at which point the depth counter should be reset and the rotary speed of the drill bit 182 should be greater than zero. An example hole start message is provided below in Table IV. The holeID parameter identifies the hole being drilled; the GPS Location parameter identifies the GPS Location of the hole; the operatorID parameter indicates the operator of the drill 170; and the shiftID parameter indicates current employee working shift (e.g., first shift, second shift, or third shift) at the time of the simple event.
The hole state message is sent for every foot of drilling and occurs in the drill state. An example hole state message is provided below in Table V. The F parameter indicates the depth of the hole in feet (ft), PD parameter indicates the pull down force in kilo-pounds (klbs); RS parameter indicates the rotary speed of the bit 182 in rotations per minute (RPM); the TQ parameter indicates the rotary torque of the bit 182 in foot-pounds (ft-lbs); the ROP parameter indicates the rate of penetration of the bit 182; the AD parameter is a binary flag that indicates whether the drill 170 is operating in an auto drill mode or manual drill mode; and the EX parameter is a binary flag that indicates whether an exception occurred, such as a excessive vibration exception. In some instances, additional parameters are included in the hole state message, such as a weight-on-bit parameter, bit air pressure parameter (pounds per square inch (PSI)), feed rate parameter (feet per minute), horizontal vibration parameter (RMS value), and vertical vibration parameter (RMS value).
The hole end message occurs when the drill 170 exits the drill state, at which point the bit 182 should be fully retracted, the jacks 180 should be up. Cleanup drilling should generally also be complete before the hole end message is sent. An example hole start message is provided below in Table VI, which includes the same parameters as the hole start message.
Although the above hole start, hole state, and hole end messages are shown as including a text portion, an XML portion, and a stringdelimiter portion, such messages may include only one or two of the text portion, XML, portion, and stringdelimiter portion.
Table VII below lists exemplary selections of the parameters 258 provided in simple event messages for the shovel 100 during various states. For example, a simple event message sent while within the tuck state includes RMS hoist armature current, Fourier transform and torque hoist field current, RMS crowd armature current, etc., but not hoist armature voltage data, hoist interpole temperature data, etc. In contrast, a simple event message sent while within the dig state includes RMS, maximum, and minimum hoist armature current; RMS, standard deviation, maximum, and minimum hoist armature voltage; etc., but not swing armature current, swing speed, etc. The particular parameters 258 sent for particular states as listed below are exemplary, and, in other embodiments, different parameters 258 are selected to be sent and not selected to be sent.
The exemplary selections of the parameters 258 listed above may be sent upon entrance to a particular state, exit from the particular state, and while within the particular state. For instance, when entering the swing state, the parameters 258 listed in the right column for each of the hoist motion, crowd motion, and swing motion may be included in a simple event message. Additionally, when exiting the swing state, the same parameters 258 may be included in a simple event message. Furthermore, once (half-way through) or periodically (e.g., every ten seconds) within the swing state, a simple event message with the same parameters 258 may be generated and sent.
In some instances, the parameters 258 included in a simple event message vary depending on whether the machine is entering a state, exiting the state, or present (remaining) in the state. For example, in some embodiments, upon entry into the tuck state, a generated simple event message includes the swing position, the crowd position, the hoist position, and the current time of day; upon exit into the tuck state, the same data is included in a generated simple event message; and while in the tuck state, the parameters 258 listed above in Table VII for the tuck state are included in a generated simple event message.
The monitoring module 250 proceeds to step 410, where the state machine module 252 determines whether a new state has been entered. If so, the state machine module 252 indicates the state transition to the message generating module 260. In response, in step 412, the message generating module 260 generates a simple event message (a “state start message”) including a different portion of the parameters 258 particular to the entered state. In step 408, the message generating module 260 outputs the generated simple event message to the remote device 245, the user interface 225, or both.
In step 416, the message generating module 260 determines whether the parameters 258 and current state machine 254 satisfy trigger conditions of a simple event. For instance, the message generating module 260 may determine that the drill 170 is in the drill state and that a progress threshold has been satisfied, such as another foot of drilling being completed. If so, the message generating module 260 generates a simple event message including a different portion of the parameters 258 particular to the simple event (step 418). In step 420, the message generating module 260 then outputs the generated simple event message to the remote device 245, the user interface 225, or both. In some instances, the message generating module 260 may determine in step 416 that a predetermined time has elapsed while within a state, or has elapsed since the last simple event message has been generated, and determine to proceed to steps 418 and 420 to generate and send a simple event message.
Returning to
Hourly, daily, monthly, and annually generated processed-data messages may include calculations data related to calculations of averages, maximums, minimums, root-mean-squared (RMS) values, standard deviation values, etc., for temperature, payload, current drawn by a motor (e.g., hoist, crowd, swing motors), vibration data, overall power consumption by the mining machine, and other data types.
A processed-data message may be sent alone or the data of a processed-data message may be incorporated into a simple event message similar to how other data (e.g., parameters 258) is sent upon the occurrence of a simple event. For example, as indicated in Table VII above, processed data, such as RMS data, may be included in simple event messages.
Accordingly, rather than sending essentially raw data continuously or in relatively quick increments (e.g., 10 minute intervals), data is collected and analyzed locally by the monitoring module 250 and resulting calculations data is sent periodically. This technique reduces the amount of data communicated, reducing the data traffic on the network 247, which improves scalability of the system for use with many mining machines. For instance, the number of reads and writes to a database of the remote server 245 that would otherwise store the raw data to-be-analyzed is drastically reduced because each individual mining machine performs a portion of the analysis. In some embodiments, the raw data is still sent to the remote device 245 for backup storage and to allow an OEM to further analyze the data as necessary.
Accordingly, embodiments of the invention provide an event-based monitoring system that packages monitored information regarding drilling equipment as XML data, which can be used by third-party monitoring systems to determine machinery states, cycles, and other productivity-related statistics.
The present application claims priority to U.S. patent application Ser. No. 13/754,082, filed Jan. 30, 2013, which claims priority to U.S. Provisional Application No. 61/632,767, filed Jan. 30, 2012, the entire contents of which is hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
5659470 | Goska et al. | Aug 1997 | A |
5844800 | Brandt et al. | Dec 1998 | A |
7143007 | Long et al. | Nov 2006 | B2 |
7246156 | Ginter et al. | Jul 2007 | B2 |
7324923 | DellaVilla et al. | Jan 2008 | B2 |
7406399 | Furem et al. | Jul 2008 | B2 |
7599939 | DeStefano et al. | Oct 2009 | B2 |
7693633 | Donnelli et al. | Apr 2010 | B2 |
8294568 | Barrett | Oct 2012 | B2 |
8838417 | Rikkola et al. | Sep 2014 | B2 |
20020124652 | Schultz et al. | Sep 2002 | A1 |
20030055666 | Roddy et al. | Mar 2003 | A1 |
20030084053 | Govrin et al. | May 2003 | A1 |
20050085973 | Furem et al. | Apr 2005 | A1 |
20050144936 | Hulse et al. | Jul 2005 | A1 |
20060271582 | Collins | Nov 2006 | A1 |
20070192063 | Abu-El-Zeet | Aug 2007 | A1 |
20080059005 | Greiner et al. | Mar 2008 | A1 |
20080059411 | Greiner et al. | Mar 2008 | A1 |
20080195365 | Ohkura et al. | Aug 2008 | A1 |
20080262820 | Nasle | Oct 2008 | A1 |
20090096637 | Olson et al. | Apr 2009 | A1 |
20090182472 | Singh et al. | Jul 2009 | A1 |
20090240481 | Durrant-Whyte et al. | Sep 2009 | A1 |
20110106384 | Corke | May 2011 | A1 |
20110108324 | Stacy, II et al. | May 2011 | A1 |
20110208567 | Roddy et al. | Aug 2011 | A9 |
20110282626 | Rikkola et al. | Nov 2011 | A1 |
20110282630 | Rikkola et al. | Nov 2011 | A1 |
20120092180 | Rikkola et al. | Apr 2012 | A1 |
20130190966 | Collins et al. | Jul 2013 | A1 |
20130197737 | Malayappalayam Shanmugam et al. | Aug 2013 | A1 |
20160356144 | Toti | Dec 2016 | A1 |
Number | Date | Country |
---|---|---|
1677287 | Oct 2005 | CN |
1273723 | Jan 2003 | EP |
WO1996016383 | May 1996 | WO |
WO2009152561 | Dec 2009 | WO |
WO2011143458 | Nov 2011 | WO |
Entry |
---|
Office Action issued by the Chilean Patent Office for related Application No. 2016-000996 dated Dec. 20, 2017 9 ( 8 pages including Statement of Relevance). |
Office Action from the Chilean Intellectual Property Office for Application No. 201300281, first known to us dated Sep. 9, 2015, (10 pages, which includes English Statement of Relevance). |
Office Action from the Chilean Intellectual Property Office for Application No. 2013-000281, first known to us dated Mar. 6, J017, (2 pages, which includes English Statement of Relevance). |
First Office Action from the Statement Intellectual Property Office of the People's Republic of China for Application No. 201310079979.1 dated May 25, 2016 (24 pages, English translation included). |
Second Office Action from the Statement Intellectual Property Office of the People's Republic of China for Application No. 201310079979.1 dated Jan. 25, 2017 (25 pages, English translation included ). |
First Office Action from the Australian Intellectual Property Office for Application No. 2015202551 dated Oct. 15, 2015, (3 pages). |
Second Office Action from the Chilean Intellectual Property Office for Application No. 201300281, first known to us dated Oct. 27, 2015, (9 pages, which includes English Statement of Relevance). |
First Office Examination from the Australian Intellectual Property Office for Application No. 2013200491 dated May 16, 2014 (7 pages). |
“The Apache Cassandra Project,” The Apache Software Foundation, 2009, retrieved from Internet <URL: cassandra. apache.org>. |
“VMware vFabricTM GemFire,” VMware, Inc., 2013, retrieved from Internet <URL: http://www.vmware.com/products/ application-platform/vfabric-gemfire/overview.html>. |
“Apache Hadoop,” The Apache Software Foundation, 2012, retrieved from Internet <URL: hadoop.apache.org>. |
Feinleib, D., “The Big Data Landscape—About,” BigDataLandscape.com, 2012, 14 pages. |
Feinleib, D., “The Big Data Landscape—Apps, Infrastructure, Technologies,” BigDataLandscape.com, Jan. 2013, 1 page. |
Office Action dated Sep. 11, 2017 by the Chilean Patent Office for related Application No. 2016-000996 (8 pages, Statement of Relevance included). |
Third Office Action from the Statement Intellectual Property Office of the People's Republic of China for Application No. 201310079979.1 dated Jul. 24, 2017 (6 pages, English Translation Included). |
Office Action from the Canadian Patent Office for related Application No. 2804075 dated Oct. 30, 2018 (4 Pages). |
Canadian Intellectual Property Office action for Application No. 2804075 dated Jun. 7, 2019 (4 pages). |
Chilean Patent Office Action for Application No. 2016000996 dated Oct. 7, 2019 (3 pages including statement of relevance). |
Number | Date | Country | |
---|---|---|---|
20170218746 A1 | Aug 2017 | US |
Number | Date | Country | |
---|---|---|---|
61632767 | Jan 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13754082 | Jan 2013 | US |
Child | 15485461 | US |