Apparatus, system and methods for alerting of abnormal drilling conditions
A method of monitoring drilling conditions includes acquiring raw data from drilling equipment and conditioning the raw data to generate conditioned data. Conditioning the raw data includes removing outlier data values and/or filtering out noise. The method further includes processing the conditioned data to generate output values. Processing the conditioned data includes determining a slope of a first set of data values of the conditioned data. The first set of data values correspond to a regression length of time. Processing the conditioned data further includes determining whether a difference between the slope of the first set of data values and a median slope determined over a median window of time exceeds a threshold. The method also includes generating an alarm based on the output values to indicate an abnormal drilling condition.
Latest CHEVRON U.S.A. INC. Patents:
- Drill bit for downhole electrocrushing drilling
- Systems and methods for independent control and operations of tubing and annulus at the wellhead
- Combined analytic technique for differentiating changes to structures using acoustic signals
- NOVEL FEED FOR WASTE PLASTIC COPROCESSING IN A REFINERY
- Diverter test cell with replaceable insert
The present application claims priority under 35 U.S.C. Section 119(e) to U.S. Provisional Patent Application No. 61/941,249, filed Feb. 18, 2014, and titled “Apparatus, System And Methods For Alerting Of Abnormal Drilling Conditions,” the entire content of which is incorporated herein by reference.
FIELD OF THE INVENTIONThe field of the invention relates to an apparatus, systems and methods for alerting of abnormal drilling conditions in the construction of wells in subterranean formations.
BACKGROUNDIn oil/gas drilling operations, early detection of abnormal drilling conditions is important. For example, influx of pressurized hydrocarbons into a wellbore during the drilling of a well, referred to in the drilling industry as a “kick” is undesirable. An early detection of a kick is valuable in drilling operations.
During the drilling of subterranean wells, individual drilling parameters may often be reviewed by a drilling engineer. Generally, available systems display different drilling parameters separately, for example, for a drill engineer to analyze. While analysis of an individual drilling parameter is useful, a reliable analysis requires consideration of multiple drilling parameters. However, analysis of large amounts of separately presented data by one or more drill engineers can lead to unreliable and inconsistent decisions about abnormal drilling conditions. Thus, apparatus, systems and processes that provide alerts about abnormal drilling conditions based on trends and relationships between different drilling parameters are desirable.
SUMMARYThe invention comprises an apparatus, system and process for characterizing multiphase fluids in a fluid flow stream. In an example embodiment, a method of monitoring drilling conditions includes acquiring raw data from drilling equipment and conditioning the raw data to generate conditioned data. Conditioning the raw data includes removing outlier data values and/or filtering out noise. The method further includes processing the conditioned data to generate output values. Processing the conditioned data includes determining a slope of a first set of data values of the conditioned data. The first set of data values correspond to a regression length of time. Processing the conditioned data further includes determining whether a difference between the slope of the first set of data values and a median slope determined over a median window of time exceeds a threshold. The method also includes generating an alarm based on the output values to indicate an abnormal drilling condition.
In another example embodiment, a method of monitoring drilling conditions includes acquiring raw data from drilling equipment and conditioning the raw data to generate conditioned data. Conditioning the raw data includes removing outlier data values and/or filtering out noise. The method further includes processing the conditioned data to generate output values. Processing the conditioned data includes determining incremental changes in data values of the conditioned data and determining whether a sum of the incremental changes exceeds a threshold. The method further includes generating an alarm based on the output values to indicate an abnormal drilling condition.
In yet another example embodiment, a system for monitoring drilling conditions includes a raw data source to provide raw data related to a drilling by a drilling rig. The system further includes a data conditioning module to generate conditioned data by removing outlier data values and/or filtering out noise. The system also includes a data processor for processing the conditioned data to generate output values. The data processor determines incremental changes in data values of the conditioned data and whether a sum of the incremental changes exceeds a threshold. The system also includes an alarm generator to generate an alarm based on the output values to indicate an abnormal drilling condition.
These and other aspects, objects, features, and embodiments will be apparent from the following description and the appended claims.
Reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, and wherein:
The drawings illustrate only example embodiments and are therefore not to be considered limiting in scope. The elements and features shown in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the example embodiments. Additionally, certain dimensions or placements may be exaggerated to help visually convey such principles. In the drawings, reference numerals designate like or corresponding, but not necessarily identical, elements.
DETAILED DESCRIPTION OF THE EXAMPLE EMBODIMENTSIn general, early detection of abnormalities in drilling conditions is important in oil/gas drilling operations. For example, early detection of abnormal drilling conditions may allow timely corrective actions to be taken before the occurrence of unwanted events. A real time data stream may be analyzed to alert a drilling engineer to a potential change in a formation. For example, an alert may warn a drilling engineer about one or more parameters that are in an abnormal range in view of one or more other parameters well before a kick reaches the top of the wellbore. Alerts provided to a drilling engineer may lead to earlier corrective action such as changing wellbore trajectory through desirable hydrocarbon bearing zones in a formation. In general, alarms that indicate abnormal drilling conditions based on trend analysis of drilling parameters and causal relationships among drilling parameters may provide a valuable tool to a drilling engineer.
Now referring to the drawings,
In some example embodiments, the method 100 includes acquiring raw data at step 102. To illustrate, the raw data may include several parameters (e.g., different stream/sets of data representing different drilling related parameters) that are measured in real time during drilling. Some of the parameters may be related to each other such that a change in one parameter is linked to a change in another parameter. Examples of parameters that may be measured include stand pipe pressure (SPP), total strokes per minute (SPM), block position (BP), weight on bit (WOB), tank volume (TV), and flow out (FO). The raw data may include parallel streams of data representing the different parameters. Alternatively, the raw data may include serial streams of data representing the different parameters. In some example embodiments, the raw data may be received/acquired from a data server that acquires/receives the raw data from drilling equipment (e.g., sensors) that measure and/or determine the different parameters.
At step 104, the method 100 includes conditioning the raw data to generate conditioned data. Step 104 may be performed on some data streams (i.e., sets of data) of the raw data while other data streams (i.e., sets of data) of the raw data may be unaffected by conditioning the raw data at step 104. Conditioning of individual data streams or sets of data may be performed using signal processing methods.
In some example embodiments, generating the conditioned data includes performing an outlier removal process based on a median deviation of the raw data. In general, performing outlier removal removes unwanted and/or abnormal spikes in the raw data. To perform outlier removal at step 104, a median value of the raw data over a pre-defined moving window may first be determined. If a particular data value of the raw data is greater than the median value plus an outlier threshold value (e.g., user provided threshold value), the particular data value may be replaced with the median value.
In some example embodiments, noise removal is performed at step 104. For example, noise removal may be performed on the output of the outlier removal process. Alternatively, noise removal may be performed on the raw data without performing the outlier removal process. To illustrate, treating the raw data as signal streams, noise removal may be accomplished by performing a first order lag filtering on one or more signal streams to remove high frequency noise from the signal streams.
For example, a first order exponential filter may be used on a signal stream (before or after outlier removal) to pass the low frequency components and reducing the amplitude of signals with higher frequencies. The output of the filter depends on previous output value, current input value, the filter constant, and the time interval between two input values.
In some example embodiments, a deadband process is also performed at step 104 to reduce unwanted variations in the data by outputting only step changes. The deadband process may be performed on the output of the outlier removal process or the noise removal process or on the raw data.
In some example embodiments, one or more of the outlier removal, noise removal and deadband processes may be omitted at step 104. For example, one or more of the processes may be omitted for sets of data corresponding to some drilling parameters while two or all of the processes are performed on data sets corresponding to other drilling parameters. To illustrate, a deadband process may be performed without performing the outlier removal and the noise removal processes on some sets of data while all three processes may be performed at step 104 on other sets of data. In general, the last one of the processes performed in series at step 104 outputs the conditioned data.
At step 106, the method 100 includes processing the conditioned data generated at step 104 to generate output values for use in alarm generation. To illustrate, data trend and variation of the conditioned data over varying ranges of time may be analyzed to identify increasing, decreasing, and constant trends.
In some example embodiments, processing the conditioned data at step 106 may include performing a number of processes. For example, processing the conditioned data may include performing a first process that includes analyzing for changes in rates of change (increasing/decreasing/no change) over ranges of time. To illustrate, a slope process may be performed to determine (e.g., calculate) the slope of a set of data values of the conditioned data and to determine whether a difference between the slope of the set of data values and a median slope determined over a median window of time exceeds a threshold. To illustrate, the set of data values may correspond to a data stream of the raw data representing a drilling parameter (e.g., BP). If the difference between the two slopes is beyond the threshold and has been beyond the threshold for a period (for example, a time period defined by the user), the slope process indicates a change in slope with respect to the particular drilling parameter. The type of change, i.e., increase or decrease, is specified by the manner in which the threshold is exceeded.
In some example embodiments, processing the conditioned data at step 106 may include performing a second process/a value change process that includes analyzing for incremental changes (increasing/decreasing/no change) over ranges of time. The value change process includes determining incremental changes in data values of the conditioned data and determining whether a sum of the incremental changes exceeds a threshold. For example, the value change process may be performed on a set of data values corresponding to WOB. To illustrate, the value change process tracks incremental changes in a data stream (i.e., in a set of data values) of the conditioned data and determines if the total change is beyond a user defined threshold. If the total change is beyond the threshold, and has been beyond the threshold for a time period (e.g., a time period provided by the user), the value change process indicates a change in value in the data values. The type of change in value, increase or decrease, is specified by the manner in which the threshold is exceeded.
In some example embodiments, processing the conditioned data at step 106 may include performing a third process that includes estimating expected causal response in one set of data (corresponding to a drilling parameter) due to a change in another set of data (corresponding to another drilling parameter). For example, the third process may be an expected standing pipe pressure process that is performed to determine severity of a trend deviation in SPP with respect to variations in total SPM.
In some example embodiments, processing the conditioned data at step 106 may include performing a fourth process that includes estimating the rates of change of rates of change (i.e., estimating the derivative of acceleration with respect to time). To illustrate, an acceleration process may include determining (e.g., calculating) the rate of change of the current rate of change of data values of a particular parameter between two points in time.
In some example embodiments, processing the conditioned data at step 106 may include performing a lag time lookup process on causally related drilling parameters based on the corresponding sets of data. To illustrate, a lag time look-up formula may be used to determine the look-back time or lag time for a set of data values corresponding to a particular drilling parameter. For example, the lag time lookup process may be used to look back on the value changes of the total SPM parameter determined by performing the slope process or the value change process described above.
In some example embodiments, the method 100 includes determining a rig state at step 108. For example, determining a rig state includes determining whether a drilling rig is drilling and generating a rig state indicator value to indicate the rig state (i.e., drilling or not drilling). For example, the rig state may be determined based on data values in the raw data that indicate that a particular rig is drilling or not drilling. In some example embodiments, the particular data values may be different among different rigs.
At step 110, the method 100 further includes generating one or more alarms based on the outputs generated at step 106 to indicate one or more abnormal drilling conditions. For example, the alarms may be generated at step 110 by performing logical operations (such as true, false, greater than, less than, etc.) using outputs of the data processing operations at step 106, the rig state indicator value as well as other inputs such as end-user specified thresholds and data ranges. The alarms generated at step 110 will be transmitted in real-time and displayed so that early warning of abnormal conditions existing downhole can be provided to a drilling engineer.
As described above, the method 100 may be performed to provide the ability to create and/or display output alarms for abnormal drilling conditions based on trend analysis and causal relationships of basic drilling parameters subject to unexpected external forces. Such alarms can reliably alert drilling personnel of abnormal conditions.
In some example embodiments, the system 200 includes a data conditioner 204. For example, the data conditioner 204 may be a signal processor that processes the signal representing the raw data from the raw data source 202. The data conditioner may perform the processes described above with respect to step 104 of the method 100 of
In some example embodiments, the system 200 includes a data processor 206. For example, the data processor 206 may be a microprocessor or a microcontroller. The data processor 206 may perform the processes described above with respect to step 106 of the method 100 of
In some example embodiments, the system 200 includes a rig state generator 208. The rig state generator 208 determines whether a drilling rig is drilling and outputs a rig state indicator value to indicate the rig state (i.e., drilling or not drilling). For example, the rig state generator 208 may determine the rig state based on data values in the raw data that indicate that a particular rig is drilling or not drilling.
In some example embodiments, the system 200 includes an alarm generator 210. The alarm generator 210 outputs one or more alarms to indicate one or more abnormal drilling conditions. For example, the alarm generator 210 may be used to implement alarm generation described above with respect to step 110 of the method 100. The alarms generated by the alarm generator 210 may be transmitted in real-time or displayed so that early warning of abnormal conditions existing downhole can be provided to a drilling engineer. Such alarms can reliably alert drilling personnel of abnormal conditions as compared to alarms that are based on a single drilling parameter exceeding a threshold.
In some example embodiments, one or more of the components of the system 200 may be implemented in a single device. For example, the alarm generator 210 may be integrated into the data processor 206. Further, the data conditioner 204, the data processor 206, and the rig state processor 208, and the alarm generator 210 may be implemented using hardware (e.g., FPGA), software, or a combination of hardware and software.
The data conditioner 204 may receive the raw data from the raw data source 202 and perform conditioning of the raw data. In some example embodiments, the data conditioner 204 may be a signal processing device. As illustrated in
In some example embodiments, the outlier removal module 304 performs the outlier removal process described with respect to step 104 of the method 100 to remove unwanted and/or abnormal spikes in the raw data. To perform outlier removal at step 104, a median value of the raw data over a pre-defined moving window may first be determined. If a particular data value of the raw data is greater than the median value plus an outlier threshold value (e.g., user provided threshold value), the particular data value may be replaced with the median value.
In some example embodiments, the filter module 306 performs the noise removal process described with respect to step 104 of the method 100. To illustrate, the filter module 306 may be a first order exponential filter that removes high frequency noise from signals corresponding to data streams of the raw data representing different drilling parameters. The output of the filter depends on previous output value, current input value, the filter constant, and the time interval between two input values. The operation of the filter module 306 may be described by Equation (1) below.
outputn=(1−α)·inputn+α·outputn-1 Equation (1)
Where:
α is a constant between 0 and 1.
In Equation (1), outputn equals the current output value; input, equals the current input value; and outputn-1 equals the previous output value.
In some example embodiments, the deadband module 308 reduces unwanted variations in the data by outputting only step changes. The deadband module 308 may operate on the output of the noise removal process as shown in
In some example embodiments, to reduce unwanted variations in a filtered set of data values corresponding to a particular drilling parameter (e.g., SPP), the deadband module 308 determines the median value of the filtered data over a pre-defined moving window and if a data value of the filtered set of data values falls within the median value +/− (i.e., plus or minus) a deadband threshold, the particular parameter is considered constant, and the output is set at the previous output value. If the data value of the filtered set of data values exceeds the deadband threshold, a change in trend of the data values of the particular filtered set of data values is considered to have occurred, and the output is set at the current median. The deadband module 308 may operate on other sets of data corresponding to other drilling parameters represented in the raw data in a similar manner.
In some example embodiments, the data processor 206 may receive the output of the data conditioner 204 and generate outputs that are used in alarm generation by the alarm generator 210. In particular, the data processor 206 may receive the output of the deadband module 308. As illustrated in
To illustrate the operation of the slope module 310 in more detail, in some example embodiments, the slope module 310 calculates the slope of a set of data values corresponding to a particular drilling parameter and determines if the slope has changed beyond a user defined threshold. If the difference between the two slopes exceeds the threshold, and has been beyond the threshold for a period defined by a user, the slope module 310 outputs an indication of a change in slope. The type of change, i.e., increase or decrease, is specified by the manner in which the threshold has been exceeded. In some example embodiments, the inputs provided to the slope module 310 are the set of data values corresponding to a particular drilling parameter, a regression length of time, a median window for calculating a median slope value, an offset time, and an onset (time) window as well as user defined threshold. The slope module 310 may generate/store outputs including Slope Value (in unit of the particular parameter/second, an Offset Median Slope (in unit of the particular parameter/second), Slope Change Marker Increase (e.g., 1), Decrease (e.g., (−1), No Change (e.g., 0)), and timestamps associated with all stored outputs.
During operation, the slope module 310 calculates the slope of the data values using a linear regression according to Equation (2):
In Equation (2),
-
- a.
x is the average of associated x values, andy is the average of the associated y values. - b. x is time expressed in seconds. The number of seconds over which to calculate the slope is defined by the input value Regression Length.
- c. y is a value of the set of data value expressed in units applicable to the particular drilling parameter.
- d. The Regression Length indicates the number of values in the past to be used in the calculation. The current value will always be the most recent value in the calculation. That is, the slope module 310 will not wait for a future value to perform a calculation. Instead, the slope module 310 always looks at past values. For example, a Regression Length of 60 seconds means that all values between the current data value and the data value 60 seconds ago, inclusive, will be used in the calculation.
- a.
The slope module 310 also calculates a median Slope Value over the Median Window. To illustrate, median is defined herein as the middle value of a set of numbers, when the numbers are arranged from least to greatest. If number of values is even, the median is the average of the two values in the middle. The number of Slope Values over which to calculate the median value is defined by the Median Window, which indicates up to how many Slope Values in the past are to be used in the calculation. The current value will always be the most recent value in the calculation. That is, the slope module 310 will not wait for a future value to perform a calculation. Instead, the slope module 310 always looks at past values. For example, a Median Window of 60 seconds means that all Slope Values between the current value and the value 60 seconds ago, inclusive, will be used in the median determination.
The slope module 310 also determines the Offset Median Slope. The Offset Median Slope for the current timestamp is a Median Slope that was calculated in the past, as defined by the Offset. For example, if the current timestamp is 07:05:00, and the Offset is 60 seconds, then the Offset Median Slope associated with 07:05:00 is the Median Slope calculated at 07:04:00.
The slope module 310 may further calculate the difference (Delta) between the current Slope Value and the Offset Median Slope using Equation (3).
Delta=Slope Value−Offset Median Slope Equation (3)
After determining the difference between the current Slope Value and the Offset Median Slope, the slope module 310 determines whether a Slope Change threshold has been reached. To illustrate, if Delta>=the Slope Change Threshold, the slope module 310 indicates that the slope change is an increase (e.g., 1). If Delta<=−1×Slope Change Threshold, the slope module 310 indicates that the slope change is a decrease (e.g., −1). Otherwise, the slope module 310 indicates there is no slope change (e.g., 0). In some example embodiments, the conversion of units may be required. For example, a unit of bbl/hr may need to be converted to bbl/second or vice versa.
After determining whether the Slope Change threshold has been reached, the slope module 310 may determine whether the Slope Change threshold has been continuously met over the Onset Window. If the Slope Change threshold has been continuously met over the Onset Window, the slope module 310 may output Slope Change Marker indicating an Increase, a Decrease, or No Change along with corresponding timestamps. To illustrate, if a slope change has been detected, the slope module 310 checks whether that same change has been detected continuously over a window defined by Onset Window. For example, if the current timestamp is 07:05:30, the Onset Window is equal to 30 seconds, and Slope Change equals “Increase,” the slope module 310 checks whether Slope Change equals “Increase” for all timestamps between 07:05:00 and 07:05:30, inclusive and outputs a Slope Increase to indicate so. A similar operation is performed for when Slope Change equals “Decrease.” In both cases, if Slope Change has not been a constant value in the Onset Window, the slope module 310 will not output a marker indicating a change in slope.
In some example embodiments, the value change module 312 of the data processor 206 analyzes incremental changes (increasing/decreasing/no change) over ranges of time for SPP, TSPM, WOB, and FO drilling parameters represented by sets of data values in the output data from the data conditioner 204. The value change module 312 may perform the value change process of step 106 of the method 100 to tracks the incremental changes of a set of data values corresponding to a drilling parameter and to determine if the total change is beyond a user defined threshold.
In some example embodiments, the value change module 312 performs a series of calculations and value comparisons to analyze incremental changes. If the total change is beyond the threshold, and has been beyond the threshold for a period defined by the user, the value change module 312 outputs a change in value. The type of change in value, i.e., increase or decrease, is specified by the manner in which the threshold has been exceeded.
In some example embodiments, the inputs provided to the value change module 312 are a set of data values corresponding to a particular drilling parameter, Onset Window, and Value Change Threshold provided by a user. The value change module 312 may generate/store outputs including Value Change Marker as Increase (e.g., 1), Decrease (e.g., (−1), No Change (e.g., 0)) and Timestamps associated with all stored outputs.
During operation, the value change module 312 determines the incremental change in the data values corresponding to a particular drilling parameter by calculating the difference (V-difference) between current data value and a previous data value of the data values corresponding to the particular drilling parameter. To determine the total the total change in the data values, the value change module 312 increments the total change (Sum) by V-difference if a previous Value Change Marker indicates No Change, and resets Sum to zero if a previous Value Change Marker indicates “Increase” or “Decrease. The value change module 312 also checks if Sum (the total change in the data values) has reached a threshold. To illustrate, if Sum >=Value Change Threshold, Value Change is set to “Increase.” If Sum <=−1×Value Change Threshold, Value Change is set to “Decrease.”
If a value change has been detected as indicated by Value Change, the value change module 312 determines whether the same change has been detected continuously over a time window defined by Onset Window. For example, if the current timestamp is 07:05:30, the Onset Window is equal to 30 seconds and Value Change equals “Increase,” the value change module 312 checks whether Value Change equals “Increase” for all timestamps between 07:05:00 and 07:05:30, inclusive and outputs “Increase” to indicate so. A similar operation is performed when Value Change equals “Decrease.” In both cases, if Value Change has not been a constant value in the Onset Window, the value change module 312 will not output a marker indicating a change in value.
Before a final indication of Value Change Marker as “Increase” (e.g., 1), “Decrease” (e.g., −1), or “No Change” (e.g., 0), the value change module 312 may check for persistence of the behavior after an initial marker to provide a final Value Change Marker. To illustrate, if a value change marker has occurred right before (n−1), then the value change module 312 checks for the current difference value to determine (1) if the difference value is >=0 for a previous increase marker and to output an increase marker if true; and (2) if the difference value is <=0 for a previous decrease marker and to output a decrease marker if true.
In some example embodiments, the data processor 206 estimates expected causal response in one set of data values (corresponding to a drilling parameter) due to a change in another set of data values (corresponding to another drilling parameter). To illustrate, the expected SPP module 314 of the data processor 206 may determine severity of a trend deviation in data values corresponding to the SPP drilling parameter with respect to variations in data values of the TSPM drilling parameter.
In some example embodiments, the SPP, TSPM and Lookback Window are provided to the expected SPP module 314 as inputs. Further, in some example embodiments, Rig State Activity Code from the rig state processor 208 and output of the Value Change module 312 are provided as inputs to the expected SPP module 314. The expected SPP module 314 may generate/store outputs including Expected Stand Pipe Pressure, Difference between Expected and Current Stand Pipe Pressure values, and percentage Difference between Expected and Current Stand Pipe Pressure values.
During operation, the expected SPP module 314 may analyze the Current Rig State to determine whether current operations are of “Drilling or “Not Drilling.” For example, the expected SPP module 314 may determine whether current operations are of “Drilling or “Not Drilling” based on the Rig State Activity Code from the rig state processor 208 that provides a standard indication of a drilling activity. The expected SPP module 314 may also analyze the outputs from the Value Change module 312 for current output marker corresponding to TSPM and SPP data. The expected SPP module 314 may also analyze the outputs from the Value Change module 312 for any instance and type of an “Increasing” or “Decreasing” marker output over the time interval specified by the “Lookback Window” provided by an end-user and indicate whether or not a “recent” change in TSPM has occurred and whether the change was of “Increase” or “Decrease.” Analysis for instances and type of “Increasing” or “Decreasing” marker output allows for determining whether or not a “recent” change in TSPM has occurred and whether this change was of “Increase” or “Decrease.”
The expected SPP module 314 calculates Expected SPP based on the current TSPM value, TSPM value at a previous time period and the Stand Pipe Pressure corresponding to the TSPM value at the previous time period based on Equation (4).
In Equation (4),
-
- a. SPPexpected is a calculated value of SPP that would result from a change in TSPM.
- b. “Current” and “Previous” values are the outputs of Signal Processing techniques applied on the data values corresponding to SPP and TSPM drilling parameters.
- c. The term “Previous” refers to a point back in time from the current timestamp of the Onset Window plus the sample rate, i.e., if the Onset Window=30 sec, Sample Rate 5 sec, then the Previous Value would be at Current Timestamp−35 seconds.
- d. The Onset Window is the end-user input variable provided to the Value Change module 310.
The expected SPP module 314 also calculates the difference and the percentage difference between the expected and current SPP values based on Equations (5) and (6), respectively.
In some example embodiments, the data processor 206 estimates rates of change of rates of change (i.e., acceleration). In particular, the acceleration module 316 may determine (e.g., calculate) the rate of change of the current rate of change of data values of a particular parameter between two points in time. To illustrate with respect to the BP drilling parameter, the acceleration module 314 may receive Sample Rate, Median Window from the slope module 310, and Offset, which is the same as the Offset provided to the slope module 310. Based on these inputs, the acceleration module 316 may output (1) “Instantaneous Velocity,” which is the rate of change between the current and previous data values corresponding to the BP parameter based on current sample rate; (2) “Average Velocities,” which is the average of Instantaneous Velocity outputs over two ranges of time; and (3) “Acceleration,” which is a calculated rate of change based on a rate of change (Instantaneous Velocity) at a previous point in time.
The instantaneous Velocity, vt, is determined according to Equation (7).
Average Velocity over Offset equals Average of Instantaneous Velocities (Vt) over the Offset, and Average V over median window equals Average of Instantaneous Velocities (Vt) over the Median Window. The acceleration module 316 determines of from the data values corresponding to the BP according to Equation (8).
In Equation (8),
-
- a=Acceleration;
- BP=block position (BP) from the data conditioner 204;
- t=current time;
- Offset=Offset (time in seconds) used in the slope module 310; and
- t−offset=current time−offset time.
In some example embodiments, the data processor 206 includes a lag time lookup module 318 align causally related drilling parameters based on their corresponding sets of data values. To illustrate, a lag time look-up formula may be used to determine the look-back time or lag time for a set of data values corresponding to a particular drilling parameter. For example, the lag time lookup module 318 may be used to look back on value changes of the TSPM drilling parameter determined by the slope module 310 or the value change module 312 described above.
To illustrate with respect to Bit Depth drilling parameter, the lag time lookup module 318 may calculate “Lag Time” based on current Bit Depth indicated by the sets of data values in the raw data and conditioned by the data conditioner module 204. For example, the lag time lookup module 318 may calculate “Lag Time” according to Equation (9).
In Equation (9), the time, in number of seconds, can be configurable and may not always be 2 seconds.
In some example embodiments, the alarm generator 210 may generate a number of alarms based on the outputs of the data processor 206. As illustrated in
In some example embodiments, one or more of the modules 310, 312, 314, 316, 318 may be omitted or may operate on different drilling parameters than shown in
A flow chart showing generation of the SPP alarm based on outputs of modules of the data processor 206 and user provided inputs is shown in
At 802, a rig state activity code is provided, for example, by the rig state generator 210 of
At 806, a TSPM Value Change Marker is provided, for example, by the value change module 312
At 814, a percentage in the difference between expected/calculated SPP and current SPP values is calculated based on the delta calculated at 812, which depends on the expected/calculated SPP (SPP2) determined at 810. In general, the percentage difference determined at 814 is determined in the manner described with respect to the expected SPP module 314 of
SPP Alarm #1 is generated if (a) a “Decreasing” SPP Value Change Marker currently exists; and (b) neither a “Decreasing” or “Increasing” TSPM Value Change Marker is present within the Lookback Window. SPP Alarm #2 is generated if (a) a “No Change” SPP Value Change Marker currently exists; (b) an “Increasing” TSPM Value Change Marker is present within the Lookback Window; and (c) the calculated SPP percentage change is greater than the user provided threshold (e.g., 5%). SPP Alarm #3 is generated if (a) a “Decreasing” SPP Value Change Marker currently exists; (b) a Decreasing” TSPM Value Change Marker is present within the Lookback Window; and (c) the calculated SPP percentage change is greater than the user provided threshold. SPP Alarm #4 is generated if (a) an “Increasing” SPP Value Change Marker currently exists; (b) neither a “Decreasing” or “Increasing” TSPM Value Change Marker is present within the Lookback Window; and (c) the calculated SPP percentage change is greater than the user provided threshold. SPP Alarm #5 is generated if (a) an “Increasing” SPP Value Change Marker currently exists; (b) an “Increasing” TSPM Value Change Marker is present within the Lookback Window; and (c) the calculated SPP percentage change is greater than the user provided threshold.
In general, the apparatus, system, and method described above with respect to
Although some embodiments have been described herein in detail, the descriptions are by way of example. The features of the embodiments described herein are representative and, in alternative embodiments, certain features, elements, and/or steps may be added or omitted. Additionally, modifications to aspects of the embodiments described herein may be made by those skilled in the art without departing from the spirit and scope of the following claims, the scope of which are to be accorded the broadest interpretation so as to encompass modifications and equivalent structures.
Claims
1. A method of monitoring drilling conditions, the method comprising:
- acquiring raw data from drilling equipment;
- conditioning, by a data conditioning module, the raw data to generate conditioned data, wherein conditioning the raw data comprises removing outlier data values and/or filtering out noise;
- processing, by a data processor, the conditioned data to generate output values for use in alarm generation, wherein processing the conditioned data comprises: determining a slope of a first set of data values of the conditioned data with respect to a regression length of time, the first set of data values corresponding to a regression length of time; and determining whether a difference between the slope of the first set of data values and a median slope determined over a median window of time exceeds a threshold, wherein the median slope is a middle value of a set of slope values over the median window of time; and
- generating, by an alarm generator, an alarm based on the output values to indicate an abnormal drilling condition.
2. The method of claim 1, further comprising determining a rig state to generate a rig state indicator value that indicates whether a drilling rig is drilling, wherein the alarm is generated based on the rig state indicator value.
3. The method of claim 1, wherein acquiring the raw data from the drilling equipment comprises receiving the raw data from one or more sensors used in drilling operations.
4. The method of claim 3, wherein the one or more sensors sense a wellbore pressure and a stroke rate for pumping drilling mud.
5. The method of claim 1, wherein conditioning the raw data further comprises performing a deadband operation to reduce unwanted variations in filtered data produced by performing filtering out noise.
6. The method of claim 1, wherein the raw data comprise data sets representing stand pipe pressure (SPP), total strokes per minute (SPM), block position (BP), weight on bit (WOB), tank volume (TV), and/or flow out (FO).
7. The method of claim 1, wherein the alarm comprises a drilling break alarm indicating an increase in a rate of penetration (ROP) that occurs without a corresponding increase in weight on bit (WOB).
8. The method of claim 6, further comprising compensating for lag time between causally related data sets of the conditioned data.
8705318 | April 22, 2014 | Zheng |
9091773 | July 28, 2015 | Selman |
20030220742 | November 27, 2003 | Niedermayr et al. |
20040124012 | July 1, 2004 | Dunlop |
20100050017 | February 25, 2010 | Almadi |
20110220410 | September 15, 2011 | Aldred et al. |
20120123756 | May 17, 2012 | Wang |
20130341090 | December 26, 2013 | Zeineddine |
20150134258 | May 14, 2015 | Luppens |
20150300151 | October 22, 2015 | Mohaghegh |
20150308253 | October 29, 2015 | Clark |
20160003035 | January 7, 2016 | Logan |
20160237810 | August 18, 2016 | Beaman, Jr. |
- Arghad Arnout et al: “Drilling events detection using hybrid intelligent segmentation algorithm”, Hybrid Intelligent Systems (HIS), 2012 12th International Conference On, IEEE, Dec. 4, 2012 (Dec. 4, 2012), pp. 508-511, XP032315842, DOI: 10.1109/HIS.2012.6421386 ISBN: 978-1-4673-5114-0 the whole document.
- R Wong et al.: “Advances in Real-Time Event Detection While Drilling”, Mar. 7, 2013 (Mar. 7, 2013), XP055218411, Retreived from the internet: URL:https://www.onepetro.org/conference-paper/SPE-163515-MS?sort=&start=0&q=163515&from—year=&peer—reviewed=&published—between=&fromsearchresults=true&to—year=&rows=10# [retrieved on Oct. 6, 2015] p. 1-p. 2.
- Adrian Ambrus et al: “Drilling Rig Sensor Data Validation in the Presence of Real-Time Process Variations”, Oct. 2, 2013 (Oct. 2, 2013), XP055218414, Retreived from the internet: URL:https://www.onepetro.org/conference-paper/SPE-16387-MS?sort=&start=0&q=166387&from—year=&peer—reviewed=published—between=&fromsearchresults=true&to—year=&rows=10# [retrieved on Oct. 6, 2015] the whole document.
- International Search Report for PCT/2015/011229 mailed on Oct. 16, 2015.
Type: Grant
Filed: Nov 21, 2014
Date of Patent: Jun 6, 2017
Patent Publication Number: 20150235544
Assignee: CHEVRON U.S.A. INC. (San Ramon, CA)
Inventors: Carlos A. Hernandez (Houston, TX), Ray E. Johnston (Austin, TX), Kelli M. Rettew (Houston, TX), Janice S. Mathew (Houston, TX), Steven J. Shipula (Conroe, TX), Tony Gomez (League City, TX)
Primary Examiner: Hirdepal Singh
Application Number: 14/550,643
International Classification: E21B 44/00 (20060101); E21B 7/00 (20060101);