US11537981B2 - Produced physical bulk asset hauling dispatch system - Google Patents
Produced physical bulk asset hauling dispatch system Download PDFInfo
- Publication number
- US11537981B2 US11537981B2 US16/426,896 US201916426896A US11537981B2 US 11537981 B2 US11537981 B2 US 11537981B2 US 201916426896 A US201916426896 A US 201916426896A US 11537981 B2 US11537981 B2 US 11537981B2
- Authority
- US
- United States
- Prior art keywords
- network
- data package
- optimized
- physical
- processor
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active, expires
Links
- 238000000034 method Methods 0.000 claims abstract description 60
- 239000000969 carrier Substances 0.000 claims abstract description 50
- 238000004519 manufacturing process Methods 0.000 claims abstract description 26
- 230000008569 process Effects 0.000 claims abstract description 18
- 238000005457 optimization Methods 0.000 claims description 56
- 230000002401 inhibitory effect Effects 0.000 claims 1
- 239000007788 liquid Substances 0.000 abstract description 12
- 239000004576 sand Substances 0.000 abstract description 6
- 238000012384 transportation and delivery Methods 0.000 description 13
- 238000003860 storage Methods 0.000 description 11
- 238000010586 diagram Methods 0.000 description 10
- 238000004590 computer program Methods 0.000 description 8
- 230000004044 response Effects 0.000 description 8
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 8
- 230000007246 mechanism Effects 0.000 description 6
- 239000012530 fluid Substances 0.000 description 5
- 239000000047 product Substances 0.000 description 5
- 230000008676 import Effects 0.000 description 4
- 238000007726 management method Methods 0.000 description 4
- 238000012545 processing Methods 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 238000005553 drilling Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000008520 organization Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 239000003209 petroleum derivative Substances 0.000 description 2
- 238000013515 script Methods 0.000 description 2
- 240000008168 Ficus benjamina Species 0.000 description 1
- 238000004458 analytical method Methods 0.000 description 1
- 239000003795 chemical substances by application Substances 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 229930195733 hydrocarbon Natural products 0.000 description 1
- 150000002430 hydrocarbons Chemical class 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 239000012263 liquid product Substances 0.000 description 1
- 239000003921 oil Substances 0.000 description 1
- 239000003208 petroleum Substances 0.000 description 1
- 230000000644 propagated effect Effects 0.000 description 1
- 150000003839 salts Chemical class 0.000 description 1
- 238000007790 scraping Methods 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 239000002351 wastewater Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/08—Logistics, e.g. warehousing, loading or distribution; Inventory or stock management
- G06Q10/087—Inventory or stock management, e.g. order filling, procurement or balancing against orders
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/04—Forecasting or optimisation specially adapted for administrative or management purposes, e.g. linear programming or "cutting stock problem"
- G06Q10/047—Optimisation of routes or paths, e.g. travelling salesman problem
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/08—Logistics, e.g. warehousing, loading or distribution; Inventory or stock management
- G06Q10/083—Shipping
- G06Q10/0835—Relationships between shipper or supplier and carriers
- G06Q10/08355—Routing methods
-
- G—PHYSICS
- G08—SIGNALLING
- G08G—TRAFFIC CONTROL SYSTEMS
- G08G1/00—Traffic control systems for road vehicles
- G08G1/20—Monitoring the location of vehicles belonging to a group, e.g. fleet of vehicles, countable or determined number of vehicles
- G08G1/202—Dispatching vehicles on the basis of a location, e.g. taxi dispatching
Definitions
- the present invention generally relates to the management and shipment of physical bulk assets such as liquids, sand, and the like and, more particularly, to identifying and implementing optimal volumes of physical bulk assets at various sites and shipments of such optimal volumes between sites.
- the logistics involved with selling physical bulk assets such as liquid assets (e.g., petroleum products, salt water, etc.) in the absence of pipeline infrastructure involve the local inventory at tank batteries and trucking capacity.
- liquid assets e.g., petroleum products, salt water, etc.
- trucks There are many aspects of transportation in general that apply to the transportation of liquids produced in production operations.
- a delivery occurs between a single tank battery and market or other common delivery point.
- the single truck delivery is referred to as a load, where each hauled load costs the operator an amount determined by contract.
- the contracted fees can vary by load size, distance, and product.
- Destinations may be one or more markets and/or various other delivery points. For instance, destinations such as disposal wells typically exist at different locations around a field, where such wells are used for safe disposal of waste water from production operations. In specific scenarios, product is picked up from two or more tank batteries before delivering the liquids (referred to as a “split load”). While hauling from multiple locations in one truck load is common with water, it is most common to haul from a single location when transporting oil and condensate. A common situation is having only a single market for oil and condensate, dependent upon existing contracts or location. In more complex situations, multiple destinations can receive the product from a particular tank battery. In situations where products are dedicated to specific destinations, the number of decisions is reduced.
- Managing the resources to handle inventory, transportation, and disposition of liquid products is a highly complex task.
- the dispatch process represents a large amount of time spent by producers and carriers to provide adequate direction to complete the necessary work.
- Each type of user can have different interests, depending upon the relationship between producer, carrier and destination. Seeking operational efficiency in such management and transportation can be aided through the use of optimization models.
- Producers e.g., petroleum exploration and production company
- some existing optimization models receive input such as production forecasts, existing inventory levels, and macro hauling capacity and generate output representing optimal levels of fluids to maintain in inventory and to be shipped to efficiently utilize their hauling capacity and maintain flow assurance.
- Producers typically enter into different pricing arrangements with different carriers to transport liquid deliveries in various manners. Furthermore, producers can realize various profit levels by sending produced liquids into different markets. Accordingly, there are existing optimization models that receive inputs such as carrier contract parameters (e.g., in relation to prices, etc.), any dedicated carrier requirements (e.g., carriers that only haul certain liquid types, volume thresholds, etc.), market rates, and the like and generate output that aims to minimize delivery costs. For instance, such output may recommend that one or more particular carriers should be used to haul one or more particular loads into one or more particular markets in order to minimize such delivery costs. There are also industry standard vehicle routing models to minimize time, mileage, and/or other costs incurred in delivering requested loads from sources to destinations or markets.
- Operators who control truck shifts can act as operators and use such models with their own cost interests included to minimize their expenditure in hauling. For instance, a carrier can utilize the models by receiving load requests from one or more operators and designing truck shifts to meet the requirements of the operators while minimizing their own costs.
- the system can be used by producers and carriers in various manners to drive their unique interests in hauling and has representation for production operators or producers (e.g., oil and gas exploration and production company), carriers (e.g., oil or water haulers), and destinations (e.g., water disposal or recycle operator or oil market).
- production operators or producers e.g., oil and gas exploration and production company
- carriers e.g., oil or water haulers
- destinations e.g., water disposal or recycle operator or oil market.
- the disclosed system is capable of sharing necessary data between operators and carriers without granting complete access to the other's data.
- a producer interested in only particular mechanisms in the complete process e.g., only in relation to optimal inventory levels, carriers, and markets
- can supply producer specific input to the system which may include one or more producer-specific restraints
- receive output recommendations by the system in relation to trucks, loads, destinations, and the like e.g., trucks, loads, destinations, and the like.
- a particular hauler contracted with the producer may utilize a different mechanism of the system to optimize routing for the recommendations outputted by the system in relation to the producer but free of access to the producer specific data inputted into the system by the producer.
- the disclosed system may generate data (e.g., producing location, the amount to haul, the earliest arrival time, the latest departure time, the carrier, the truck, and the destination) for a carrier to complete a haul from a producing location to a destination in a manner that optimizes parameters for system users.
- data e.g., producing location, the amount to haul, the earliest arrival time, the latest departure time, the carrier, the truck, and the destination
- a method for use in facilitating transport of physical bulk assets between sites in a network includes receiving, at a processor, first input data regarding physical bulk assets of a network made up of a plurality of physical sites in a geographic area, the first input data including a current inventory of the physical bulk assets in the network, forecasted production of physical bulk assets at one or more of the plurality of physical sites in the network, a current capacity to store physical bulk assets at sites in the network, and a hauling capacity by carriers accessible to the network; generating by the processor at least one optimized load data package that is configured to maintain flow assurance of physical bulk assets in the network, the generating the at least one optimized load package including executing at least a first optimization model using the first input data; generating by the processor at least one optimized carrier assignment data package that is configured to limit a cost to deliver physical bulk assets between sites in the network using the carriers, the generating the at least one optimized carrier assignment data package including executing at least a second optimization model using the at least one optimized load
- the at least one optimized load data package may include at least one first volume of at least one physical bulk asset in the network to be transported from at least one source site in the network to at least one destination site in the network by at least one first deadline.
- the optimized load data package may include the source or producing site, the carrier and truck(s), the volume and type of bulk asset to haul, the destination site, the latest departure time from the source site, and/or the earliest arrival time at the destination site.
- the method may also include receiving at least one requested load data package, and the method may further include determining, by the processor, whether at least one conflict or inconsistency exists between the at least one optimized load data package and the at least one requested load data package; and generating, by the processor, at least one indication regarding the determination for presentation on the display.
- the requested load data package may include one or more producer-specific constraints (e.g., in relation to deadlines, minimum or maximum capacities, etc.) and at least one inconsistency may be identified when one or more portions of the optimized load data package fail to comply with the one or more constraints.
- a user may choose to override the inconsistency such that the optimized assignment data package is generated on the basis of the optimized load data package with the inconsistencies.
- a user may be prompted to submit revised first input data whereupon the revised optimized load data package may be generated which may again by analyzed in view of the requested load data package to check for inconsistencies.
- the method may further include generating at least one optimized physical bulk asset routing data package that is configured to limit a cost to deliver the physical bulk assets between sites in the network using the carriers, the generating the at least one optimized physical bulk asset routing data package including executing at least a third optimization model using the at least one optimized load data package and the at least one optimized carrier assignment data package.
- the at least one optimized physical bulk asset routing data package may specify at least one specific route (e.g., directions that include roads, highways, etc.) to be traveled by the at least one carrier to transport the at least one first volume of the at least one liquid asset in the network from the at least one source site in the network to the at least one destination site in the network by the at least one first deadline.
- FIG. 1 is a schematic diagram illustrating a number of networks made up of physical bulk item storage sites in a geographic area.
- FIG. 2 is a block diagram of a server that is configured to communicate with client devices and generate optimized data usable by various types of users to minimize costs and maximize production in the hauling of produced physical bulk assets (e.g., liquids, sand, etc.) to various destinations in a network.
- produced physical bulk assets e.g., liquids, sand, etc.
- FIG. 3 is a schematic flow diagram illustrating the operation of various optimization processes executed by the optimization engine of FIG. 2 .
- FIG. 4 is a flow diagram of a method for use in facilitating transport of physical bulk assets between sites in a network.
- FIGS. 5 a - 5 j present various screenshots of a user interface that provides access to the optimization engine of FIG. 2 .
- FIG. 1 presents a schematic diagram illustrating a number of networks 104 made up of physical bulk item storage sites 108 in a geographic area.
- Each site 108 may generally be configured to store one or more capacities 112 of one or more types 116 of physical bulk assets such as petroleum products, water, sand, gravel, and/or the like.
- each site 108 may be disposed at a particular location 120 (e.g., GPS coordinates), be managed by a particular entity 124 , be identified by one or more IDs 128 , and have a role 132 in the nature of a bulk asset source and/or a bulk asset destination.
- each network 104 may include one of more sites 108 , where one or more of the sites 108 may in some arrangements be present in two or more networks 104 .
- FIG. 2 presents a block diagram of a server 200 that is configured to communicate with client devices 204 over one or more networks (e.g., Internet, WANs, LANs, not shown) and generate optimized data usable by various types of users to minimize costs and maximize production in the hauling of produced physical bulk assets (e.g., liquids, sand, etc.) to various destinations in a network.
- networks e.g., Internet, WANs, LANs, not shown
- the server 200 includes at least one memory device 208 (e.g., RAM or other volatile memory device(s)), at least one processor 212 (e.g., processing core(s)) for executing computer readable instructions from the memory device 208 , at least one storage module 216 (e.g., hard disk, flash, or other non-volatile memory), and/or various other peripheral devices or components (e.g., display, input devices, etc.), all of which may be interconnected by one or more busses (not shown).
- memory device 208 e.g., RAM or other volatile memory device(s)
- processor 212 e.g., processing core(s)
- storage module 216 e.g., hard disk, flash, or other non-volatile memory
- peripheral devices or components e.g., display, input devices, etc.
- the storage module 216 may store input information (e.g., bulk asset inventories, production forecasts, capacity information, etc., discussed in more detail below) received from client devices 204 (or other sources) as well as the results of any analyses performed on the information by the server 200 according to any appropriate structured arrangement that allows for efficient input and retrieval of data (e.g., RDBMS). While the server 200 is illustrated as a single device (e.g., server, laptop, desktop, mobile device, and/or other computing device), one or more functionalities or processes of the server 200 may be allocated among a number of machines or devices which may or may not be embodied in a single housing. For instance, a first set of one or more functionalities could be handled by a first machine or group of machines or processes while a second set of one or more functionalities could be handled or performed by a second machine or group of machines or processes.
- input information e.g., bulk asset inventories, production forecasts, capacity information, etc., discussed in more detail below
- client devices 204 or other sources
- the memory 208 may be configured to store (e.g., as loaded from storage module 216 ) an optimization engine 220 (e.g., application middleware in the form of one or more sets of computer-readable instructions executable by the processor 212 ) that is configured to employ certain optimization methods in a unique manner to implement a decision-making framework for making the optimal bulk asset dispatch decisions for producers, carriers, destinations, and the like, all while decreasing the manual effort required to complete each dispatch.
- an optimization engine 220 e.g., application middleware in the form of one or more sets of computer-readable instructions executable by the processor 212
- the memory 208 may be configured to store (e.g., as loaded from storage module 216 ) an optimization engine 220 (e.g., application middleware in the form of one or more sets of computer-readable instructions executable by the processor 212 ) that is configured to employ certain optimization methods in a unique manner to implement a decision-making framework for making the optimal bulk asset dispatch decisions for producers, carriers, destinations, and the like, all while decreasing the
- a producer interested in only particular functionalities of the optimization engine 220 can supply producer specific input to the system (which may include one or more producer-specific restraints) and receive output recommendations by the system in relation to trucks, loads, destinations, and the like.
- a particular hauler contracted with the producer may utilize a different mechanism or functionality of the system to optimize routing for the recommendations outputted by the system in relation to the producer but free of access to the producer specific data inputted into the system by the producer.
- the disclosed system may generate data (e.g., producing location, the amount to haul, the earliest arrival time, the latest departure time, the carrier, the truck, and the destination) for a carrier to complete a haul from a producing location to a destination in a manner that optimizes parameters for system users.
- data e.g., producing location, the amount to haul, the earliest arrival time, the latest departure time, the carrier, the truck, and the destination
- the server 200 may include a web server 224 that handles system and user interaction and send requests to the optimization engine 220 .
- the optimization engine 220 is generally configured to read and write data to the RDBMS of storage module 216 and which may include the updating of transactional data, scheduling of jobs, and administration of the applications.
- a job agent may read and write data specific to the execution of requested jobs (e.g., where job status may be the primary update) while individual worker nodes may write output to the RDBMS directly.
- the server 200 may run within its own private network with the web server 224 being the only public-facing interface.
- the optimization engine may generally include an inventory optimizer 228 , a carrier (hauler) optimizer 232 , and a routing optimizer 236 .
- the inventory optimizer 228 generally represents the mechanism for making decisions specific to a producer of a network (e.g., of one of the networks 104 in FIG. 1 ).
- each producer may be interested in flow assurance for each producing site (e.g., each site 108 in FIG. 1 whose role is a “source”) and/or substantial full utilization of their hauling capacity (e.g., whether contracted or owned hauling capacity).
- An output of the inventory optimizer 228 may be an optimized load data package that generally defines bulk asset loads that are to be transported from one or more source sites to one or more destination sites in the network according to one or more deadlines in order to maintain such flow assurance and realize substantial full utilization of the producer's hauling capacity.
- the carrier optimizer 232 generally represents the mechanism for making decisions specific to a producer who can realize different results by using different carriers or sending produced bulk assets to different markets (e.g., different destinations).
- An output of the carrier optimizer 232 may be an optimized carrier assignment data package that matches specific carriers and trucks with loads to be delivered from one or more particular source sites to one or more particular destination sites to minimize or at least reduce the cost of delivery of the bulk assets.
- the routing optimizer 236 generally represents the mechanism for recommending decisions for individual truck shifts and generates an optimized routing data package that minimizes or at least reduces time, mileage, and/or other costs incurred as part of delivering requested loads to destinations. For instance, a carrier can receive load requests from producers and then utilize the routing optimizer 236 to design truck shifts to meet the requirements of the load requests while minimizing or at least reducing their own costs.
- FIG. 3 is a schematic flow diagram illustrating the operation of various optimization processes executed by the optimization engine 220 of FIG. 2 . More specifically, FIG. 3 illustrates how the inventory optimizer 228 , the carrier optimizer 232 , and the routing optimizer 236 can be combined to achieve a single, flexible system that is capable of serving multiple different types of customers.
- the system is capable of substantially seamlessly passing optimized data packages between optimizers in a manner that limits parties from knowing all of the original data inputted by the other party.
- the diagram illustrates how users can take advantage of one or all of the optimizers by supplying differing input data.
- FIG. 4 presents a flow diagram of a method 400 for use in facilitating transport of physical bulk assets between sites in a network.
- FIGS. 5 a - 5 j present screenshots of a user interface usable by customers (e.g., via client devices 204 ) to utilize the optimization engine 220 .
- the server 200 may receive (e.g., from a customer such as a producer via a client device 204 ) first input data 300 that includes production forecasts 304 , inventories 308 , and capacity data 312 for physical bulk assets in a network.
- the first input data 300 may be supplied by or on behalf of a producer of a particular type of physical bulk asset (e.g., oil, water, sand, etc.) in a network of source and destination sites and carriers.
- the production forecast data 304 represents a projected or forecasted production (or acquisition) of the particular type of bulk asset at all sites in the network under consideration for a particular forward-looking period of time.
- the production forecasts may be quantified in any appropriate manner such as by barrels, cubic units (cubic meters), other volumetric measures, and/or the like.
- the inventory data 308 broadly represents a current volume or quantity of the particular type of bulk asset at all sites in the network under consideration and may be in the nature of granular data with respect to each particular site.
- the inventory data 308 may also include historical production rates with respect to each site.
- the capacity and dedication data 312 broadly represents minimum and maximum capacities of available hauling resources (e.g., available carriers) as well as minimum and maximum capacities of delivery points (sites).
- the first input data 300 may be supplied to the server 200 in any appropriate manner, whereby the server 200 may store the first input data 300 in a RDBS of storage module 216 in any appropriate manner.
- some or all of the first input data 300 may be retrieved from one or more sources via web application programming interfaces (APIs) or the like.
- APIs web application programming interfaces
- customers may manually input data to the server 200 .
- FIG. 5 a - 5 j present screenshots of a user interface that a customer may utilize to interact with the server 200 . As shown in FIG. 5 a , the customer may initially establish a plurality of sites (e.g., via clicking the “Sites” icon on the left side of the interface and then clicking “ADD SITE”).
- the server 200 may prompt the customer to input various identifying information for the particular site such as name, corporation, division, role, time zone, location (e.g., GPS coordinates such as latitude/longitude), IDs, and the like. Similarly, the customer may initially establish a plurality of carriers (e.g., via clicking the “Carriers” icon on the left side of the interface) and then clicking “ADD CARRIER” See FIG. 5 b . The server 200 may prompt the customer to input various identifying information for the particular carrier such as name, IDs, and the like.
- the customer may also create one or more networks whereby the server 200 may prompt the customer to input various identifying information for the particular network such as name, product type, time zone, sites, carriers, and the like.
- FIG. 5 d illustrates a list of all of the sites associated with the “Plankton Reuse Company” network, where the sites in FIG. 5 d include all or a subset of the sites entered in FIG. 5 a .
- FIG. 5 e illustrates a list of all of the carriers (only one shown in this example) associated with this network, where the carriers in FIG. 5 d include all or a subset of the carriers entered in FIG. 5 b.
- the customer may click on the “inventory input” button (e.g., see left side of FIG. 5 a ) whereupon the user can import (e.g., via csv files, etc.) the input information.
- imported input may include the IDs or other identifying information previously created in the system such that upon import, the various inputted information (e.g., production forecasts 304 , inventories 308 , and capacity data 312 ) may be automatically associated with the appropriate respective site, carrier, or the like.
- a user may be able to view the entered inventory information associated with the particular site as shown in FIG. 5 g .
- a user can click the “add inventory point” button in FIG. 5 g to bring up the screenshot in FIG. 5 h to allow the user to manually enter inventory information associated with the site.
- the method 400 may then include generating 408 (e.g., via the inventory optimizer 228 ) an optimized load data package 316 by executing a first optimization model 318 using the first input data 300 .
- the first optimization model may be any appropriate standard optimization model such as a stochastic inventory model or the like.
- the optimized load data package 316 represents an optimized load and sets forth one or more load parameters that, when implemented by the network, maintain flow assurance in the network and allow the network to realize substantial full utilization of the hauling capacity.
- the load package 316 may include a plurality of site IDs 320 that are sources of the particular bulk asset or destinations of the particular bulk asset in the network.
- each site ID 320 may correspond to one of the sites associated with the particular network (e.g., from FIG. 5 d ) and thus automatically be linked with role (e.g., source or destination), capacities, etc.
- the optimized load data package 316 may also include other parameters such as a volume parameter 324 (e.g., particular volumes of the bulk assets at particular sites or to be moved to particular sites), deadlines 328 (e.g., dates by which bulk assets need to be moved from one or more source sites to one or more destination sites), a load ID 332 (e.g., an ID that uniquely identifies the load in the server 200 ), and/or the like.
- a customer may be able to select one or more of the various optimizers to be run by the optimization engine 220 such as via accessing the “network list” of the user interface (see FIG. 5 c ) and selecting “load” to trigger the inventory optimizer 228 , “trans” to trigger the carrier optimizer 232 , and/or “schedule” to trigger the routing optimizer 236 .
- the customer may be able to create one or more “plans” that are each made up of one or more periods of time for which to run the selected optimizer(s). As shown in FIG. 5 f , for instance, a customer has established two different plans for the “DJ Disposals” network, one running from Aug. 1, 2018 to Aug.
- buttons may be included (e.g., see top of page) to allow the user to execute those optimizers selected for the corresponding network in the screenshot of FIG. 5 c.
- the method 400 may include querying 412 whether the optimized load package 316 conflicts with any constraints 336 supplied by the user and/or acquired by the server.
- the constraints 336 may include particular deadlines (e.g., dates, times) to be met, minimum carrier filling capacity to be utilized, bulk asset volumes, and/or the like. Additionally or alternatively, the constraints 336 may include any appropriate industry standards, state/federal regulations, and/or the like to be met. Still further, a constraint 336 may be a production forecast 304 greater than site and/or carrier capacity during the plan period.
- the various constraints 336 may be manually supplied by the user (e.g., via the “Import” button in FIG. 5 a ) and/or may be automatically obtained by the server 200 in any appropriate manner (e.g., via APIs, web scraping, etc.).
- the method may proceed to generate and display 420 an indication regarding the conflict.
- the middle of the page includes several types of risks that may be encountered if an optimized load data package conflicts with one or more restraints 336 . For instance, at site “Conrad 5104,” there is a risk of a projected inventory being greater than an inventory capacity at the site. Various other types of risks are envisioned and encompassed herein (e.g., “inventory overflow risks,” etc.).
- the method 400 may then proceed to receive revised input data from the customer/user and then generate 424 a revised optimized load data package.
- the user may choose to supply revised input data to the server 200 and then rerun the inventory optimizer 228 .
- the user may choose to add actual physical capacity (e.g., tanks, barrels, etc.) to the Conrad 5104 site, update the corresponding capacity information for the Conrad 5104 site (e.g., via the screenshot of FIG. 5 g ), and then rerun the inventory optimizer 228 (e.g., via clicking the load “rerun” or “execute” button in FIG. 5 j .
- a user may be able to override one or more of the risks by way of clicking an “override” button or the like (not shown) or by not rerunning the inventory optimizer 228 .
- the method 400 may return to the query 412 .
- the method 400 may proceed to generate 416 (e.g., via the carrier optimizer 232 ) an optimized carrier assignment data package 232 by executing a second optimization model 340 (different than the first optimization model 318 ) using the optimized load data package 316 .
- the optimized load data package 318 may be substantially seamlessly transferred by the optimization engine 220 as input directly into the carrier optimizer 232 for generation of the optimized carrier assignment data package 232 .
- the second optimization model 340 may be any appropriate standard optimization model such as a generalized transportation model or the like.
- the carrier optimizer 232 may also receive at least some carrier-specific input 350 for use in generating the optimized carrier assignment data package 344 .
- some of the carrier input 350 may be granular capacity/dedication data 352 as well as costs/fee structures that are specific to each particular carrier associated with the network (e.g., each carrier in the list of FIG. 5 e , only one carrier being illustrated in the example of FIG. 5 e ).
- a first carrier could have a capacity of 75 loads of 200 barrels/load and a fee structure of $90/hour
- a second carrier could have a capacity of 25 loads of 200 barrels/load and a fee structure of $100/hour
- a third carrier could have a capacity of 50 loads of 150 barrels/load and a fee structure of $60/hour.
- the server 200 may receive fee structure input at $/hour, $/barrel, and/or $/load.
- the input 300 , 350 may be provided by the user and/or obtained by the server 200 before running of either of the inventory or carrier optimizers 228 , 232 , whereupon the inventory optimizer 228 executes the first optimization model 318 using the input it needs while the carrier optimizer 232 executes the second optimization model 340 using the input it needs as discussed above.
- the user in some embodiments need only supply (or the server 200 need only obtain) the granular carrier-specific capacity/dedication data 352 and then the server 200 may be configured to appropriately aggregate such data 352 to obtain the aggregate capacity/dedication data 312 for use by the inventory optimizer 228 .
- a user may be able to submit one or more “load requests” 356 for use by the carrier optimizer 232 in generating optimized carrier assignment load packages 344 , where each load request 356 includes some or all of the parameters of an optimized load package 316 .
- a user may choose to not execute the inventory optimizer 228 and only execute the carrier optimizer 232 which needs some or all of the information that would have been present in a generated optimized load package such as particular site IDs 320 , deadlines, 328 , etc. In this regard, the user may manually supply such information as part of a load request 356 .
- the optimized load data package 316 is incomplete (e.g., missing one or more parameters)
- such parameters may be supplied as part of a load request 356 .
- a user may supply a load package 356 even if the user also chooses for the inventory optimizer 228 to generate an optimized load data package 316 whereupon the carrier optimizer 232 may serve to assess the parameters in the optimized load data package 316 with corresponding parameters in the load request 350 to identify if any conflicts exist (e.g., as part of the query 428 discussed below).
- the parameters of such load request 356 may essentially serve as constraints 358 (e.g., although a user may also submit additional constraints 358 ).
- the method 400 may query whether there are conflicts with any restraints 358 (e.g., which may be encompassed in a load request 350 as discussed above). In response to an affirmative answer to the query 428 , the method 400 may proceed to generate and display 436 an indication regarding the conflict and then receive revised input data and generate 440 a revised optimized carrier assignment data package. For instance, the middle of FIG. 5 j presents various types of conflict risks that may occur if the optimized carrier assignment data package was implemented. In some embodiments, a user may again have the option to manually override or otherwise ignore such risks.
- each optimized carrier assignment data package 344 may include one or more parameters or pieces of data such as one or more load IDs 332 , one or more carrier IDs 360 , and one or more assignments 362 between load IDs 332 and carrier IDs 360 (e.g., where each assignment generally stipulates one or more particular loads for which one or more particular carriers are responsible).
- the method 400 may proceed to query 432 whether specific routing is requested for the optimized loads 316 and optimized carrier assignments 344 .
- the method 400 may proceed to present 444 the data packages on the display. It is to be understood that the operation 444 need not always necessarily occur only after all of the above discussed steps. In other words, one or more of the data packages may be displayed (e.g., in the screenshot of FIG. 5 j ) as data is received and the optimizers 228 , 232 are run. For instance, while FIG. 5 j presents conflict risks that may occur, FIG.
- the server 200 may proceed to rerun the various optimizers whereupon the displayed optimized carrier assignment data package may automatically update.
- the user may then choose to actually implement the recommendations in the optimized carrier assignment data package 344 in any appropriate manner such as via exporting the generated data to another data system, trigging implementation directly from the user interface, and/or the like.
- the method 400 may proceed to generate 434 (e.g., via the routing optimizer 236 ) an optimized routing data package 363 by executing a third optimization model 364 using the optimized load and carrier assignment data packages 316 , 344 .
- the third optimization model 364 may be based off of decision-making platforms supplied by Google® or the like.
- Each optimized routing data package 363 may include various pieces of data such as site IDs 320 , routes/directions 368 , schedules 370 , and/or the like.
- the optimized carrier assignment data package 344 may be substantially seamlessly fed directly into the routing optimizer 236 for use in generating optimized routing data packages 363 .
- the routing optimizer 236 may also make use of other user or server-supplied input 372 such as, for example, one or more constraints 374 (e.g., highways on which the user does not want carriers to travel).
- the optimization engine 200 is able to accommodate different users with different interests in the bulk asset dispatch process. For instance, producers that have substantially full control over the carriers used to transport their bulk assets may make use of all of the inventory optimizer 228 , the carrier optimizer 232 , and the routing optimizer 236 . In other situations, however, producers may hire carriers to transport bulk assets but have little to no control over the specific routing used by the carriers to transport the bulk assets between sites in the producers' networks. That is, a carrier in charge of specific truck shifts may receive load requests from producers (or site operations) regarding particular volumes of bulk assets to be moved between particular sites and want to utilize the routing optimizer 236 of the optimization engine 220 to optimize specific routes between the sites to minimize their own handling expenditures.
- the routing optimizer 236 may receive manually input load requests 356 , capacity/dedication data 352 , and costs/fee structures 354 and generate optimized routing data packages 363 for use by the carriers.
- the carrier may receive data files that include such aforementioned data and then import such data into the disclosed system for use by the routing optimizer 236 .
- a carrier may be able to coordinate with a producer so that optimized carrier assignment data packages 344 generated for the producer are automatically received at the routing optimizer 236 for use in generating optimized routing data packages 363 for the carrier but free of granting access to the input data 300 , 350 used by the server 200 to generate the optimized load and carrier assignment data packages 316 , 344 .
- the carrier may not have access to and/or be unaware of constraints 336 , 358 , production forecasts 304 , and/or the like.
- the carrier or other user may also be able to input constraints 374 to be used by the routing optimizer 236 in determining 446 whether any conflicts exist, generating and displaying 448 corresponding indications, and then receiving revised input and generating 452 revised optimized routing data packages 363 that comply with such restraints 374 .
- the carrier or other user may also be able to input costs/fee structures 354 and the like (e.g., which can also serve as constraints 374 ).
- loads assigned to certain carriers can be shared with the carriers so that users from the appropriate carrier organizations can access the system and view the loads assigned to them from other organizations with the data sufficient to allow them to run the routing optimizer 236 .
- Data pertaining to sites which have no loads shared with a carrier organization are not available to the carrier organization through the “Shared Run Requests” functionality. See FIGS. 5 i - 5 j .
- a user can access the shared run requests through file export or API to feed their fleet management systems or other processes.
- the optimization engine 220 can be used in various manners to achieve various bulk asset dispatch optimizations for various entities with differing interests such as production operators (producers) commonly known as oil and gas exploration and production companies; oil or water haulers (carriers); water disposal/recycle operators or oil markets (destination); and/or the like.
- production operators producers
- oil or water haulers carriers
- water disposal/recycle operators or oil markets destination
- a user may need to manage inventory but does not need to make decisions on who hauls the fluids (e.g., such as when oil is purchased at the wellhead by a single purchaser and the purchaser makes the hauler and destination decision).
- the user could only execute the inventory optimizer 228 and input their minimum and maximum volumes and/or loads per day (e.g., data 300 in FIG. 3 ) dictated by the purchaser.
- a user may need to manage the inventory and also need to decide who hauls the fluids and/or where the deliveries are to be made.
- the user could enter the capacities for haulers and/or delivery points as well as fee structures for hauling and disposing/selling the fluids and then execute both of the inventory and carrier optimizers 228 , 232 .
- a user may not need to manage the inventory at the source locations but needs to decide which haulers/carriers are assigned specific loads and/or where the deliveries are to be made.
- the user may utilize only the carrier optimizer 232 by way of manually providing load requests 356 as well as capacity/dedication data 352 and costs/fee structures 354 that are specific to individual carriers.
- the load requests 356 may in some cases be optimized in other manners; however, in this case, optimized load data packages 316 would not be generated and automatically transferred from the inventory optimizer 228 to the carrier optimizer 232 .
- the various data packages disclosed herein may be output in any appropriate manner. As discussed herein, the data packages may be output in the nature of graphics, charts, maps, and/or the like on a user interface. Additionally or alternatively, the data packages may be output to other processes or locations such as to an electronic ticketing system, a data warehouses, analytical tools, and/or the like.
- the disclosed utilities reflect an improvement in physical bulk asset dispatching between one or more source sites and one or more destination sites in a network as they provide a single solution that can be used in different manners by different entities in the dispatch process (e.g., producers, carriers, destination operators, etc.) to realize various efficiencies specific to the entity.
- the disclosed optimization engine may be configured to generate specific recommended input changes to be made to avoid detected conflicts between data packages and constraints. It is to also be understood that the method 400 may in some arrangements be performed in other manners than as specifically shown in FIG. 4 . Furthermore, one or more various combinations of the arrangements and embodiments disclosed herein are also envisioned.
- the functionalities of the inventory optimizer 228 and carrier optimizer 232 could be combined into a single optimizer, whereby the output of such optimizer may be an optimized package including the data of the optimized load package 316 and optimized assignment package 344 of FIG. 3 .
- the single optimizer may make use of the first optimization model 318 , the second optimization model 340 , and/or another optimization model.
- Inputs to the disclosed system may be received in any appropriate manner. As discussed herein, inputs may be received through a user interface such as that shown in the figures. Additionally or alternatively, inputs may be received via voice interaction or the like.
- Embodiments disclosed herein can be implemented as one or more computer program products, i.e., one or more modules of computer program instructions encoded on a computer-readable medium for execution by, or to control the operation of, data processing apparatus.
- the optimization engine 220 responsible for the various functionalities disclosed herein may be provided in such computer-readable medium of the server 200 and executed by the processor(s) 212 as appropriate.
- the computer-readable medium can be a machine-readable storage device, a machine-readable storage substrate, a non-volatile memory device, a composition of matter affecting a machine-readable propagated signal, or a combination of one or more of them.
- processor(s) may encompass one or more apparatuses, devices, and machines for processing data, including, by way of example, a programmable processor, a computer or multiple processor or computers.
- the server 200 may include code that creates an execution environment for the computer program in question, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them.
- a computer program (also known as a program, software, software application, script, or code) used to provide the functionality described herein may be written in any form of programming language, including compiled or interpreted languages, and may be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
- a computer program does not necessarily correspond to a file in a file system.
- a program can be stored in a portion of a file that holds other programs or data (e.g., one or more scripts stored in a markup language document), in a single file dedicated to the program in question, or in multiple coordinated files (e.g., files that store one or more modules, sub-programs, or portions of code).
- a computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by an information flow network.
- the block diagrams, processes, protocols and logic flows described in this specification can be performed by one or more programmable processors executing one or more computer programs to perform functions by operating on input data and generating output.
- the processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
- processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer.
- a processor will receive instructions and data from a read-only memory or a random access memory or both.
- the elements of a computer are a processor for performing instructions and one or more memory devices for storing instructions and data.
- the techniques described herein may be implemented by a computer system configured to provide the functionality described.
- the server 200 may comprise one or more of various types of devices, including, but not limited to a personal computer system, desktop computer, laptop, notebook, netbook computer, mainframe computer system, handheld computer, workstation, network computer, application server, storage device, a consumer electronics device, a peripheral device such as a switch, modem, router, or, in general, any type of computing or electronic device.
- a personal computer system desktop computer, laptop, notebook, netbook computer, mainframe computer system, handheld computer, workstation, network computer, application server, storage device, a consumer electronics device, a peripheral device such as a switch, modem, router, or, in general, any type of computing or electronic device.
Landscapes
- Business, Economics & Management (AREA)
- Engineering & Computer Science (AREA)
- Economics (AREA)
- Human Resources & Organizations (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Strategic Management (AREA)
- Quality & Reliability (AREA)
- Operations Research (AREA)
- Marketing (AREA)
- Tourism & Hospitality (AREA)
- Entrepreneurship & Innovation (AREA)
- General Business, Economics & Management (AREA)
- Development Economics (AREA)
- Theoretical Computer Science (AREA)
- Accounting & Taxation (AREA)
- Finance (AREA)
- Game Theory and Decision Science (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
Description
Claims (20)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/426,896 US11537981B2 (en) | 2018-06-04 | 2019-05-30 | Produced physical bulk asset hauling dispatch system |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201862680178P | 2018-06-04 | 2018-06-04 | |
US16/426,896 US11537981B2 (en) | 2018-06-04 | 2019-05-30 | Produced physical bulk asset hauling dispatch system |
Publications (2)
Publication Number | Publication Date |
---|---|
US20190370735A1 US20190370735A1 (en) | 2019-12-05 |
US11537981B2 true US11537981B2 (en) | 2022-12-27 |
Family
ID=68694001
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/426,896 Active 2041-05-22 US11537981B2 (en) | 2018-06-04 | 2019-05-30 | Produced physical bulk asset hauling dispatch system |
Country Status (3)
Country | Link |
---|---|
US (1) | US11537981B2 (en) |
CA (1) | CA3090806C (en) |
WO (1) | WO2019236373A1 (en) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113780839B (en) * | 2021-09-15 | 2023-08-22 | 湖南视比特机器人有限公司 | Evolutionary sorting job scheduling method and system based on deep reinforcement learning |
US11429801B1 (en) * | 2021-09-21 | 2022-08-30 | Pitt Ohio | System and method for carrier identification |
CN114862191B (en) * | 2022-05-07 | 2024-07-02 | 中国石油大学(北京) | Finished oil pipeline scheduling optimization method and system based on running stability |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060241986A1 (en) | 2005-04-22 | 2006-10-26 | Harper Charles N | Production optimizer for supply chain management |
US20070106680A1 (en) * | 2001-06-27 | 2007-05-10 | Mci, Llc. | Digital media asset management system and method for supporting multiple users |
US20090307063A1 (en) | 2001-07-20 | 2009-12-10 | International Business Machines Corporation | Network-based supply chain management method |
US20120191272A1 (en) * | 2011-01-24 | 2012-07-26 | Sky-Trax, Inc. | Inferential load tracking |
US20140234059A1 (en) * | 2013-02-21 | 2014-08-21 | Schlumberger Technology Corporation | Remote wellsite material tracking |
US20160217399A1 (en) | 2015-01-22 | 2016-07-28 | Elementum Scm (Cayman) Ltd. | Method and system for monitoring shipments in a supply and/or logistics chain |
US10783507B1 (en) * | 2019-07-03 | 2020-09-22 | Spellbound Development Group, Inc. | Consumables dispensing system and method |
US20210004754A1 (en) * | 2019-07-03 | 2021-01-07 | Spellbound Development Group, Inc. | Consumables dispensing system and method |
US20210192442A1 (en) * | 2019-12-19 | 2021-06-24 | Lob.com, Inc. | Method and system for physical asset tracking |
-
2019
- 2019-05-30 US US16/426,896 patent/US11537981B2/en active Active
- 2019-05-30 CA CA3090806A patent/CA3090806C/en active Active
- 2019-05-30 WO PCT/US2019/034634 patent/WO2019236373A1/en active Application Filing
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070106680A1 (en) * | 2001-06-27 | 2007-05-10 | Mci, Llc. | Digital media asset management system and method for supporting multiple users |
US20090307063A1 (en) | 2001-07-20 | 2009-12-10 | International Business Machines Corporation | Network-based supply chain management method |
US20060241986A1 (en) | 2005-04-22 | 2006-10-26 | Harper Charles N | Production optimizer for supply chain management |
US20120191272A1 (en) * | 2011-01-24 | 2012-07-26 | Sky-Trax, Inc. | Inferential load tracking |
US20140234059A1 (en) * | 2013-02-21 | 2014-08-21 | Schlumberger Technology Corporation | Remote wellsite material tracking |
US20160217399A1 (en) | 2015-01-22 | 2016-07-28 | Elementum Scm (Cayman) Ltd. | Method and system for monitoring shipments in a supply and/or logistics chain |
US10783507B1 (en) * | 2019-07-03 | 2020-09-22 | Spellbound Development Group, Inc. | Consumables dispensing system and method |
US20210004754A1 (en) * | 2019-07-03 | 2021-01-07 | Spellbound Development Group, Inc. | Consumables dispensing system and method |
US20210192442A1 (en) * | 2019-12-19 | 2021-06-24 | Lob.com, Inc. | Method and system for physical asset tracking |
Also Published As
Publication number | Publication date |
---|---|
WO2019236373A1 (en) | 2019-12-12 |
US20190370735A1 (en) | 2019-12-05 |
CA3090806C (en) | 2024-02-06 |
CA3090806A1 (en) | 2019-12-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR102468339B1 (en) | System and method for fulfilling e-commerce orders from a hierarchy of fulfilment centres | |
US20230088950A1 (en) | Method and system for intelligent load optimization for vehicles | |
US9767495B2 (en) | Different sales and planning product options | |
US8190465B2 (en) | Make-to-specification process and data model | |
US7904352B2 (en) | Method and system for managing material movement and inventory | |
US20100161366A1 (en) | Product requirement specification in production model | |
Dondo et al. | Operational planning of forward and reverse logistic activities on multi-echelon supply-chain networks | |
US11537981B2 (en) | Produced physical bulk asset hauling dispatch system | |
Nishi et al. | Column generation heuristics for ship routing and scheduling problems in crude oil transportation with split deliveries | |
US9811797B2 (en) | Transportation connection cache for dynamic network and route determination | |
Dong et al. | MIP model for inventory routing in industrial gases supply chain | |
KR20210008581A (en) | System for providing logistics transportation service for multi pick up and delivery with imporved navigation algorithm | |
Benlaajili et al. | Optimization of truck-shovel allocation problem in open-pit mines | |
Aksyonov et al. | A Method for Planning the Supply of Petroleum Products to Filling Stations Based on Multi-agent Resource Conversion Processes | |
US20140279321A1 (en) | Method and system of charge distribution in a transportation management component | |
Martínez-Vivar et al. | Contribution to the logistic evaluation system in the transportation process in Santo Domingo, Ecuador | |
Dondo et al. | A branch-and-price approach to manage cargo consolidation and distribution in supply chains | |
Mahmud | Towards Sustainable Food Logistics: An Open-Source Web Application for Optimizing Transportation Scheduling and Vehicle Routing | |
Gifford et al. | Dispatch optimization in bulk tanker transport operations | |
Deng | Shipment consolidation and distribution models in the international supply chain | |
JP7364280B1 (en) | Information processing device, information processing method, and program | |
Caballero-Morales et al. | Multi-product Inventory Supply and Distribution Model with Non-linear CO 2 Emission Model to Improve Economic and Environmental Aspects of Freight Transportation | |
Karakostas et al. | Modeling of sustainable integrated supply chains under the consideration of European Union regulations | |
Jauhari et al. | Designing an Integrated Logistics Information System | |
JP6806832B2 (en) | Collation method and system of gas loading amount and loading / unloading amount |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO SMALL (ORIGINAL EVENT CODE: SMAL); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: APPLICATION DISPATCHED FROM PREEXAM, NOT YET DOCKETED |
|
AS | Assignment |
Owner name: KSR UNLIMITED LLC, COLORADO Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:DYK, WESLEY ORIN;REEL/FRAME:049793/0798 Effective date: 20190617 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: PUBLICATIONS -- ISSUE FEE PAYMENT VERIFIED |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |