AutoForecast
This module performs a DCA autofit on all streams (oil, gas and water) of selected wells in a given project. You can have multiple versions of these DCA autoforecasts (for different wells or different ranges of autofit parameters) within a project.
How does the autofit algorithm work?
The autofit algorithm finds the timestep with the maximum production data and performs a singlesegment or multisegment best fit from that timestep and rest of historical time.
Here's how to create a new autoforecast case:
 Click AutoForecast in the navigation panel.
 To the upper right, click ADD AUTOFORECAST.
 Provide a name and select all the wells by clicking the check box at the top of the well list (left of Well Name).
 Click SAVE to the lower right.
You can store multiple autoforecasts per project
This main autoforecast page gives you an overview of the created autoforecasts, when they were created, who created them and what wells went into creating them.
After the autoforecast is created, there are three main steps: 1. Initialize, 2. Autofit and 3. Summary.
1. Initialize
This is where the autofit is initialized with both fit ranges and other relevant assumptions.
1.1. bfactor switch
The switch at the top of the screen dictates what should happen if the bfactor min or max is the converged solution during the autofit.
 When switch is ON: if the best fit solution hits the upper, or lower, bfactor bound, do a best fit with the default bfactor is done instead.
 When switch is OFF: if best fit solution hits the upper, or lower, bfactor bound, that is what is used.
1.2 Autofit Decline Type
You can use the Autofit Type dropdown to select between the Arps single segment decline or the 2segment Modified Arps decline.
1.3 Autofit ranges
 Default: starting point for autofit  \(q_i\) is the initial production ratio, b is the rate exponent or the bfactor, and \(a_i\) is the nominal decline rate.
 Min: lower bounds of bestfit solution for \(q_i\), b and \(a_i\).
 Max: upper bound of bestfit solution for \(q_i\), b and \(a_i\).
What is the initial production ratio?
This is the ratio between the \(q_i\) that the DCA will use and the maximum production rate found in the production dataset for the well. As an example, if you have a given well where the maximum oil production in history is 1000 STB/d, having an initial production ratio between 0.8 and 1.2 means we are allowing the initial rate in DCA to be between 800 STB/d and 1200 STB/d. It is basically a generic way to specify the range for \(q_i\), for a large number of wells, and all the different phases (oil, gas and water) in one go.
1.4 Forecast
 Total Production Period: sum of historical time and forecasted time.
 Oil Cutoff rate: the rate at which to stop the forecast.
 Limiting Effective Decline Rate: specifies when the hyperbolic decline curve transitions into an exponential decline curve at a specified limiting effective decline rate.
2. Autofit
This is where you get an overview of your autofit. In this view you can filter and manually update the individual fits.
2.1 Autofit all wells
Click "Autofit all wells" to the upper left to bestfit all the wells in a given project.
2.2 Sort, Filter and Change Streams.
 Sort: Click the header parameter to sort the well list by that parameter.
 Search: Use the search bar to search for a specific well.
 Change stream: click OIL  GAS  WATER tabs to change between the streams.
2.3 Manually Edit
You can manually check and adjust each fit by clicking the row in the table.
 Click the row. A window showing the singlewell DCA fit will appear.
 Navigate to the next well with the right arrow (→) and the previous well with the left arrow (←) on your keyboard.
What does the DCA bfactor represent?
DCA fits can be tied to physical parameters as long as the fit is done while the flowing bottomhole pressure is constant (or about constant). The bfactor represent recovery efficiency. A low bfactor indicates a low recovery efficiency. A high bfactor indicates a high recovery efficiency.
2.3.1 Adjusting the autoforecast fit on a well
 Values can be changed by typing.
 The fit can also be graphically edited.
 See .gif above (it's just for example purposes).
2.4 Save Fit
Click SAVE up to the right to save all the autofits (for all the streams). These forecasts can be appended to the historical data in the type well feature.
2.5 Export
Click EXPORT up to the right to export to thirdparty software (for all streams).
3. Summary
 Click the third step in the stepper (3. Summary).
 Click CREATE NEW CHARTS
 To quality check that the overall fits are ok, a simple "rollup" exercise can be performed on all the data.
 That is done by adding up all the rates from all the wells producing at a given time step and plotting that over time in both rate and cumulative space.
 Here you like to visually ensure that there are no strange discontinuities when the data goes from the historical data to the forecasted part of the data.
4. Go back to the AutoForecast Overview?
If you want to go back to the autoforecast overview, either 1. click the AutoForecast tab in the navigation panel. 2. or click the AutoForecast menu in the top bar.
5. Want edit AutoForecast well selection?
If you want to edit the well selection, either
 click the Edit AutoForecast tab in the AutoForecast Overview.
 or click the Edit AutoForecast menu in the top bar.
Decline Curve Analysis
Decline curve analysis (DCA) for all three flowing phases can be performed within whitson+, both automatically and manually. Userfriendly, "draganddrop" curvefitting functionality is also provided.
1. Input
The inputs for this analysis are:
 DCA parameters (\(b\), \(a_i\), \(q_i\))
 Start (day or month)
 Total production period (years)
 Limited Decline Rate (\(a_{lim}\) or \(d_{lim}\)). More info here.
The user can decide whether to lock in the start day and the DCA parameters, or if these should change freely during the curve fitting.
2. Theory
2.1 Fundamentals
The classical equation that provides that basis for this module is
where
\(q_i\) = initial flow rate
\(a_i\) = nominal decline rate at time zero
\(b\) = rate exponent
\(q(t)\) = flow rate at time t
Equation 1 is a threeparameter performancematching equation. When the \(b\) is equal to zero, the flow rate decline is exponential, when \(b\) is 1, the rate decline is called harmonic, and when b is between zero and one, the rate decline is hyperbolic. Some general guidelines for b and how it relates to the description of the reservoir are provided below.
\(b\) value  Context 

0  Singlephase oil, or singlephase gas at high pressure 
0.10.4  Solution gas drive 
0.40.5  Singlephase gas flow 
0.51  Layered reservoirs 
>1  Infinite acting flow 
2.1.1 Exponential Decline (b=0)
where \(N(\infty)\) is the ultimate cumulative production.
2.1.2 Hyperbolic Decline (0 < b < 1)
2.1.3 Harmonic Decline (b = 1)
2.1.4 Beyond Hyperbolic (b > 1)
2.2 DCA Summary
Type  Decline Rate  Producing Rate, q  Elapsed Time, t  Cum. Production, \(Q_{t}\) 

Exponential  \(a_t = ln(\frac{q_i}{q_t})/t\)  \(q_ie^{a_it}\)  \(ln(\frac{q_i}{q_t})/a_i\)  \(\frac{q_iq_t}{a_i}\) 
Hyperbolic  \(\frac{a_i}{a_t} = (\frac{q_i}{q_t})^b\)  \(q_i(1+ba_it)^{1/b}\)  \(\frac{(q_i/q_t)^b1}{ba_i}\)  \(\frac{q_i}{a_i(1b)}(1\frac{q_t}{q_i}^{1b})\) 
Harmonic  \(\frac{a_i}{a_t} = \frac{q_i}{q_t}\)  \(q_i(1+a_it)^{1}\)  \(\frac{(q_iq_t)}{a_iq_t}\)  \(\frac{q_i}{a_i}ln(\frac{q_i}{q_t})\) 
2.3 Effective Decline
Nominal annual decline rate is denoted "a". The effective annual decline rate is denoted "d", with units %/yr. There are two common ways the industry converts annual decline into effective decline,
"Effective Hyperbolic Decline" aka "Secant Effective"
"Effective Exponential Decline aka "Tangent Effective"
Both of these properties can be converted back by the following equations
Note
These numbers are mere conversions to and from \(a_{i}\) and should yield identical results irrespective of what is chosen. For most folks, it's mainly the matter of preference when it comes to what is communicated in terms of the final results.
The symbols for the different terms can vary somewhat from software to software, so here is a little overview for some handpicked softwares.
Name  whitson+  ARIES  Harmony  PhdWin / SPEE  Val Nav 

Initial nominal annual decline rate  \(a_{i}\)  \(A_{i}\)  \(a_{i}\)  \(D_{i}\)  Di (nom) 
Initial effective hyperbolic annual decline rate  \(d_{hyp}\)  \(D_{b}\)  \(d_{sec}\)  \(D_{esi}\)  Di (eff. sec) 
Initial effective exponential annual decline rate  \(d_{exp}\)  \(D_{h}\)  \(d_{tan}\)  \(D_{ei}\)  Di (eff. tan) 
Rate exponent  b  n  b  b  Ni 
More information about this is provided by SPEE.
2.4 Limited / Modified Decline
The limited decline rate begins when the hyperbolic decline curve transitions into an exponential decline curve at a specified limiting effective decline rate, \(d_{lim}\). The limiting effective decline rate is converted to a limiting nominal decline rate, \(a_{lim}\), and the following equations are applied:
When \(d_{tan}\) > \(d_{lim}\):
when \(d_{tan}\) <= \(d_{lim}\):
where
3. Autofit
The autofit algorithm finds the last segment of the data that is consecutively (continously) nonzero, and fits the DCA parameters to this part of the data only. A single or set of zero rates in the data is typically associated with a shutin, in which reinitialization of the DCA fit should be performed.
3.1 Residual Function
The fitting routine uses the following residual function in the least square routine.
where \(r_i\) is the residual at time \(i\), \(w_i\) is the weight factor of time \(i\), \(t_0\) is the time index and q is the actual rate.
3.2 Default Bounds
Parameter  Lower Bound  Higher Bound  Unit 

\(q_i\)  0  10% higher than max observed q  volume unit / time 
\(a_i\)  0  10  /yr 
\(b\)  0  4   
3.3 Weighting factors
By default, all days have a weighting factor of 1, except from the days when q = 0, in which the weighting factor is 0.
4. Fit the DCA parameters to a physics based forecast
If a physics based forecast has been established for this well, an option to include this data will appear. This allows for physicsbased, DCA forecasts.
5. General tips

You can add multiple Arps decline segments to the data, as proposed by the Modified Arps decline method (2 segments). Each of these segments can be linear incline, constant or the Arps decline type segments  controlled individually by directly entering the inputs, or adjusting the curve on the plot itself to autocompute the decline parameters for each of them. These segments may be useful to model particular flow regimes, constant rate well control or refrac analysis.
Fig. 1: Adding DCA Segments

You can also adjust the settings for autofitting decline to your data by adjusting the decline parameter ranges and specifying the autofit type as the default Arps decline or the modified Arps decline. The autofit function will automatically add a second decline segment (if it does not exist) and fit 2 segments to the data if the autofit type is modified Arps decline. You can choose to autofit some or all of your segments at once and control the autofit on each segment by using the locks on decline parameters.
Fig. 2: Autofitting DCA Segments and Autofit settings

The end date of the forecast on the DCA plot dictates where the forecast is appended to historical data. The forecast is appended to the last producing day of the well history, or the end date of the last segment itself, whichever is earlier, and the EUR is calculated accordingly. End date beyond the last producing day will include all the production history, followed by the forecast to calculate EUR and any end date before the last producing day will append the forecast from the set end date and follow the forecast from this point, discarding the production data after this end date. EUR shown in the topleft box should be exactly equal to the EUR (black line) plotted on the cumulative plot (bottom) at the end of the total production period.
Fig. 3: Appending forecasts to data and EUR calculation

You can observe the decline fit in rate vs time space or rate vs cumulative space on the same plot (top).
Fig. 4: DCA segments on rate vs cumulative plots

You can use the 'Link to Previous Segment' checkbox for each segment to link the previous segment to this one in time for continuity. We are working on linking other elements from the previous segment (like the rates and declines at the end of the previous segment) to add to this functionality.
6. Export
The results from the DCA feature can to be exported to:
 Aries
 ComboCurve
 Excel
 PHDWin
 Mosaic
 Val Nav
Note that the forecast in the export starts from the end of the uploaded historical data. Hence the best fit qi and decline parameters has to be recalculated for the end of history (as they change with time), as outlined here here.
6.1 Export to Aries
The following outlines how the ARIES export works with a specific example.
For an example well with these parameters.
 qi = 51.7334 STB/d
 d_lim = 5.0000 %/yr
 b = 1.2
 d_hyp = 43.7863 %/yr
 Cutoff rate = 3.0 STB/d
 forecast_time = 582.3934 months
There will be 4 cases, these are all shown assuming the parameters are for the oil phase, but the logic is equally applicable for gas and water.
Case 1  well reaches cutoff rate before d_lim, the ARIES export would look like this:
We have a single line which shows qi, cutoff rate, b and d
DEMOWELL
PRODUCTION
CUMS 80.1645 0.4055 780.3532
START 03/2022
OIL 51.7334 3.0 B/D X MOS B/1.2 43.7863
Case 2  well reaches cutoff rate after d_lim but before end of forecast period, the ARIES export would look like this:
We have two lines as before, only difference being that instead of putting the period of 582 months (or any number for the case), we put X
DEMOWELL
PRODUCTION
CUMS 80.1645 0.4055 780.3532
START 03/2022
OIL 51.7334 X B/D 5.0000 EXP B/1.2 43.7863
" X 3.0 B/D X MOS EXP 5.0000
Case 3  well reaches d_lim and does not reach cut off rate until the end of the forecast period, the ARIES export would look like this:
DEMOWELL
PRODUCTION
CUMS 80.1645 0.4055 780.3532
START 03/2022
OIL 51.7334 X B/D 5.0000 EXP B/1.2 43.7863
" X X B/D 582.3934 MOS EXP 5.0000
Case 4  d_hyp is lower than d_lim:
In addition to these 3 main cases, there is an exceptional case in which d_hyp < d_lim, for example if in the case presented above d_hyp was 3.2561 %/yr instead 43.7863 %/yr. The export to Aries would look as follows.
Case 4a  If cutoff rate is not reached before end of forecast period:
DEMOWELL
PRODUCTION
CUMS 80.1645 0.4055 780.3532
START 03/2022
OIL 51.7334 X B/D 582.3934 MOS EXP 3.2561
Case 4b  If cutoff rate is reached before end of forecast period:
DEMOWELL
PRODUCTION
CUMS 80.1645 0.4055 780.3532
START 03/2022
OIL 51.7334 3.0 B/D X MOS EXP 3.2561</mark