Not applicable.
The present invention generally relates to systems and methods for positioning pads. More particularly, the present invention relates to the automated positioning of pads, sometimes referred to as platforms, and orienting slot templates for the pads. The present invention also relates to the automated adjustment of well path plans from a pad to selected well targets.
Historically, the positioning of onshore pads has involved a number of issues related to proper pad positioning. In the oil and gas industry, for example, proper positioning of onshore pads for oil and gas rigs requires consideration of surface topography and slope constraints. In addition, the orientation of slot templates, which are located on each pad and are used to organize the location of each well on the pad, must also be considered. Finally, each well path—sometimes referred to as a plan from the pad to a selected well target—must be considered.
For example, large scale onshore field development planning creates unique problems for oil and gas companies. Unconventional and tight gas pays generally contain large numbers of subsurface targets to exploit. A direct result is a large number of wells that must be planned and drilled from surface pads or sites, which are analogous to offshore platforms. In order to adequately plan for this, several objectives must be accomplished. The number and location of surface pads or sites required to complete the development is required, for example, which depends on the number of wells that will be drilled from each pad, the engineering constraints placed on the individual well paths (i.e. maximum reach, dogleg severity, inclination angle, etc.), the location of the subsurface targets and the topographic constraints—such as elevation and grade. Slot template geometry and the orientation for each pad also need to be defined. Slot templates generally involve very tight spacing between slots, which requires an understanding of the well paths that will originate from each slot so that collision risk between wells is minimized. And, well paths need to be assigned to the correct slot. Individual well paths may also need to be altered in order to minimize interference with other wells planned or drilled from the same, or different, slot template(s).
The main issue with each objective is the planning cycle time. Planning for 50 pads with 20 wells per pad (i.e. 1000 total wells) can be a tedious, iterative-process subject to trial and error. For instance, a pad is visually positioned over a grouping of targets by visualizing a topographic map. Elevation is eyeballed, estimated and used as the starting reference point elevation. Well locations for the proposed slot template geometry must then be calculated and each individual well path must be assigned to a slot and designed. During the well path design process, it may be determined that the site positioning just did not work due to well path constraints and the process is repeated over and over again until it is successful. At this time, each individual well path must be altered to minimize collision risks with other wells that will be drilled from the same or other sites. The aforementioned process would realistically take anywhere from 3-5 days for just one pad. Multiply this process by 50 and the length of time required becomes significant.
One method for determining platform placement that is most often used may be thought of as a “move and calculate footage” based method. In this method, a series of wellpath plans are created manually, one at a time, using dogleg, inclination, reach, and anti-collision as the planning criteria for the platform location. The cumulative measured depth traversed by the many wellpaths is summed and used as a measurement of the base case location.
Once the wellpaths are created, the well planner then moves the surface location of the base case platform a fixed distance, usually in one of the four compass directions, and recalculates the cumulative measured depth. If the cumulative measured depth decreases from the base case measurement, the well planner knows that there is a potential location which is “better” than the base case location. The planner then goes through many iterations moving the platform location by different distances and to different compass directions from the base case location looking for the best location based on the total calculated footage of the wellpaths that will be required to drill from the wells to the platform location.
The above-mentioned methodology has a number of drawbacks. For example, it is tedious, time consuming, and requires fixing the number of plans and targets to be reached. Using this methodology, it is not unusual for well planners to spend three to four weeks on just one project.
Other automated methods for platform placement use Monte-Carlo or random number based statistical calculations for platform placement and take into account producers vs. injectors, cost of processing facilities, and existing pipelines. They, however, do not take into account target weighting, which is addressed in U.S. Pat. No. 7,200,540. The '540 Patent, which is assigned to Landmark Graphics Corporation and is incorporated herein by reference, further addresses the need for a method that varies the number and locations of platforms and optimizes the targets used if the resultant platform set provides a plan that: a) reaches more targets; b) reaches the same number of targets with less distance; or c) reaches the same number of targets, but includes targets with higher weighting values based on the reservoir parameters. In short, the '540 Patent describes systems that implement methods for selecting a set of platform locations, determining additional platform locations, and determining an optimum location for each platform location in the set of platform locations.
The '540 Patent, however, does not address the need to utilize surface topography for automatically extracting pad elevations after positioning when working on large scale onshore field development planning, especially in mountainous regions. Additionally, the '540 Patent does not address the ability to update existing pad elevations using a surface grid or the ability to restrict the placement of pads based on slope constraints.
There is also a need, which is not met by the prior art and which will reduce the risk of collision, to optimize slot template orientations by aligning them on strike with the surface elevation model or rotating them based on the planned trajectories. Due to the tight spacing of slot templates, there is also a need to optimally assign plans to the proper slots and to stagger kick-offs and nudge individual plans.
The present invention therefore, meets the above needs and overcomes one or more deficiencies in the prior art by providing systems and methods for orienting a slot template using incremental rotations and positioning a pad using incremental nudges.
In one embodiment, the present invention includes a computer implemented method for orientating a slot template, which comprises: i) computing an optimum slot assignment value for the slot template based on a predetermined number of slots, a predetermined number of plans, a trajectory for each plan and an initial angle using a computer processor; ii) rotating the slot template by a predetermined angle to a new angle; iii) computing another optimum slot assignment value for the slot template based on the predetermined number of slots, the predetermined number of plans, the trajectory for each plan and the new angle using the computer processor; iv) repeating the steps of i) rotating the slot template by a predetermined angle to a new angle; and ii) computing another optimum slot assignment value until the slot template is rotated to another predetermined angle; v) identifying each new angle when the another optimum slot assignment value is less than the optimum slot assignment value; and vi) orienting the slot template at the last identified new angle.
In another embodiment, the present invention includes a non-transitory program carrier device tangibly carrying computer executable instructions for orientating a slot template. The instructions are executable to implement: i). computing an optimum slot assignment value for the slot template based on a predetermined number of slots, a predetermined number of plans, a trajectory for each plan and an initial angle; ii) rotating the slot template by a predetermined angle to a new angle; iii) computing another optimum slot assignment value for the slot template based on the predetermined number of slots, the predetermined number of plans, the trajectory for each plan and the new angle; iv) repeating the steps of i) rotating the slot template by a predetermined angle to a new angle; and ii) computing another optimum slot assignment value until the slot template is rotated to another predetermined angle; v) identifying each new angle when the another optimum slot assignment value is less than the optimum slot assignment value; and vi) orienting the slot template at the last identified new angle.
In yet another embodiment, the present invention includes a computer implemented method for positioning a pad, comprising: i) computing a slot template geometry for the pad based on a predetermined number and position of slots on the pad using a computer processor; ii) computing nudge parameters for each plan assigned to a respective slot based on the slot template geometry using the computer processor; iii) adjusting a nudge for each plan based on the nudge parameters for each respective plan; iv) moving each nudge by a predetermined angle toward a target azimuth if a difference between an azimuth from each nudge to a respective slot and another azimuth from each nudge to a respective target does not meet a predetermined allowable value; v) repeating the steps of adjusting a nudge for each plan and moving each nudge until each plan is in a position that meets a minimum separation distance at a final kick-off depth and the difference between the azimuth and the another azimuth for each respective nudge meets the predetermined allowable value; and vi) applying the nudge for each respective plan.
In yet another embodiment, the present invention includes a non-transitory program carrier device tangibly carrying computer executable instructions for positioning a pad. The instructions are executable to implement: i) computing a slot template geometry for the pad based on a predetermined number and position of slots on the pad; ii) computing nudge parameters for each plan assigned to a respective slot based on the slot template geometry; iii) adjusting a nudge for each plan based on the nudge parameters for each respective plan; iv) moving each nudge by a predetermined angle toward a target azimuth if a difference between an azimuth from each nudge to a respective slot and another azimuth from each nudge to a respective target does not meet a predetermined allowable value; v) repeating the steps of adjusting a nudge for each plan and moving each nudge until each plan is in a position that meets a minimum separation distance at a final kick-off depth and the difference between the azimuth and the another azimuth for each respective nudge meets the predetermined allowable value; and vi) applying the nudge for each respective plan.
Additional aspects, advantages and embodiments of the invention will become apparent to those skilled in the art from the following description of the various embodiments and related drawings.
The present invention is described below with references to the accompanying drawings in which like elements are referenced with like reference numerals, and in which:
The subject matter of the preferred embodiments is described with specificity however, is not intended to limit the scope of the invention. The subject matter thus, might also be embodied in other ways to include different steps, or combinations of steps, similar to the ones described herein, in conjunction with other present or future technologies. Although the term “step” may be used herein to describe different elements of methods employed, the term should not be interpreted as implying any particular order among or between various steps herein disclosed unless otherwise expressly limited by the description to a particular order.
Referring now to
In step 102, a surface elevation model and subsurface data are loaded, which may be used to populate a 3D viewer. Of primary importance are the subsurface targets that will dictate surface pad positioning as well as well path trajectory design. The targets may be imported from an ASCII delimited text file or automatically generated according to U.S. Pat. No. 7,096,172, which is assigned to Landmark Graphics Corporation and is incorporated herein by reference.
In step 104, the pad parameters are defined, such as the number of slots and the number of wells.
In step 106, the well path types to be used (i.e. S-shaped, Slant, Horizontal, etc.) are defined along with their priority. Trajectory constraints are also defined for each well path type selected, which specify if each trajectory will penetrate single targets, multiple targets or a combination of both. The number of slots (wells) per pad should also be defined at this step.
In step 108, the method 100 determines if the surface elevation model is to be used for pad positioning. If the surface elevation model is to be used for pad positioning, go to step 108b. If the surface elevation model is not to be used for pad positioning, then go to step 110.
In step 108b, pads (preexisting or new) are positioned based on the surface elevation model in several ways. The surface elevation model may be used in both the original positioning of the pad and in the final setting of the orientation of the pad. Limits on the elevation and slope (or grade) can impact whether particular locations can or cannot be used. As an example, the user may restrict pad positioning to locations where the slope is less than 15 degrees or to elevations greater than 7000 feet because gathering stations are below this elevation (i.e. due to liquid handling considerations). By extracting the elevations when the pads are positioned, and assigning them to each respective pad (plus a user specified air gap), the user can create Rotary Kelly Bushing elevations for the proposed wells, which are generally used as the starting reference points for well paths. This is a modification to the algorithms utilized in the '540 Patent. There is also a more subtle way in which the extracted elevations can influence the pad positioning. When a particular site is being evaluated, its geometric positioning, relative to the targets that are being considered for use are compared to the engineering constraints placed upon the types of wells being considered. So, for a particular target, a location at one elevation might be capable of hitting that target with a particular well design at another location that is the same distance laterally, but at a lower elevation, would not. It also provides the orientation of the elevation. This information is utilized to orient the pads on strike (i.e. parallel to) with the contours.
In step 110, pads are positioned. Existing pads may be used with available slots. In this case the user would have to allocate slots as “taken” by existing wells and the number of trajectories designed from these pads will be limited to the number of available slots. If any additional pads are required to hit remaining targets they will be automatically generated and positioned according to the '540 Patent. If no pads exist, the new pads will be positioned automatically according to the '540 Patent with the number of plans per pad dictated by the planning constraints along with the number of slots per pad. A case may exist where the only pads to be used currently exist. In this case, no new pads will be generated and the number of well paths generated will be limited to a maximum being the number of available slots on each pad.
In step 112, plans for each pad are automatically generated. Once all “new” pads are positioned by step 108b, or in the alternative step 110, the surface elevation is extracted from the surface elevation grid and the air gap is applied (if applicable) to generate the starting reference point elevation—which is applied to all plans that are automatically generated in step 112. For “existing” pads, the elevations can be updated based on the elevation model.
In step 114, the slot template geometry for each pad is defined. This would include the number of rows and columns, the spacing and the orientation.
In step 116, the method 100 determines whether to use the elevation model to orient the templates. If the template geometry is elongated and the terrain is fairly steep, the user might wish to optimize the orientation of the template such that the pad was as flat as possible—i.e. oriented along strike. When this occurs, the elevation model will be used to orient the slot template based on elevation grid contours. If the elevation model should be used, then the method 100 proceeds to step 116b. If the elevation model should not be used, then the method 100 proceeds to step 118.
In step 116b, the slot template is oriented based on elevation grid contours according to the method 200 illustrated in
In step 118, the method 100 determines whether to auto-orient each slot template. The user might prefer to orient the slot template such that there are the fewest problems caused by plans that cross each other or interfere with other slots. In this case, the slot template is automatically oriented based on minimizing interference between plans. If each slot template should be auto-oriented, then the method 100 proceeds to step 118b. If each slot template should not be auto-oriented, then the method 100 proceeds to step 120.
In step 118b, each slot template orientation is optimized based on minimizing interference between plans according to the method 300 illustrated in
In step 120, plans are automatically assigned to the appropriate slots based on their trajectory to minimize the risk of collision.
In step 122, the current status of the pad with respect to slot allocation is evaluated as it pertains to anti-collision issues. If all planned kick-offs work, then there is no need to optimize or nudge the plans. If there are plans that do not meet the required separation criteria (i.e. ft separation/1000 feet of measured depth), it may be necessary to optimize the kick-offs to achieve the required separation as illustrated, for example, in
Referring now to
In
In step 202, the Northeastern most slot is found (Slot1). Two slots that are representative of the two ends of the long axis of the template must be determined. The most Northern slot and the most Eastern slot among them is determined to be the most Northeastern slot.
In step 204, the most common azimuth from the location of Slot1 is found (Azm). A histogram of the azimuths of the other slots is then built from this slot.
In step 206, the slot along Azm which is the farthest away from Slot1 is found (Slot2).
In step 208, BestShift is set equal to zero. BestShift is used to hold the amount of rotating needed to arrive at the optimum angle used to optimize the slot template.
In step 210, the distance in elevations between Slot1 and Slot2 is found (MinDiff).
In step 212, the value of Slot2 is changed by rotating Slot2 around Slot1 by one degree in one degree increments from 0 to 359 degrees.
In step 214, the difference between Slot1 and the new Slot2 is computed using techniques well known in the art and the result (Diff) is stored. At each angle formed by the new Slot2, the grid is checked by measuring the differences in elevation between the two slots in step 214. The azimuth where the absolute difference in elevation is the least is the optimum angle.
In step 216, Diff and Mindiff are compared. If Mindiff is less than Diff in step 216, go to step 222. If Mindiff is greater than Diff, go to step 218.
In step 218, Mindiff is set equal to Diff.
In step 220, BestShift is set equal to i.
In step 222, variable i is initialized to 0. If i is less than 360, increase i by 5 and go to step 212. If i is not less than 360, then go to step 224. During this process, BestShift is constantly updated to find the optimum angle needed to rotate the slot template.
In step 224, the template is rotated to the optimum angle BestShift. The method 200 then returns to step 120.
In
In step 302, MinProblems is set equal to “findOptimumSlotAssignment( )”. The algorithm “findOptimumSlotAssignment( )” is illustrated in
In step 304, MinAngle is set equal to 0.0 and Angle is set equal to 0.
In step 306, the template is rotated in 5 degree increments.
In step 307, Angle is set equal to Angle plus 5 degrees.
In step 308, Problems is set equal to “findOptimumSlotAssignment( )”.
In step 310, the method 300 determines if Problems is less than MinProblems. If Problems is less than MinProblems, then go to step 312. If Problems is not less than MinProblems, then go to step 316.
In step 312, MinProblems is set equal to Problems.
In step 314, MinAngle is set equal to Angle.
In step 316, the method 300 determines if the Angle is less than 360 degrees. If the Angle is less than 360 degrees, then go to step 306. If the Angle is greater than or equal to 360 degrees, then go to step 318. During this process, MinAngle is constantly updated to find the optimum angle needed to rotate the slot template.
In step 318, the template is rotated by MinAngle degrees. The method 300 then returns to step 120.
In
In step 402, the method 400 determines if the number of slots equals the number of plans, or if all kick-offs are about equal, or if the template is not rectangular. If the number of slots equals the number of plans, or if all kick-offs are about equal, or if the template is not rectangular, then go to step 404. If the number of slots does not equal the number of plans, or if all kick-offs are not about equal, or if the template is rectangular, then go to step 420.
In step 404, the “MakeInitialAssignmentOnMaximumBasis” algorithm is executed. The algorithm is intended to put each plan into the best possible slot for that plan. To do that, it goes through the list of plans and, for each one, it finds the best slot based upon being the nearest to the initial target in that plan and being the closest in orientation from the center of the pad to the initial target. Step 404 is further discussed in reference to
In step 406, the plan is added to a list of possibilities for that slot instead of assigning the plan directly to the slot. Once this has been done for each plan, it finds the slot with the most plans on its list. It orders the plans by kick-off depth, then, from the bottom of the list (deepest) up, it tries to find the best possible empty slot (one with an empty list) that will work for that plan.
In step 408, the plan is moved to the correct slot found in step 406.
In step 410, the method 400 determines if there are more unassigned plans. If there are more unassigned plans, then the method 400 proceeds to steps 406 and 408, which are repeated until all slots with plans in their lists are addressed. If there are no more assigned plans, then the method 400 proceeds to step 412.
In step 412, any previously assigned slots are added to the list for existing wells. Since the presence of existing wells would mean it was too late to re-orient the template, this would never be the case in the optimization workflow, but is useful when planning new wells from existing sites.
In step 414, the “FixAnyProblems” algorithm is executed. This algorithm is a sequence of repeated attempts to see if problems can be eliminated by swapping slot assignments. It looks at each combination of slots, decides whether they can be swapped or not, then if they can, swaps the plans in them and evaluates the results. If the results are fewer problems, the swap is considered successful. Otherwise, the plans are swapped back. This continues for 10 iterations or until a full pass is made with no successful swaps. The criteria for whether two slots can be swapped or not is if at least one of them has a plan, neither is locked, neither has an existing well and each is a valid slot type for the other's plan (some slots are reserved for specific well types). Step 414 is further discussed in reference to
In step 416, the “CountProblems” algorithm is executed. This algorithm is discussed in reference to
In step 418, the method 400 returns to step 302 as MinProblems or step 308 as Problems.
In step 420, the algorithm begins by sorting the plans by decreasing kick-off depth. This algorithm is designed to put the plans with the deepest kick-offs to the center of the template and leave any empty slots on the outside. It is primarily used when there are enough rows and columns for there to be an inside and an outside (>2×2) and there is some variation in the kick-off depths and there are some empty slots.
In step 422, the initial assignments are made by assigning each plan to the slot which has the lowest cost. Step 422 is further discussed in reference to
In step 424, any previously assigned slots are added to the list for existing wells. Since the presence of existing wells would mean it was too late to re-orient the template, this would never be the case in the optimization workflow, but is useful when planning new wells from existing sites.
In step 426, unused slots are locked so that they will not have plans assigned to them in step 428.
In step 428, the “FixAnyProblems” algorithm is executed. This algorithm is a sequence of repeated attempts to see if problems can be eliminated by swapping slot assignments. It looks at each combination of slots, decides whether they can be swapped or not, then if they can, swaps the plans in them and evaluates the results. If the results are fewer problems, the swap is considered successful. Otherwise, the plans are swapped back. This continues for 10 iterations or until a full pass is made with no successful swaps. The criteria for whether two slots can be swapped or not is if at least one of them has a plan, neither is locked, neither has an existing well and each is a valid slot type for the other's plan (some slots are reserved for specific well types). Step 428 is further discussed in reference to
In
In step 502, MinCost is set equal to 10000000.
In step 504, the method 500 determines if the slot is not used and if the slot type is compatible with the plan type. If the slot is not used and is compatible with the plan type, then the method 500 continues to step 506. If the slot is used and is not compatible with the plan type, then the method 500 continues to step 520.
In step 506, Cost is defined as the distance from the slot to the target times the distance from the template center to the slot. Cost is multiplied times a minimum of 5 degrees or the difference between the angles from the center to the slot and the center to the first target.
In step 508, Angle is defined as the difference between the azimuth center to the slot and the center to the first target.
In step 510, the method 500 determines if Angle is less than 5. If Angle is less than 5, then the method 500 continues to step 510b. If Angle is not less than 5, then the method 500 continues to step 512. A minimum of 5 degrees is used to avoid zero divide issues and to keep differences smaller than 5 degrees from having an inappropriately large significance when used as a divisor. This should put the deepest kick-off plans closest to the center and the empty slots farthest from the center.
In step 510b, Angle is set equal to 5.
In step 512, Cost is set equal to Cost multiplied by Angle.
In step 514, the method 500 determines if Cost is less than MinCost. If Cost is less than MinCost, then the method 500 continues to step 516. If Cost is not less than MinCost, then the method 500 continues to step 504.
In step 516, MinCost is set equal to Cost.
In step 518, MinSlot is set equal to Slot.
In step 520, the method 500 determines if there are more slots. If there are more slots, then the method 500 continues to step 504. If there are no more slots, then the method 500 continues to step 522.
In step 522, the method 500 determines if MinSlot is not equal to Null. If MinSlot is not equal to Null, then the method 500 continues to step 522b. If MinSlot is equal Null, then the method 500 continues to step 524.
In step 522b, the plan is assigned to MinSlot.
In step 524, the method 500 determines if there are more plans to assign. If there are more plans to assign, then the method 500 continues to step 502. If there are no more plans to assign, then the method 500 returns to step 424.
In
In step 602, MaxVal is set equal to −10000000.
In step 604, the method 600 determines if the slot is not used, and if the slot type is compatible with the plan type. If the slot is not used and is compatible with the plan type, then the method 600 continues to step 606. If the slot is used and is not compatible with the plan type, then the method 600 continues to step 620.
In step 606, the difference between the distance from the center to the first target and the distance from the target to the slot is found (Val).
In step 608, the difference between the azimuth center to the slot and the center to the first target is found (Angle).
In step 610, the method 600 determines if Angle is less than 0.01. If Angle is less than 0.01, then the method 600 continues to step 610b. If Angle is not less than 0.01, then the method 600 continues to step 612.
In step 610b, Angle is set equal to 5.
In step 612, Val is set equal to Val divided by Angle.
In step 614, the method 600 determines if Val is greater than MaxVal. If Val is greater than MaxVal, then the method 600 continues to step 616. If Val is not greater than MaxVal, then the method 600 continues to step 620.
In step 616, MaxVal is set equal to Val.
In step 618, MaxSlot is set equal to Slot.
In step 620, the method 600 determines if there are more slots. If there are more slots, then the method 600 continues to step 604. If there are no more slots, then the method 600 continues to step 622.
In step 622, the method 600 determines if MaxSlot is not equal to Null. If MaxSlot is not equal to Null, then the method 600 continues to step 622b. If MaxSlot is equal to Null, then the method 600 continues to step 624.
In step 622b, a plan is assigned to the list for slots.
In step 624, the method 600 determines if there are more plans to assign. If there are more plans to assign, then the method 600 continues to step 602. If there are no more plans, then the method 600 continues to
In step 626, Slot is set equal to the slot with the most plans in its list.
In step 628, the plans in Slot's list are sorted by kick-off depth.
In step 630, the best alternate empty slot for the plan is found by starting with the deepest plan and going through each plan.
In step 632, the method 600 determines if there was an alternate slot found. If there was an alternate slot found, then the method 600 continues to step 634. If there was no alternate slot found, then the method 600 continues to step 638.
In step 634, the plan is assigned to the alternate slot.
In step 636, the plan is removed from the selected slot's list.
In step 638, the method 600 determines if Length is equal to 1. Length is the number of plans in Slot's list. If Length is equal to 1, then the method 600 continues to step 406. If Length is not equal to 1, then the method 600 continues to step 640.
In step 640, element 1 is removed from the list of plans.
In step 642, the method 600 determines if Length is greater than 1. If length is greater than 1, then the method 600 continues to step 640. If Length is not greater than 1, then the method 600 continues to step 644.
In step 644, the method 600 determines if there are more plans. If there are more plans, then the method 600 continues to step 630. If there are no more plans, then the method 600 continues to step 646.
In step 646, the remaining slot is assigned to the plan.
In step 648, variable k is initialized to 0. If k is less than the number of slots, increase k by 1 and return to step 626. If k is greater than the number of slots, then the method 600 returns to step 406.
In
In step 702, MinProblems is assigned a value determined by the “CountProblems” algorithm as discussed in reference to
In step 704, Changed is set equal to false.
In step 706, the method 700 determines if it is possible to swap plans in slots. If it is not possible to swap plans in slots, then the method 700 continues to step 720. If it is possible to swap plans in slots, then the method 700 continues to step 708.
In step 708, plans in slots I and J are swapped.
In step 710, Problems is assigned a value determined by the “CountProblems” algorithm as discussed in reference to
In step 712, the method 700 determines if Problems is less than MinProblems. If problems is less than MinProblems, then the method 700 continues to step 714. If Problems is not less than MinProblems, then the method 700 continues to step 718.
In step 714, MinProblems is set equal to Problems.
In step 716, Changed is set equal to True.
In step 718, plans I and J are swapped back to their original position.
In step 720, variable j is initialized to equal i+1. If j is less than the number of slots, then increase j by 1 and go to step 706. If j is greater than the number of slots, then go to step 722.
In step 722, variable i is initialized to equal 0. If i is less than the number of slots minus 1, then increase i by 1 and go to step 706. If i is greater than the number of slots minus 1, then go to step 724.
In step 724, Changed is set equal to false.
In step 726, the method 700 determines if method 700 has completed 10 iterations. If there have not been 10 iterations of method 700, then the method 700 returns to step 704. If there have been 10 iterations of method 700, then the method 700 returns to step 416.
In
In step 802, Problems is set equal to 0.0.
In step 804, the method 800 determines if plans I and J cross. If plans I and J do cross, then the method 800 continues to step 806. If plans I and J do not cross, then the method 800 continues to step 810.
In step 806, the method 800 determines if there is any kick-off optimization. If there is kick-off optimization, then the method 800 continues to step 808. If there is no kick-off optimization, then the method 800 continues to step 806b.
In step 806b, Problems is set equal to Problems plus 3.
In step 808, Problems is set equal to Problems plus 1.
In step 810, the method 800 determines if plan I interferes with slot J. If plan I interferes with slot J, then the method 800 continues to step 812. If plan I does not interfere with slot J, then the method 800 continues to step 818.
In step 812, Problems is set equal to Problems plus 3.
In step 814, the method 800 determines if slot J is not empty. If slot J is not empty, then the method 800 continues to step 816. If slot J is empty, then the method 800 continues to step 818.
In step 816, Problems is set equal to Problems plus 2.
In step 818, the method 800 determines if plan J interferes with slot I. If plan J interferes with slot I, then the method 800 continues to step 820. If plan J does not interfere with slot I, then the method 800 continues to step 826.
In step 820, Problems is set equal to Problems plus 3.
In step 822, the method 800 determines if slot I is not empty. If slot I is empty, then the method 800 continues to step 826. If slot I is not empty, then the method 800 continues to step 824.
In step 824, Problems is set equal to Problems plus 2.
In step 826, variable j is initialized to equal i+1. If j is less than the number of slots, then increase j by 1 and return to step 804. If j is greater than the number of slots, then go to step 828.
In step 828, variable i is initialized to equal 0. If i is less than the number of slots minus 1, then increase i by 1 and return to step 804. If i is greater than the number of slots minus 1, then go to step 830.
In step 830, the method 800 determines if the slot has a plan. If the slot does not have a plan, then the method 800 continues to step 828. If the slot has a plan, then the method 800 continues to step 832.
In step 832, Problems is set equal to Problems plus distance from the slot to the first target divided by 100.
In step 834, the method 800 determines if the plan crosses the diagonal of the template. If the plan crosses the diagonal of the template, then the method 800 continues to step 834b. If the plan does not cross the diagonal of the template, then the method 800 continues to step 836.
In step 834b, Problems is set equal to Problems plus 2.
In step 836, the method 800 determines if the slot is reserved for a specific type. If the slot has been reserved for a specific type, then the method 800 continues to step 836b. If the slot has not been reserved for s specific type, then the method 800 continues to step 838.
In step 836b, Problems is set equal to Problems plus 10.
In step 838, variable j is initialized to equal 0. If j is less than the number of slots minus 1, then increase j by 1 and return to step 830. If j is greater than the number of slots minus 1, then go to step 840.
In step 840, Problems is returned to step 416, 702, or 710.
Referring now to
In
In step 902, the method 900 determines whether to optimize with nudges. If optimizing without nudges is selected, then go to step 902b. If optimizing with nudges is selected, then go to step 904. For the purpose of designing nudging patterns, there are 4 significant geometries; a single line, a double line, a circle and a rectangular pattern containing 3 or more rows and 3 or more columns. For purposes of this algorithm, a double line and a circle will be considered the same geometry as they will be handled the same. Once the geometry has been established, the appropriate algorithm for determining the initial inclinations and azimuths will be executed. Then any issues with overlapping nudge locations, or plans that have been nudged too far from their intended azimuth, will be addressed. Once this has been straightened out, the nudges are applied to the plans, then the set of nudges are optimized.
In step 902b, the “OptimizeWithoutNudges” algorithm is executed. Step 902 is further discussed in reference to
In step 904, the method 900 determines if the plans were previously nudged. If the plans were previously nudged, then the method 900 ends. If the plans were not previously nudged, then go to step 906.
In step 906, the method 900 determines if the plans have been assigned to slots. If the plans have been assigned to slots, then go to step 908. If the plans have not been assigned to slots, then the method 900 ends.
In step 908, the method 900 determines if the minimum kick-off is less than the water depth. If the minimum kick-off is less than the water depth, then the method 900 ends. If the minimum kick-off is not less than the water depth, then go to step 910.
In step 910, the method 900 determines if the maximum initial kick-off is less than the minimum initial kick-off. If the maximum initial kick-off is less than the minimum initial kick-off, then the method 900 ends. If the maximum initial kick-off is not less than the minimum initial kick-off, then go to step 912.
In step 912, the method 900 determines if the maximum final kick-off is less than the minimum final kick-off. If the maximum final kick-off is less than the minimum final kick-off, then the method 900 ends. If the maximum final kick-off is not less than the minimum final kick-off, then go to step 914.
In step 914, the method 900 determines if there is insufficient difference between initial and final kick-offs for nudge. If there is insufficient difference between initial and final kick-offs for nudge, then the method 900 ends. If there is not insufficient difference between initial and final kick-offs for nudge, then go to step 916.
In step 916, the “ComputeGeometry” algorithm is executed. This algorithm is further discussed in reference to
In step 918, the method 900 determines if Geometry has been set equal to 1. If Geometry equals 1, then go to step 918b. If Geometry does not equal 1, then go to step 920.
In step 918b, the “computeNudgeParametersForEachPlanUsingSingleLineAlgorithm” algorithm is executed. This algorithm is further discussed in reference to
In step 920, the method 900 determines if Geometry has been set equal to 2. If Geometry equals 2, then go to step 920b. If Geometry does not equal 2, then go to step 922.
In step 920b, the “computeNudgeParametersForEachPlanUsingDoubleLineOrCircleAlgorithm” algorithm is executed. This algorithm is further discussed in reference to
In step 922, Geometry is set equal to 3.
In step 922b, the “computeNudgeParametersForEachPlanUsingRectangularAlgorithm” algorithm is executed. This algorithm is further discussed in reference to
In
In step 924, the “GetPointsClear” algorithm is executed. This algorithm is further discussed in reference to
In step 926, Done is set equal to a value returned by the “FixAzimuths” algorithm. The algorithm is fairly simple. For each plan, check the difference between the slot to nudge azimuth and the nudge to target azimuth and, if the absolute value exceeds the allowable value, walk the nudge 1 degree at a time toward the target azimuth until it is within the allowable value. Since the nudge azimuth was selected based upon maintaining separation and this algorithm sacrifices separation to bring azimuths into user-specified limits, the two algorithms are combined thus—executing “GetPointsClear” (step 924), then “FixAzimuths” (step 926) until both of the azimuths are fixed and the proper amount of separation is achieved. The “FixAzimuths” algorithm is further discussed in reference to
In step 928, the method 900 determines if Done is equal to True. If Done is equal to True, then go to step 932. If Done is not equal to True, then go to step 930.
In step 930, the method 900 returns to step 924, repeating this loop for a maximum of five iterations. A limit of 5 iterations is placed on this process to keep it from running indefinitely in the case where the goal of steps 924-26 cannot be met.
In step 932, the initial nudges are applied to their respective plans.
In step 934, the method 900 determines if there are more plans. If there are more plans, then go to step 932. If there are no more plans, then go to step 936.
In step 936, the “OptimizeNudges” algorithm is executed. The nudges applied in step 932 are optimized to reduce the risk of collision. During execution of “OptimizeNudges”, there are a number of ways that the plans may be evaluated in order to insure that they do not get too close to one another and stay within engineering constraints. It is almost impossible to achieve both of these goals simultaneously, so the separation issues are usually resolved first and then the other goals are addressed without introducing separation issues. There are 3 types of separation issues. The first is where a plan is actively getting closer to another plan and gets within the minimum separation distance. The second is where the plans are already too close to one another before they have deviated from their original vertical trajectory. An example of the second type would be where two wells are being planned from slots that are 5 feet apart and the user has specified a minimum separation of 6 feet per 1000 feet and a minimum nudge depth of 500 feet. Once both plans are at 500 feet, there has been a total of 1000 feet drilled. So the plans need to be at least 6 feet apart but the slots are only 5 feet apart. Because the “OptimizeNudges” algorithm does not resolve this, it simply acknowledges it and does not let the optimization become adversely impacted by it. The third type of separation issue is where the plans are moving away from each other, but at a slower rate than the desired separation is increasing. This would probably happen in the example above if the user had set the minimum nudge depth to 400 feet. At 400 feet, the plans would need to be 4.8 feet apart since the slots are 5 feet apart. Unless they were building at more than 1 degree per 100 feet or at azimuths more than 90 degrees apart, they would probably not be more than 6 feet apart by the time they were at 500 feet measured depth (md) along the wellbore. The “OptimizeNudges” algorithm has more control over this type of separation than it does over the second type of separation, but less so than it does over the first type of separation. For this reason, the algorithm measures these types of separation problems at different times, first concentrating on keeping the plans from actively moving toward one another, then making sure that they diverge fast enough. Likewise, the algorithm looks at different lengths of the plans at different steps in the algorithm. The algorithm, by its use of nudges and altering kick-offs, cannot eliminate or reduce separation problems between well plans that occur beyond the first target, so it does not attempt to measure or account for them. Likewise, during the point where nudges are being optimized, it does not measure or account for any separation problems that occur beyond the final kick-off since altering the nudges will have no impact upon them. This algorithm is further discussed in reference to
In
In step 1002, the “FindCenter” algorithm is executed. This algorithm is further discussed in reference to
In step 1004, the plans are sorted by decreasing slot distance, measured from the Center.
In step 1006, the list of previous plans is cleared by creating an empty set.
In step 1008, Incr is set equal to the maximum kick-off minus the minimum kick-off, divided by the number of plans minus 1.
In step 1010, md is set equal to the minimum kick-off depth.
In step 1012, the amount assigned to kick-off a plan is set equal to md.
In step 1014, Cost is set equal to “calculateOptimizationValue,” which is described more fully in reference to step 1102 in
In step 1016, md is set equal to md plus Incr.
In step 1018, the amount of plan kick-off is set equal to md.
In step 1020, Cost is set equal to “calculateOptimizationValue,” which is described more fully in reference to step 1102 in
In step 1022, the method 1000 determines if cost is greater than 0 and md less than the mazimum kick-off minus Incr. If cost is greater than 0 and md is less than the maximum kick-off minus Incr, then return to step 1016. If cost is not greater than 0 and md less than the maximum kick-off minus Incr, then go to step 1024.
In step 1024, the method 1000 determines if Cost is greater than 0. If Cost is greater than 0, then go to step 1026. If Cost is not greater than 0, then go to step 1046.
In step 1026, md is set equal to the minimum kick-off.
In step 1030, PreviousCost is set equal to cost.
In step 1032, md is set equal to md plus Incr.
In step 1034, the amount of plan kick-off is set equal to md.
In step 1036, Cost is set equal to “calculateOptimizationValue,” which is described more fully in reference to step 1102 in
In step 1038, the method 1000 determines if Cost is less than or equal to PreviousCost and Cost is greater than 0. If Cost is less than or equal to PreviousCost and Cost is greater than 0, then return to step 1030. If Cost is not less than or equal to PreviousCost and Cost is greater than 0, then go to step 1040.
In step 1040, the method 1000 determines if Cost is greater than PreviousCost. If Cost is greater than PreviousCost, then go to step 1042. If Cost is less than PreviousCost, then go to step 1046.
In step 1042, md is set equal to md minus Incr.
In step 1044, the amount of plan kick-off is set equal to md.
In step 1046, the current plan is added to the previous plan.
In step 1048, the method 1000 determines if there are more plans. If there are more plans, then go to step 1010. If there are no more plans, then go to step 1050.
In step 1050, Changed is set equal to False.
In step 1052, Value is set equal to 0.
In step 1054, the method 1000 determines if there are more plans. If there are more plans, then go to step 1056. If there are no more plans, then go to step 1064.
In step 1056, Result is set equal to a boolean value returned from the algorithm “OptimizeKickoff.” This algorithm is further discussed in reference to
In step 1058, the method 1000 determines if Result is equal to True. If Result is equal to True, then go to step 1060. If Result is not equal to True, then go to step 1062.
In step 1060, Change is set equal to True.
In step 1062, Value is set equal to Value plus calculateOptimizationValue.
In step 1064, the method 1000 determines if Changed is equal to false. If Changed is equal to false, then the method 1000 ends. If Changed is not equal to false, then go to step 1066.
In step 1066, variable i is initialized to equal 0. If i is less than 10, then increase i by 1 and return to step 1050. If i is greater than 10, then the method 1000 ends.
In
In step 1102, an optimization value (or cost as the case may be) is calculated by the following costs, which represent the initial value:
In step 1104, the method 1100 determines if the InitialValue is less than 0.1. If the InitialValue is less than 0.1, then go to step 1106. If the InitialValue is greater than 0.1, then go to step 1108.
In step 1106, a value of False is returned to step 1056.
In step 1108, the starting depth is set equal to the kick-off depth.
In step 1110, the md is set equal to the starting depth.
In step 1112, the optimization values are computed using techniques well known in the art at 1 increment above md, as well as one increment below md.
In step 1114, md is set equal to the optimization value that was smallest in step 1112.
In step 1116, the method 1100 determines if the optimum md is equal to the current md. If the optimum md is equal to the current md, then go to step 1112. If the optimum md is not equal to the current md, then go to step 1118.
In step 1118, Incr is divided in half.
In step 1120, the method 1100 determines if Incr is greater than 1.0. If Incr is greater than 1.0, then go to step 1112. If Incr is less than 1.0, then go to step 1122.
In step 1122, the method 1100 determines if md is equal to the original, starting kick-off depth. Up to 5 passes are processed through the plans unless, on a given pass, no kick-off depths were moved. If md is equal to the starting depth, then go to step 1126. If md is not equal to the starting depth, then go to step 1124.
In step 1124, a value of True is returned to step 1056.
In step 1126, a value of False is returned to step 1056.
In
In step 1202, N is set equal to the number of slots.
In step 1204, the slot with the maximum Y value is found, resolving ties with Maximum X, effectively finding the most Northeastern slot.
In step 1206, the number of slots at each orientation from that slot are counted.
In step 1208, the orientation with the maximum number of slots is found.
In step 1210, the method 1200 determines if maxCount is greater than N minus 2, where maxCount is the number of slots found at the orientation with the maximum number of slots in step 1208. If maxCount is greater than N minus 2, then go to step 1210b. If maxCount is less than N minus 2, then go to step 1212.
In step 1210b, a 1 is returned to step 916, representing single line geometry.
In step 1212, the method 1200 determines if maxCount is equal to 1. If maxCount is equal to 1, then go to step 1212b. If maxCount is not equal to 1, then go to step 1214.
In step 1212b, a 2 is returned to step 916, representing a circle geometry.
In step 1214, a 3 is returned to step 916, representing a rectangle with greater than three rows and three columns.
In order to understand the initial positioning of the nudges, it is necessary to think of the pad as having two templates. One at the surface, containing the original surface locations of the plans and one at the (expected) final kick-off depth that contains the locations where the plans will be after they have been nudged. The goal here is to have each plan in a location, which is more than the minimum separation at that depth from any other plan, be on an azimuth that is compatible with the plan's intended trajectory and not have crossed another plan to get there. Unfortunately, there is not a one-size-fits-all algorithm that will accomplish this for every possible geometry and the slot assignments play into it as well. It will be necessary to determine which algorithm works best, execute the algorithm and then fix any separation or azimuth issues.
In
In step 1302, the azimuth of the original plan is computed using techniques well known in the art and stored as the nudge azimuth. This step determines the original planned trajectory for each plan.
In step 1304, the method 1300 determines if the current slot y is the maximum y. If the current slot y is the maximum y, then go to step 1304b. If the current slot y is not the maximum y, then go to step 1306.
In step 1304b, the azimuth of the plan is stored as the maximum y azimuth. This step completes the process of finding the plan whose slot has the maximum y value (most Northern.)
In step 1306, the method 1300 determines if there are more plans. If there are more plans, then return to step 1302. If there are no more plans, then go to step 1308.
In step 1308, the method 1300 determines if the nudge azimuth is less than the maximum y azimuth. If the nudge azimuth is less than the maximum y azimuth, then go to step 1308b. If the nudge azimuth is not less than the maximum y azimuth, then go to step 1310.
In step 1308b, Azimuth is set equal to azimuth plus 360. This results in all smaller slots having 360 added to them.
In step 1310, the method 1300 determines if there are more plans. If there are more plans, then return to step 1308. If there are no more plans, then go to step 1312. When this step is done, the most Northern slot will have the minimum azimuth.
In step 1312, plans are sorted by ascending azimuth.
In step 1314, an azimuth of 360/nplans is assigned to each of the plans.
In step 1316, a nudge azimuth of 0.0 (due north) is assigned to the plan with the most Northern slot.
In step 1318, the nudge azimuth is set equal to Azm.
In step 1320, Azm is set equal to Azm plus AzmIncr. In this manner, a pattern of nudge locations will be created that is somewhat circular, albeit stretched by the length of the original template. Assuming a series of 8 slots in a straight line, for example, with plans having trajectories of 35, 0, 340, 110, 300, 250, 165, and 175 degrees (listed from Northeast to Southwest), the ordering would be azimuths 35, 110, 165, 175, 250, 300, 340, 0 (i.e., plans in slots 1, 4, 7, 8, 6, 5, 3, 2). Slot 1 would be nudged due north (0 degrees). The next plan, slot number 4, would be nudged 45 degrees (360/8) before heading in its 110 degree azimuth. The plan in slot 7 would get nudged 90 degrees and so on all the way around to the plan in slot 2, which would be nudged 315 degrees. This should maximize the distance between the plans at the final kick-off depths and minimize crossing issues.
In step 1322, the method 1300 determines if there are more plans. If there are more plans, then return to step 1318. If there are no more plans, then go to step 924.
In
In step 1402, the “FindCenter” algorithm is executed.
In step 1404, the azimuth from the center of the plan to the original slot is computed using techniques well known in the art.
In step 1406, the method 1400 determines if the current slot y is the maximum y. If the current slot y is the maximum y, then go to step 1406b. If the current slot y is not the maximum y, then go to step 1408.
In step 1406b, the azimuth of the plan is stored as the maximum y azimuth. This step completes the process of finding the plan whose slot has the maximum y value (most Northern).
In step 1408, the method 1400 determines if there are more plans. If there are more plans, then return to step 1404. If there are no more plans, then go to step 1410.
In step 1410, the method 1400 determines if the nudge azimuth is less than the maximum y azimuth. If the nudge azimuth is less than the maximum y azimuth, then go to step 1410b. If the nudge azimuth is not less than than the maximum y azimuth, then go to step 1412.
In step 1410b, Azimuth is set equal to azimuth plus 360. This results in all smaller slots having 360 added to them.
In step 1412, the method 1400 determines if there are more plans. If there are more plans, then go to step 1410. If there are no more plans, then go to step 1414. When this step is done, the most Northern slot will have the minimum azimuth.
In step 1414, plans are sorted by ascending azimuth.
In step 1416, an azimuth of 360/nplans is assigned to each of the plans.
In step 1418, a nudge azimuth of 0.0 (due north) is assigned to the plan with the most Northern slot.
In step 1420, the nudge azimuth is set equal to Azm.
In step 1422, Azm equal is set equal to Azm plus AzmIncr.
In step 1424, the method 1400 determines if there are more plans. If there are more plans, then return to step 1420. If there are no more plans, then go to step 924.
In
In step 1502, the “FindCenter” algorithm is executed. This algorithm will be further discussed in reference to
In step 1504, the “CalculateFactors” algorithm is executed. This algorithm will be further discussed in reference to
In step 1506, the “calculateMaximumStepOut” algorithm is executed. This algorithm will be further discussed in reference to
In step 1508, the original X offset and Y offset from the Center are obtained.
In step 1510, the X and Y offsets are multiplied by the X and Y factors, which are determined in steps 1606 and 1608, respectively, in
In step 1512, the azimuth and distance are computed using techniques well known in the art using the new X and Y offsets from step 1510.
In step 1514, the method 1500 determines if there are more plans. If there are more plans, then go to step 1508. If there are no more plans, then go to step 924.
In
In step 1602, the minimum and maximum values for slot X and Y offsets are obtained.
In step 1604, the result of the “CalculateMaximumStepout” algorithm in
In step 1606, the expanded X limits are divided by the original limits to get a multiplication factor for each X, which can be used compute the offsets of where the nudge should place the plan.
In step 1608, the expanded Y limits are divided by the original limits to get a multiplication factor for each Y, which can be used compute the offsets of where the nudge should place the plan. After this is complete, the method 1600 returns to step 1506.
In
In step 1702, the step out distance from the minimum initial kick-off depth to the minimum final kick-off depth is computed using dogleg severity and maximum nudge inclination. The step out distance is the lateral distance that a plan will travel during the course of a nudge. It includes both the distance that it travels as it is building to the nudge inclination and the distance it travels during the hold section. If the nudge is a build-hold-drop type, it will also include the lateral distance traveled as the plan drops back to vertical. Likewise, in a build-hold-drop, the user will specify the desired step out, so if the computed maximum step out is greater than that user-supplied value, the user-supplied max step out is used. Since the step out is dependent upon the nudge kick-off and the final kick-off depths (or the distance between them) and these values can vary, the minimum values for both of these and the maximum nudge inclination are used to obtain a representative step out for this computation.
In step 1704, the method 1700 determines if useSShaped is equal to True. If useSShaped is equal to True, then go to step 1708. If useSShaped is not equal to True, then go to step 1706.
In step 1706, the StepOutDistance is returned to step 1506.
In step 1708, the method 1700 determines if StepOutDistance is greater than maxStepOut. If StepOutDistance is greater than maxStepOut, then go to step 1710. If StepOutDistance is less than maxStepOut, then go to step 1706.
In step 1710, maxStepOut is returned to step 1506.
In
In step 1802, Clear is set equal to True.
In step 1804, the “TryFixingSeparationProblemsByIncreasingInclination” algorithm is executed. This algorithm is further discussed in reference to
In step 1806, the “TryFixingSeparationProblemsByIncreasingAzimuth” algorithm is executed. This algorithm is further discussed in reference to
In step 1808, the “TryFixingSeparationProblemsByDecreasingAzimuth” algorithm is executed. This algorithm is further discussed in reference to
In step 1810, the “TryFixingSeparationProblemsByDecreasingInclination” algorithm is executed. This algorithm is further discussed in reference to
In step 1812, the method 1800 determines if Clear is equal to True. If Clear is equal to True, then go to step 926. If Clear is not equal to True, then go to step 1814.
In step 1814, the method 1800 determines if it has made 3 iterations. If there have been 3 iterations, then go to step 926. If there have not been 3 iterations, then go to step 1802.
In
In step 1902, the method 1900 determines if NudgePointClear is not True. If NudgePointClear is not True, then go to step 1904. If NudgePointClear is True, then go to step 1924. The NudgePointClear result is determined according to the method 2300 in
In step 1904, origInclination is set equal to plan inclination.
In step 1906, prevDistance is set equal to getMinSeparation.
In step 1908, maxInclination is set equal to max userInclination, origInclination plus 2.
In step 1910, plan inclination is set equal to inclination.
In step 1912, the location is computed using techniques well known in the art.
In step 1914, the method 1900 determines if NudgePointClear is true. If NudgePointClear is true, then go to step 1924. If NudgePointClear is not true, then go to step 1916.
In step 1916, distance is set equal to getMinSeparation.
In step 1918, the method 1900 determines if distance is greater than prevDistance. If distance is greater than prevDistance, then go to step 1918b. If distance is not greater than prevDistance, then go to step 1920.
In step 1918b, prevDistance is set equal to distance.
In step 1920, plan inclination is set equal to plan inclination minus 0.25.
In step 1922, the location is computed using techniques well known in the art.
In step 1924, variable incl is initialized to originclination plus 0.25. If incl is less than maxInclination, increase inclination by 0.25 and return to step 1910. If incl is greater than maxInclination, then go to step 1926.
In step 1926, the method 1900 determines if NudgePointClear is false. If NudgePointClear is false, then go to step 1926b. If NudgePointClear is not false, then go to step 1928.
In step 1926b, Clear is set equal to false.
In step 1928, the method 1900 determines if there are more plans. If there are more plans, then return to step 1902. If there are no more plans, go to step 1806.
In
In step 2002, the method 2000 determines if NudgePointClear is not True. If NudgePointClear is not True, then go to step 2004. If NudgePointClear is True, then go to step 2024.
In step 2004, origAzimuth is set equal to plan nudge Azimuth.
In step 2006, prevDistance is set equal to getMinSeparation.
In step 2008, maxAzimuth is set equal to Azimuth plus 10.
In step 2010, plan nudge Azimuth is set equal to Azm.
In step 2012, the location of the nudge point is computed using techniques well known in the art.
In step 2014, the method 2000 determines if NudgePointClear is true. If NudgePointClear is true, then go to step 2024. If NudgePointClear is not true, then go to step 2016.
In step 2016, distance is set equal to getMinSeparation.
In step 2018, the method 2000 determines if distance is greater than prevDistance. If distance is greater than prevDistance, then go to step 2018b. If distance is not greater than prevDistance, then go to step 2020.
In step 2018b, prevDistance is set equal to distance.
In step 2020, plan nudge Azimuth is set equal to plan nudge Azimuth minus 1.
In step 2022, the location of the nudge point is computed using techniques well known in the art.
In step 2024, variable azm is initialized to equal origAzimuth. If azm is less than maxAzimuth, then increase azm by 1 and return to step 2010. If azm is greater than maxAzimuth, then go to step 2026.
In step 2026, the method 2000 determines if NudgePointClear is false. If NudgePointClear is false, then go to step 2026b. If NudgePointClear is not false, then go to step 2028.
In step 2026b, Clear is set equal to false.
In step 2028, the method 2000 determines if there are more plans. If there are more plans, then return to step 2002. If there are no more plans, go to step 1808.
In
In step 2102, the method 2100 determines if NudgePointClear is not True. If NudgePointClear is not True, then go to step 2104. If NudgePointClear is True, then go to step 2124.
In step 2104, origAzimuth is set equal to plan nudge Azimuth.
In step 2106, prevDistance is set equal to getMinSeparation.
In step 2108, maxAzimuth is set equal to Azimuth minus 10.
In step 2110, plan nudge Azimuth is set equal to azm.
In step 2112, the location of the nudge point is computed using techniques well known in the art.
In step 2114, the method 2100 determines if NudgePointClear is true. If NudgePointClear is true, then go to step 2124. If NudgePointClear is not true, then go to step 2116.
In step 2116, distance is set equal to getMinSeparation.
In step 2118, the method 2100 determines if distance is greater than prevDistance. If distance is greater than prevDistance, then go to step 2118b. If distance is not greater than prevDistance, then go to step 2120.
In step 2118b, prevDistance is set equal to distance.
In step 2120, plan nudge Azimuth is set equal to plan nudge Azimuth plus 1.
In step 2122, the location of the nudge point is computed using techniques well known in the art.
In step 2124, variable azm is initialized to equal origAzimuth. If azm is greater than minAzimuth, decrease azm by 1 and return to step 2110. If azm is less than mixAzimuth, then go to step 2126.
In step 2126, the method 2100 determines if NudgePointClear is false. If NudgePointClear is false, then go to step 2126b. If NudgePointClear is not false, then go to step 2128.
In step 2126b, Clear is set equal to false.
In step 2128, the method 2100 determines if there are more plans. If there are more plans, then return to step 2102. If there are no more plans, then go to step 1808.
In
In step 2202, the method 2200 determines if NudgePointClear is not True. If NudgePointClear is not True, then go to step 2204. If NudgePointClear is True, then go to step 2224.
In step 2204, origInclination is set equal to plan inclination.
In step 2206, prevDistance is set equal to getMinSeparation.
In step 2208, minInclination is set equal to min 1.0, origInclination minus 2.
In step 2210, plan inclination is set equal to inclination.
In step 2212, the location of the nudge point is computed using techniques well known in the art.
In step 2214, the method 2200 determines if NudgePointClear is true. If NudgePointClear is true, then go to step 2224. If NudgePointClear is not true, then go to step 2216.
In step 2216, distance is set equal to getMinSeparation.
In step 2218, the method 2200 determines if distance is greater than prevDistance. If distance is greater than prevDistance, then go to step 2218b. If distance is less than prevDistance, then go to step 2220.
In step 2218b, prevDistance is set equal to distance.
In step 2220, plan inclination is set equal to plan inclination plus 0.25.
In step 2222, the location of the nudge point is computed using techniques well known in the art.
In step 2224, variable incl is initialized to origInclination minus 0.25. If incl is greater than or equal to mixInclination, then decrease inclination by 0.25 and return to step 2210. If incl is less than minInclination, then go to step 2226.
In step 2226, the method 2200 determines if NudgePointClear is false. If NudgePointClear is false, then go to step 2226b. If NudgePointClear is not false, then go to step 2228.
In step 2226b, Clear is set equal to false.
In step 2228, the method 2200 determines if there are more plans. If there are more plans, then return to step 2202. If there are no more plans, then go to step 1812.
In
In step 2302, safeDistance is set equal to final minimum kick-off minus waterdepth divided by 1000 times error percentage times 2.1.
In step 2304, the method 2300 determines if nudge equals nudgeIn, which is the nudge point used as input to the method 2300 illustrated in
In step 2306, the method 2300 determines if there are more nudges. If there are more nudges, then return to step 2304. If there are no more nudges, then go to step 2308.
In step 2308, true is returned to steps 1902, 1914, 1926, 2002, 2014, 2026, 2102, 2114, 2126, 2202, 2214, and 2226.
In step 2310, the method 2300 determines if distance is less than safeDistance. If distance is less than safeDistance, then go to step 2312. If distance is not less than safeDistance, then go to step 2306.
In step 2312, false is returned to steps 1902, 1914, 1926, 2002, 2014, 2026, 2102, 2114, 2126, 2202, 2214, and 2226.
In
In step 2402, isOK is set equal to true.
In step 2404, deltaAzm is set equal to the slot to nudge Azimuth minus nudge to target Azimuth.
In step 2406, the method 2400 determines if deltaAzm is greater than allowableDeltaAzm. If deltaAzm is greater than allowableDeltaAzm, then go to step 2408. If deltaAzm is not greater than allowableDeltaAzm, then go to step 2404.
In step 2408, Angle1 is equal to nudge azimuth.
In step 2410, Angle2 is set equal to original plan azimuth.
In step 2412, the method 2400 determines if Angle2 is greater than Angle1 plus 180. If Angle2 is greater than Angle1 plus 180, then go to step 2412b. If Angle2 is not greater than Angle1 plus 180, then go to step 2414.
In step 2412b, Angel2 is set equal to Angle2 minus 360.
In step 2414, the method 2400 determines if Angle2 is less than Angle1 minus 180. If Angle2 is less than Angle1 minus 180, then go to step 2414b. If Angle2 is not less than Angle1 minus 180, then go to step 2416.
In step 2414b, Angel2 is set equal to Angle2 plus 360.
In step 2416, the method 2400 determines if Angle2 is greater than Angle1. If Angle2 is greater than Angle1, then go to step 2418. If Angle2 is not greater than Angle1, then go to step 2428.
In step 2418, the nudge azimuth is set equal to angle.
In step 2420, the location of the plan after the nudge is applied is computed using techniques well known in the art.
In step 2422, deltaAzm is computed using techniques well known in the art.
In step 2424, the method 2400 determines if deltaAzm is less than or equal to allowableDeltaAzm. If deltaAzm is less than or equal to allowableDeltaAzm, then go to step 2438. If deltaAzm is not less than or equal to allowableDeltaAzm, then go to step 2426.
In step 2426, Azm is initialized to Angle1 plus 1. If angle is less than Angle2, then increase angle by 1 and go to step 2418. If angle is not less than Angle2, then go to step 2438.
In step 2428, nudge azimuth is set equal to angle.
In step 2430, the location is computed using techniques well known in the art.
In step 2432, deltaAzm is computed using techniques well known in the art.
In step 2434, the method 2400 determines if deltaAzm is less than or equal to allowableDeltaAzm. If deltaAzm is less than or equal to allowableDeltaAzm, then go to step 2438. If deltaAzm is not less than or equal to allowableDeltaAzm, then go to step 2436.
In step 2436, Azm is initialized to Angle1 minus 1. If angle is less than Angle2, then decrease angle by 1 and go to step 2428. If angle is not less than Angle2, then go to step 2438.
In step 2438, the method 2400 determines if isNudgePointClear is equal to false. If isNudgePointClear is equal to false, then go to step 2440. If isNudgePointClear is not equal to false, then go to step 2442.
In step 2440, isOk is set equal to false.
In step 2442, the method 2400 determines if there are more plans. If there are more plans, then go to step 2404. If there are no more plans, then go to step 2444.
In step 2444, OK is returned (which has been set to True of False) to step 926.
In
In step 2502, the “FindCenter” algorithm is executed. This algorithm is further discussed in reference to
In step 2504, the plans are sorted by decreasing slot distance from the center. By starting off at the current nudge depths farthest from the pad center and not having to do much to those, and working inward, the early passes should be getting as close as possible to the required separation.
In step 2506, Incr is set equal to maximum nudge depth minus minimum nudge depth divided by number of plans minus 1.
In step 2508, the previous plans are cleared by setting the ordered set equal to an empty set. In each pass through this ordered set of plans, the algorithm will maintain a list of plans that it has previously worked on and use that list to do separation comparisons. In this manner, plan A is not adjusted for issues with plan B that will be fixed as soon as plan B is addressed. The plans are only compared with others that are already somewhat “fixed.”
In step 2510, md is set equal to the current nudge md.
In step 2512, md is set equal to md plus incr.
In step 2514, the set of plans are addressed, in order, by trying the nudge md that was set to the current (original) md in step 2510 and seeing if there is a depth at which the current plan is completely clear of previous plans.
In step 2516, while plan is not clear of previous plans and md is less than maximum nudge depth minus incr, go to step 2512.
In step 2518, the method 2500 determines if plan is not clear of previous plans. If plan is not clear of previous plans, then go to step 2520. When the plan is not clear of previous plans, method 2500 returns to the minimum nudge depth and works its way down to find a point where it is as clear of previous plans as possible. In this case, because the goal is to optimize the nudge depths, only the problems with plans approaching one another prior to final kick-off are addressed. If plan is clear of previous plans, then go to step 2534.
In step 2520, md is set equal to minimum nudge depth.
In step 2522, md is set equal to md plus incr.
In step 2524, the plans are addressed, in order, by trying the nudge md that was set to the current (original) md and seeing if there is a depth at which the current plan is completely clear of previous plans.
In step 2526, while plan is not clear of previous plans and md is less than maximum nudge depth minus incr and getting clearer(cost), go to step 2522.
In step 2528, the method 2500 determines if cost is lower. If cost is lower, then go to step 2534. If cost is not lower, then go to step 2530.
In step 2530, md is set equal to md minus incr.
In step 2532, the nudge depth is set equal to md.
In step 2534, the current plan is added to previous plan set.
In step 2536, the method 2500 determines asks if there are more plans. If there are more plans, then go to step 2510. If there are no more plans, then go to step 2538.
In step 2538, Incr is set equal to the maximum kick-off depth minus minimum kick-off depth divided by the number of plans minus 1.
In step 2540, the previous plans are cleared by being set equal to the empty set.
In step 2542, the method 2500 determines if the plan is not clear of previous plans. If plan is not clear of previous plans, then go to step 2544. If plan is clear of previous plans, then go to step 2558.
In step 2544, md is set equal to the minimum kick-off depth. A second pass is performed through the set of plans, this time working on the kick-off depths rather than the nudge depths. One pass through is needed, starting with the minimum kick-off, to look at all depths and see if one can be found that makes the plan completely clear of all other plans.
In step 2546, md is set equal to md plus incr.
In step 2548, the kick-off depth change is tried, meaning to re-compute the plan on a trial basis with it kicking off at the current md value.
In step 2550, while plan is not clear of previous plans and md is less than maximum kick-off depth minus incr and getting clearer(cost), go to step 2546.
In step 2552, the method 2500 determines if cost is lower. If cost is lower, then go to step 2558. If cost is not lower, then go to step 2554. If a plan completely clear of other plans cannot be found, the algorithm returns to the minimum and tries again—this time only looking as long as the cost is improving. In this manner, since the cost cannot be brought down to 0.0 (no separation problems), the algorithm will at least get the cost as low as possible.
In step 2554, md is set equal to md minus incr.
In step 2556, kick-off depth is set equal to md.
In step 2558, the plan is added to the previous plan set.
In step 2560, the method 2500 determines if there are more plans. If there are more plans, then go to step 2544. If there are no more plans, then go to step 2562.
In step 2562, Changed is set equal to False.
In step 2564, the method 2500 determines if optimize kick-off was successful. If optimize kick-off was successful, then go to step 2564b. If optimize kick-off was not successful, then go to step 2566. At this point, the kick-off for engineering constraints and length may be optimized without introducing any new separation issues.
In step 2564b, Changed is set equal to true.
In step 2566, the method 2500 determines if there are more plans. If there are more plans, then go to step 2564. If there are no more plans, then go to step 2568.
In step 2568, the method 2500 determines if Changed is equal to false. If Changed is equal to false, then the method 2500 ends. If Changed is not equal to false, then go to step 2570.
In step 2570, the method 2500 determines if the kick-off is not getting better. If the kick-off is not getting better, then the method 2500 ends. If the kick-off is getting better, then go to step 2572.
In step 2572, the method 2500 determines if there have been 5 iterations. If there have been 5 iterations, then go to
In
In step 2574, the previous plans are set equal to the empty set.
In step 2576, the method 2500 determines if the plan is completely clear of plan2. If the plan is completely clear of plan2, then go to step 2578. If the plan is not completely clear of plan2, then go to step 2580.
In step 2578, the “FixNudgeKickoffProblem” algorithm is executed. This algorithm is further discussed in reference to
In step 2580, the method 2500 determines if more plan2's are in previous plans. If more plan2's are in previous plans, then go to step 2576. If there are no more plan2's in previous plans, then go to step 2582.
In step 2582, the plan is added to the list of previous plans.
In step 2584, the method 2500 determines if there are more plans. If there are more plans, then go to step 2580. If there are no more plans, then go to step 2586.
In step 2586, the method 2500 determines if nudges are optional. If nudges are optional, then go to step 2588. If nudges are not optional, then the method 2500 ends.
In step 2588, the un-nudged version of the plan is obtained.
In step 2590, the method 2500 determines if the un-nudged version is completely clear of all other plans. If the un-nudged version is completely clear of all other plans, then go to step 2592. If the un-nudged version is not completely clear of all other plans, then go to step 2594.
In step 2592, the nudge is removed from the plan.
In step 2594, the method 2500 determines if there are more plans. If there are more plans, then go to step 2588. If there are no more plans, then the method 2500 ends.
In
In step 2602, the depth at which the plans first get too close is found.
In step 2604, the locations of both plans at that depth is found.
In step 2606, the method 2600 determines if plan 1 moved farthest laterally from the slot location. If plan 1 moved farthest laterally from the slot location, then go to step 2608. If plan 1 has not moved farthest laterally from the slot location, then go to step 2612.
In step 2608, plan 1 is set to be the deeper plan (Plan A).
In step 2610, plan 2 is set to be the shallower plan (Plan B).
In step 2612, plan 2 is set to be the deeper plan (Plan A).
In step 2614, plan 1 is set to be the shallower plan (Plan B).
In step 2616, the method 2600 determines if there is more room to move nudge on either plan. If there is more room to move nudge on either plan, then go to step 2618. If there is no more room to move nudge on either plan, then go to step 2616b. The algorithm iteratively attempts to (if possible) move plan A halfway from its current nudge depth to the maximum nudge depth and plan B halfway from its current nudge depth to the minimum.
In step 2616b, Failed is returned to step 2578.
In step 2618, plan A's nudge depth is moved half way to maximum nudge depth.
In step 2620, plan B's nudge depth is moved half way to minimum nudge depth.
In step 2622, the method 2600 determines if the plans are too close based on a predetermined criteria. If the plans are too close, then go to step 2624. If the plans are not too close, then go to step 2622b.
In step 2622b, Succeeded is returned to step 2578.
In step 2624, the azimuth difference between nudges is computed using techniques well known in the art.
In step 2626, plan B nudge azimuth is moved 1 degree away from plan A.
In step 2628, the method 2600 determines if the plans are not too close based on a predetermined criteria. If the plans are not too close, then go to step 2628b. If the plans are too close, then go to step 2630. If moving move plan A halfway from its current nudge depth to the maximum nudge depth and plan B halfway from its current nudge depth to the minimum does not work, step 2628 computes the difference in azimuth between plan A and plan B and moves plan B up to 3 degrees away from plan A. This process is repeated until either the plans are no longer too close or there is no more room to move the nudges up or down. This is a last resort approach to fixing the nudges when nothing else works.
In step 2628b, Succeeded is returned to step 2578.
In step 2630, variable i is initialized to equal 0. If i is less than 3, then increase i by 1 and go to step 2632. If i is greater than 3, then the method 2600 ends.
In step 2632, the method 2600 determines if the plans are too close based on a predetermined criteria. If the plans are too close, then go to step 2616. If the plans are not too close, then go to step 2622b. If the user has selected to have the algorithm nudge some plans rather than nudging all plans, another pass through may be performed, testing each plan for what would happen if that nudge was taken out. If the plan would still be completely clear of all other plans without the nudge, that nudge is removed. Because the optimization will almost always require some combination of nudged plans, and trying the various combinations could cause an astronomical number of iterations, it is much more efficient to nudge them all, then try removing them one by one.
In
In step 2702, N is set equal to the number of slots.
In step 2704, the total sum of Slot X values is found.
In step 2706, the total sum of slot Y values is found.
In step 2708, CenterX is set equal to SumX divided by N.
In step 2710, CenterY is set equal to SumY divided by N.
The following examples illustrate the objective of step 122 in
In order to optimize kick-off without using nudges, but varying the kick-off from a minimum of 1600 feet to a maximum of 2500 feet and maintaining a separation of 6 feet per 1000 feet, the algorithm will move the kick-off point of Plan 4 down to 1880 feet, which will resolve the issue of Plan 4 moving too close to Plan 3. However, with a minimum kick-off of 1600 feet, a separation of 6 feet per 1000 feet and slots that are spaced 7-10 feet from one another, nudging is required because all of the plans are closer than the minimum separation at kick-off.
In order to use nudges for all of the plans, giving it a build rate of 1 degree per 100 feet and a maximum nudge inclination of 5 degrees, a maximum azimuth change of 90 degrees and a nudge depth range of 400-800 feet, the algorithm will nudge them in the manner illustrated in
If, on the other hand, the azimuth change were restricted to about 20 degrees, the resulting nudges would be much more in line with the original trajectories as illustrated in
Alternatively, by specifying that the algorithm should only use nudges where they are needed, it will remove the nudge from Plan 4. Due to the spacing of the slots and the 1600 feet minimum kick-off, a maximum of one plan could not be nudged. Any two plans would be too close at the 1600 feet kick-off. It may be random that it happened to be Plan 4. For example, it could have been any plan, except for Plan 3, which had to nudge at a shallower depth than Plan 4. Due to the spacing of the 4 slots, they are all the same distance from the center in
The present invention may be implemented through a computer-executable program of instructions, such as program modules, generally referred to as software applications or application programs executed by a computer. The software may include, for example, routines, programs, objects, components, and data structures that perform particular tasks or implement particular abstract data types. The software forms an interface to allow a computer to react according to a source of input. AssetPlanner™, and/or TracPlanner™, which are commercial software applications marketed by Landmark Graphics Corporation, may be used as interface applications to implement the present invention. The software may also cooperate with other code segments to initiate a variety of tasks in response to data received in conjunction with the source of the received data. The software may be stored and/or carried on any variety of memory media such as CD-ROM, magnetic disk, bubble memory and semiconductor memory (e.g., various types of RAM or ROM). Furthermore, the software and its results may be transmitted over a variety of carrier media such as optical fiber, metallic wire, free space and/or through any of a variety of networks such as the Internet.
Moreover, those skilled in the art will appreciate that the invention may be practiced with a variety of computer-system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable-consumer electronics, minicomputers, mainframe computers, and the like. Any number of computer-systems and computer networks are acceptable for use with the present invention. The invention may be practiced in distributed-computing environments where tasks are performed by remote-processing devices that are linked through a communications network. In a distributed-computing environment, program modules may be located in both local and remote computer-storage media including memory storage devices. The present invention may therefore, be implemented in connection with various hardware, software or a combination thereof, in a computer system or other processing system.
Referring now to
The memory primarily stores the application programs, which may also be described as program modules containing computer-executable instructions, executed by the computing unit for implementing the present invention described herein and illustrated in
Although the computing unit is shown as having a generalized memory, the computing unit typically includes a variety of computer readable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. The computing system memory may include computer storage media in the form of volatile and/or nonvolatile memory such as a read only memory (ROM) and random access memory (RAM). A basic input/output system (BIOS), containing the basic routines that help to transfer information between elements within the computing unit, such as during start-up, is typically stored in ROM. The RAM typically contains data and/or program modules that are immediately accessible to, and/or presently being operated on, the processing unit. By way of example, and not limitation, the computing unit includes an operating system, application programs, other program modules, and program data.
The components shown in the memory may also be included in other removable/nonremovable, volatile/nonvolatile computer storage media. For example only, a hard disk drive may read from or write to nonremovable, nonvolatile magnetic media, a magnetic disk drive may read from or write to a removable, non-volatile magnetic disk, and an optical disk drive may read from or write to a removable, nonvolatile optical disk such as a CD ROM or other optical media. Other removable/non-removable, volatile/non-volatile computer storage media that can be used in the exemplary operating environment may include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like. The drives and their associated computer storage media discussed above provide storage of computer readable instructions, data structures, program modules and other data for the computing unit.
A client may enter commands and information into the computing unit through the client interface, which may be input devices such as a keyboard and pointing device, commonly referred to as a mouse, trackball or touch pad. Input devices may include a microphone, joystick, satellite dish, scanner, or the like.
These and other input devices are often connected to the processing unit through the client interface that is coupled to a system bus, but may be connected by other interface and bus structures, such as a parallel port or a universal serial bus (USB). A monitor or other type of display device may be connected to the system bus via an interface, such as a video interface. In addition to the monitor, computers may also include other peripheral output devices such as speakers and printer, which may be connected through an output peripheral interface.
Although many other internal components of the computing unit are not shown, those of ordinary skill in the art will appreciate that such components and the interconnection are well known.
Because the systems and methods described herein may be used to selectively and automatically position various platform types, they may be particularly useful for positioning pads for cell phone towers, electrical lines, homes, oil and gas rigs and the like.
While the present invention has been described in connection with presently preferred embodiments, it will be understood by those skilled in the art that it is not intended to limit the invention to those embodiments. Although the illustrated embodiments of the present invention relate to the positioning of pads and slot templates for the oil and gas industry, for example, the present invention may be applied to any drilling application in other fields and disciplines. It is therefore, contemplated that various alternative embodiments and modifications may be made to the disclosed embodiments without departing from the spirit and scope of the invention defined by the appended claims and equivalents thereof.
This application claims priority from U.S. Provisional Patent Application No. 61/027,694, filed on Feb. 11, 2008, which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4967844 | Brooks et al. | Nov 1990 | A |
5730219 | Tubel et al. | Mar 1998 | A |
6266619 | Thomas et al. | Jul 2001 | B1 |
6315054 | Brunet | Nov 2001 | B1 |
6356844 | Thomas et al. | Mar 2002 | B2 |
6853921 | Thomas et al. | Feb 2005 | B2 |
7079952 | Thomas et al. | Jul 2006 | B2 |
7096172 | Colvin et al. | Aug 2006 | B2 |
7200540 | Colvin et al. | Apr 2007 | B2 |
Number | Date | Country | |
---|---|---|---|
20090200014 A1 | Aug 2009 | US |
Number | Date | Country | |
---|---|---|---|
61027694 | Feb 2008 | US |