The disclosure relates generally to delivery systems and, more specifically, to load and route assignments in a goods delivery system.
At least some known systems and industries provide delivery services to their customers. For example, some companies in various industries provide the delivery of goods to their customers, such as the delivery of grocery items by grocers. In particular, the delivery of grocery items has increasingly become a method by which consumers obtain their grocery needs. To deliver goods, many of these companies employ delivery systems that include delivery vehicles. The delivery systems may include the scheduling and assignment of delivery orders to delivery vehicles. For example, a customer that purchases grocery items online may have the grocery items delivered to their home in a delivery vehicle.
These delivery vehicles, however, impose various costs on companies. For example, there are costs associated with purchasing or renting the vehicles, maintaining the vehicles, purchasing fuel for the vehicles, as well as employing drivers to drive the vehicles, just to name a few. In addition, delivery systems determine delivery routes and schedules for delivery trucks to deliver goods. The scheduling of the delivery of goods may also include the assignment of the goods to delivery vehicles for delivery. A delivery truck may receive a load assignment, for example, that includes the delivery of multiple orders. In addition, delivery systems may determine delivery routes that the delivery vehicles may travel to deliver ordered goods. As the number of delivery orders increase, the determination of load assignments and delivery routes, along with delivery costs, may increase as well. As such, there are opportunities to improve delivery systems and, in particular, to improve load and route assignments in a goods delivery system.
The features and advantages of the present disclosures will be more fully disclosed in, or rendered obvious by the following detailed descriptions of example embodiments. The detailed descriptions of the example embodiments are to be considered together with the accompanying drawings wherein like numbers refer to like parts and further wherein:
For simplicity and clarity of illustration, the drawing figures illustrate the general manner of construction, and descriptions and details of well-known features and techniques may be omitted to avoid unnecessarily obscuring the present disclosure. Additionally, elements in the drawing figures are not necessarily drawn to scale. For example, the dimensions of some of the elements in the figures may be exaggerated relative to other elements to help improve understanding of embodiments of the present disclosure. The same reference numerals in different figures denote the same elements.
The terms “first,” “second,” “third,” “fourth,” and the like in the description and in the claims, if any, are used for distinguishing between similar elements and not necessarily for describing a particular sequential or chronological order. It is to be understood that the terms so used are interchangeable under appropriate circumstances such that the embodiments described herein are, for example, capable of operation in sequences other than those illustrated or otherwise described herein. Furthermore, the terms “include,” and “have,” and any variations thereof, are intended to cover a non-exclusive inclusion, such that a process, method, system, article, device, or apparatus that comprises a list of elements is not necessarily limited to those elements, but may include other elements not expressly listed or inherent to such process, method, system, article, device, or apparatus.
The terms “left,” “right,” “front,” “back,” “top,” “bottom,” “over,” “under,” and the like in the description and in the claims, if any, are used for descriptive purposes and not necessarily for describing permanent relative positions. It is to be understood that the terms so used are interchangeable under appropriate circumstances such that the embodiments of the apparatus, methods, and/or articles of manufacture described herein are, for example, capable of operation in other orientations than those illustrated or otherwise described herein.
The terms “couple,” “coupled,” “couples,” “coupling,” and the like should be broadly understood and refer to connecting two or more elements mechanically and/or otherwise. Two or more electrical elements may be electrically coupled together, but not be mechanically or otherwise coupled together. Coupling may be for any length of time, e.g., permanent or semi-permanent or only for an instant. “Electrical coupling” and the like should be broadly understood and include electrical coupling of all types. The absence of the word “removably,” “removable,” and the like near the word “coupled,” and the like does not mean that the coupling, etc. in question is or is not removable.
As defined herein, two or more elements are “integral” if they are comprised of the same piece of material. As defined herein, two or more elements are “non-integral” if each is comprised of a different piece of material.
As defined herein, “approximately” can, in some embodiments, mean within plus or minus ten percent of the stated value. In other embodiments, “approximately” can mean within plus or minus five percent of the stated value. In further embodiments, “approximately” can mean within plus or minus three percent of the stated value. In yet other embodiments, “approximately” can mean within plus or minus one percent of the stated value.
As defined herein, “real-time” can, in some embodiments, be defined with respect to operations carried out as soon as practically possible upon occurrence of a triggering event. A triggering event can include receipt of data necessary to execute a task or to otherwise process information. Because of delays inherent in transmission and/or in computing speeds, the term “real time” encompasses operations that occur in “near” real time or somewhat delayed from a triggering event. In a number of embodiments, “real time” can mean real time less a time delay for processing (e.g., determining) and/or transmitting data. The particular time delay can vary depending on the type and/or amount of the data, the processing speeds of the hardware, the transmission capability of the communication hardware, the transmission distance, etc. However, in many embodiments, the time delay can be less than approximately one second, five seconds, ten seconds, thirty seconds, one minute, five minutes, ten minutes, or fifteen minutes.
The embodiments described herein may allow for the more efficient delivery of goods. For example, the embodiments described herein may allow for a reduction in the time required to deliver goods to a customer. Additionally, the embodiments described herein may allow for a reduction in the costs associated with delivering the goods to a customer. For example, the amount of miles driven by delivery trucks with little or no cargo (e.g., “empty miles”) may be reduced, thus reducing delivery vehicle costs, such as fuel costs. Other benefits would also be recognized by those skilled in the art.
In some examples, a system includes a computing device configured to obtain at least one live load assignment request for at least one live load. The computing device may determine at least one of a plurality of tour templates that match the live load assignment request based on at least one matching attribute. The computing device may then determine a fill rate for each of a tour execution associated with each of the plurality of tour templates that were matched. The computing device may then assign the live load to the tour execution with the highest fill rate. In some examples, the computing device is configured to assign the tour execution to a vehicle for execution of the live load.
In some examples, the computing device is also configured to store all of the matched tour templates in a first list, and store all of the tour executions associated with the matched tour templates in a second list. The computing device may also be configured to sort the tour executions in the second list based on respective fill rates for each of the tour executions.
In some examples, the computing device is configured to determine that the live load cannot be successfully assigned to the tour execution with the highest fill rate. The computing device may also be configured to determine that there are no further tour executions in the second list, obtain a next tour template from the first list, and generate a new tour execution based on the next tour template from the first list. The computing device may then assign the live load to the new tour execution.
In some examples, the computing device is configured to determine that a capacity of the new tour execution will not be exceeded if the live load is assigned to the new tour execution. In some examples, the computing device is configured to determine that the new tour execution is currently active. For example, the computing device may be configured to determine that the new tour execution has not expired, or will become effective at a later time.
In some examples, the computing device is configured to determine that the live load cannot be successfully assigned to the tour execution with the highest fill rate, and obtain a next tour execution in the second list with the remaining highest fill rate. The computing device may also be configured to assign the live load to the obtained tour execution.
In some examples, a method by a computing device includes obtaining live load assignment request for live load. The method further includes determining at least one of a plurality of tour templates that match the at least one live load assignment request based on at least one matching attribute, and determining a fill rate for each of a tour execution associated with each of the plurality of tour templates that were matched. The method may also include assigning the at least one live load to the tour execution with the highest fill rate.
In some examples, a non-transitory, computer-readable storage medium comprising executable instructions that, when executed by one or more processors, cause the one or more processors to: obtain at least one live load assignment request for at least one live load; determine at least one of a plurality of tour templates that match the at least one live load assignment request based on at least one matching attribute; determine a fill rate for each of a tour execution associated with each of the plurality of tour templates that were matched; and assign the at least one live load to the tour execution with the highest fill rate.
Various embodiments can include a system including one or more processors and one or more non-transitory computer-readable media storing computing instructions configured to run on the one more processors and perform certain acts. The acts can include extracting location information of nodes from origin data and destination data of historical load data for historical loads. The location information for each of the nodes can include a zip code of the node, a latitude of the node, and a longitude of the node. The acts also can include performing a first-level clustering of the nodes based on zip codes of the nodes to generate first-level clusters. The acts additionally can include setting a cluster diameter parameter. The acts further can include determining a cluster number for a second-level clustering based on the cluster diameter parameter. The acts additionally can include performing the second-level clustering of the first-level clusters in the first-level clustering based on the cluster number to generate second-level clusters. The acts further can include assigning a region cluster identifier to each of the second-level clusters and each of the nodes within each of the first-level clusters that are within each of the second-level clusters. The acts additionally can include matching at least one of a plurality of tour templates with at least one live load assignment request based at least in part on the region cluster identifiers associated with the nodes.
A number of embodiments can include a method being implemented via execution of computing instructions configured to run at one or more processors and stored at one or more non-transitory computer-readable media. The method can include extracting location information of nodes from origin data and destination data of historical load data for historical loads. The location information for each of the nodes can include a zip code of the node, a latitude of the node, and a longitude of the node. The method also can include performing a first-level clustering of the nodes based on zip codes of the nodes to generate first-level clusters. The method additionally can include setting a cluster diameter parameter. The method further can include determining a cluster number for a second-level clustering based on the cluster diameter parameter. The method additionally can include performing the second-level clustering of the first-level clusters in the first-level clustering based on the cluster number to generate second-level clusters. The method further can include assigning a region cluster identifier to each of the second-level clusters and each of the nodes within each of the first-level clusters that are within each of the second-level clusters. The method additionally can include matching at least one of a plurality of tour templates with at least one live load assignment request based at least in part on the region cluster identifiers associated with the nodes.
Turning to the drawings,
Load and route assignment computing device 102, web hosting device 104, and multiple delivery computing devices 110, 112, 114 can each be any suitable computing device that includes any hardware or hardware and software combination for processing and handling information. In addition, each may transmit data to, and receive data from, communication network 118. For example, each of these devices can be a computer, a workstation, a laptop, a mobile device such as a cellular phone, a cloud-based server, or any other suitable device. Each can include one or more processors, one or more field-programmable gate arrays (FPGAs), one or more application-specific integrated circuits (ASICs), one or more state machines, digital circuitry, or any other suitable circuitry.
Although
Workstation(s) 106 are operably coupled to communication network 118 via router (or switch) 108. For example, workstation(s) 106 can communicate with load and route assignment computing device 102 over communication network 118. The workstation(s) 106 can allow for the configuration and/or programming of load and route assignment computing device 102, such as the controlling and/or programming of one or more processors of load and route assignment computing device 102 (described further below in
Load and route assignment computing device 102 is operable to communicate with database 116 over communication network 118. For example, load and route assignment computing device 102 can store data to, and read data from, database 116. Database 116 can be a remote storage device, such as a cloud-based server, a memory device on another application server, a networked computer, or any other suitable remote storage. Although shown remote to load and route assignment computing device 102, in some examples database 116 can be a local storage device, such as a hard drive, a non-volatile memory, or a USB stick.
Communication network 118 can be a WiFi® network, a cellular network such as a 3GPP® network, a Bluetooth® network, a satellite network, or any other suitable network. Communication network 118 can provide access to, for example, the Internet.
Load and route assignment computing device 102 can also communicate with first delivery computing device 110, second delivery computing device 112, and third delivery computing device 114 over communication network 118. For example, load and route assignment computing device 102 can receive data (e.g., messages) from, and transmit data to, first delivery computing device 110, second delivery computing device 112, and third delivery computing device 114.
Load and route assignment system 100 may allow for the scheduling and assignment of loads to vehicles based on historical load data. A load may be goods a vehicle may be delivering. For example, a vehicle may need to deliver a load to a supercenter, or a distribution center from a warehouse. As another example, a vehicle may need to pick up goods from a location, such as a supercenter, for delivery to a customer's home. The load consists of the goods on the vehicle. The load may consist of one or more orders, for example. An inbound load may consist of a load being delivered to a supercenter, a distribution center, or a grocery store, for example. An outbound load may be a load being delivered from the supercenter, distribution center, or grocery store to a customer's home, for example.
Database 116 may store historical inbound load data and historical outbound load data related to previous inbound and outbound loads. The historical inbound load data and historical outbound load data may include attribute data related to previous loads, such as origin and destination data, as discussed further below. Load and route assignment computing device 102 may aggregate the historical inbound and outbound load data from the database, and determine an optimal path for a vehicle to travel to execute future load requests based on the aggregated historical data. The optimal path, along with load attribute data, may be stored in database 116 as a tour template for future load request executions. Load and route assignment computing device 102 may use the tour templates to determine future load assignments to vehicles. Load and route assignment computing device 102 may also obtain live (e.g., real-time) load assignment requests, and match them to one or more of a plurality of tour templates. Load and route assignment computing device 102 may assign the matched live loads to a vehicle for execution in accordance with the corresponding load and tour template, as described further below. For example, live loads may be assigned to a vehicle in real-time.
Processors 201 can include one or more distinct processors, each having one or more cores. Each of the distinct processors can have the same or different structure. Processors 201 can include one or more central processing units (CPUs), one or more graphics processing units (GPUs), application specific integrated circuits (ASICs), digital signal processors (DSPs), and the like.
Processors 201 can be configured to perform a certain function or operation by executing code, stored on instruction memory 207, embodying the function or operation. For example, processors 201 can be configured to perform one or more of any function, method, or operation disclosed herein.
Instruction memory 207 can store instructions that can be accessed (e.g., read) and executed by processors 201. For example, instruction memory 207 can be a non-transitory, computer-readable storage medium such as a read-only memory (ROM), an electrically erasable programmable read-only memory (EEPROM), flash memory, a removable disk, CD-ROM, any non-volatile memory, or any other suitable memory.
Processors 201 can store data to, and read data from, working memory 202. For example, processors 201 can store a working set of instructions to working memory 202, such as instructions loaded from instruction memory 207. Processors 201 can also use working memory 202 to store dynamic data created during the operation of load and route assignment computing device 102. Working memory 202 can be a random access memory (RAM) such as a static random access memory (SRAM) or dynamic random access memory (DRAM), or any other suitable memory.
Input-output devices 203 can include any suitable device that allows for data input or output. For example, input-output devices 203 can include one or more of a keyboard, a touchpad, a mouse, a stylus, a touchscreen, a physical button, a speaker, a microphone, or any other suitable input or output device.
Communication port(s) 207 can include, for example, a serial port such as a universal asynchronous receiver/transmitter (UART) connection, a Universal Serial Bus (USB) connection, or any other suitable communication port or connection. In some examples, communication port(s) 207 allows for the programming of executable instructions in instruction memory 207. In some examples, communication port(s) 207 allow for the transfer (e.g., uploading or downloading) of data, such as historical data related to previous loads.
Display 206 can display user interface 205. User interfaces 205 can enable user interaction with load and route assignment computing device 102. For example, user interface 205 can be a user interface for an application that allows for the viewing of historical data. In some examples, a user can interact with user interface 205 by engaging input-output devices 203. In some examples, display 206 can be a touchscreen, where user interface 205 is displayed on the touchscreen.
Transceiver 204 allows for communication with a network, such as the communication network 118 of
For example, the live load request may be for a delivery of goods to customer 312. As such, load and route assignment system 100 (
Assume a second live load request is received by load and route assignment system 100 (
If no new live load requests are received before delivery truck 302 leaves store S1308, delivery truck 302 may proceed along route 326 to return to hub 304. However, if a third live load request is received before delivery truck departs from store S1308 (e.g., while proceeding along routes 320 or 324), load and route assignment system 100 (
If the third live load request is for the delivery of goods to, or pickup of goods from, store S2310, delivery truck 302 may proceed along route 328 from store S1308 to reach store S2310 to execute the third live load request. Delivery truck 302 may then proceed along route 337 to return to hub 304.
Historical data based path determination module 402 uses historical data related to previous loads to determine (e.g., generate) optimal paths (e.g., delivery routes) that may be assigned to future loads. The historical data may include inbound load data and outbound load data from previous loads. Inbound loads are loads being delivered to a supercenter, distribution center, grocery store, warehouse, or the like where goods are stored. Outbound loads are loads that are delivered to customers, for example. The historical data may also include attributes associated with each previous load. For example, the historical data may include one or more of the attributes of an origin, a destination, a destination location type (e.g., distribution center, store, customer home, etc.), pickup due time window, pickup ready time window, drop off due time window, drop off ready time window, load requirements such as a commodity requirement, the time from the origin to the destination of the previous load, the number of stops made, and the distance from the origin to the destination of the previous load, for example.
The historical data may be stored in database 116 of
Constraints enforcement module 404 obtains optimal paths from historical data based path determination module 402 to determine whether the optimal paths comport with one or more requirements, such as requirements imposed by the United States Department of Transportation (DOT). For example, a rule may require that no more than a maximum number of hours be worked by a vehicle driver within a 24-hour period. As another example, a rule may require a minimum amount of resting hours within a 24-hour period. The constraints enforcement module 404 ensures that any optimal paths received comply with any number of rules. For example, for a given optimal path, constraints enforcement module 404 will determine if the optimal path violates the rule. If the optimal path does not violate the rule, constraints enforcement module 404 may provide the optimal path to the routes filtering and prediction module 406. Otherwise, if the optimal path does violate the rule, constraints enforcement module 404 may not provide the optimal path to the routes filtering and prediction module 406. In some examples, constraints enforcement module 404 provides an optimal path to the routes filtering and prediction module 406 only if none of a plurality of rules are violated. In some examples, a user is able to enable (e.g., select) which rules constraints enforcement module 404 should enforce.
Routes filtering and prediction module 406 obtains optimal paths from constraints enforcement module 404, and determines a ranking of the optimal paths. The ranking of optimal paths is based on historical data related to previous loads. A higher ranking indicates a path that has been more often taken that a lower ranked path. For example, routes filtering and prediction module 406 may determine how often each of a plurality of optimal paths has been taken over a period of time (e.g., over the past month, year-to-date, same month in the previous year, etc.) by obtaining data related to previous loads from database 116 of
Tour templates module 408 generates tour templates from the ranked optimal paths received from routes filtering and prediction module 406. Each tour template may include a sequence of optimal paths, including outbound and inbound optimal paths, which a vehicle may use to execute loads (e.g., deliver or pickup goods contained within a load). Tour templates module 408 may generate a given tour template based on historical data related to previous loads.
In some examples, tour templates module 408 generates a tour template with no more than a maximum number of outbound optimal paths, and no more than a maximum number of inbound optimal paths. For example, tour templates module 408 may require no more than one outbound optimal path, and no more than four inbound optimal paths per tour template. In another example, tour templates module 408 requires that the first optimal path is an outbound optimal path, and subsequent paths are inbound optimal paths. In some examples, tour templates module 408 requires that each tour have no more than a maximum number of optimal paths (e.g., 5, such as 1 outbound optimal path, and 4 inbound optimal paths). Tour templates module 408 provides the generated tour templates to load matching and assignment module 410.
In some embodiments, tour generation and load assignment modules 400 can include a geo clustering model 416, which can include a first-level clustering module 418 and a second-level clustering module 420 to create region clusters 422. In many embodiments, the data used in historical data based path determination module 402 can be provided to geo clustering model 416. For example, the origin and destination data from the historical inbound load data and outbound load data can be used to extract location information about locations (e.g., nodes) that have been used in the past. In some embodiments, these locations can be distribution centers, physical stores, vendor locations, etc. In other embodiments, the locations can include physical stores and vendor locations, but exclude distribution centers. In many embodiments, first-level clustering module 418 can perform first-level clustering on the location information to create first-level clusters. In a number of embodiments, the first-level clusters can be clusters for each of the five-digit zip codes for the nodes. In several embodiments, second-level clustering module 420 can perform second-level clustering on the first-level clusters to generate second-level clusters. These second-level clusters can each be assigned a unique region cluster identifier, along with the nodes within the second-level cluster, and this information can be used as region clusters 422 that are fed into load matching and assignment module 410.
Load matching and assignment module 410 assigns live loads 412 (e.g., real-time loads) to tour templates received from tour templates module 408 to generate tour executions 414. The tour templates, for example, are placeholders waiting to be assigned with one or more live loads for load execution (e.g., the transport of good from one location to another). A live load 412 is a load that needs to be executed. For example, a live load 412 may include goods that customers have ordered and need delivery now or in the future. When a tour template has been assigned to one or more live loads 412 and is ready for execution, the generated tour execution 414 is assigned to a vehicle. The vehicle may proceed along a route defined by the tour execution 414. For example, if the tour execution first includes an outbound path and then four inbound paths for the delivery or pickup of goods, the vehicle will proceed first along the outbound path, and then along the four inbound paths, delivering or picking up goods as required by the tour execution 414. A more detailed description of the functions of an example load matching and assignment module 410 is described below in
At step 504, historical inbound load data for inbound loads that have the same one or more attributes is aggregated (e.g., combined) into a single inbound node. For example, inbound loads with the same origin and destination may be aggregated into one inbound node. In some examples, inbound loads with the same origin, destination, as well as overlapping pickup due time windows, pickup ready time windows, drop off due time windows, and drop off ready time windows are aggregated into one inbound node. For example, inbound loads with pickup time windows that overlap by a minimum amount of time, as well as drop off time windows that overlap by a minimum amount of time, may be aggregated into one inbound load. As such, in some examples, a plurality of inbound nodes are generated.
Each inbound node is associated with a maximum capacity. The capacity is based on the number of inbound loads associated with the node. For example, if historical inbound load data for 3 inbound loads was aggregated, then the inbound node capacity would be 3.
At step 506, a “directed edge” is created between two inbound nodes if there is a sufficient amount of time to travel between locations associated with the two inbound loads while still satisfying at least a first time window attribute of at least one of the two inbound loads. For example, a directed edge may be created between two inbound loads if it is feasible in time to travel from the destination of one inbound node to the origin of the other inbound node within the drop off and pickup time window attributes associated with the inbound loads of each inbound node.
A sufficient amount of time may be a pre-defined amount of time. For example, a sufficient amount of time to travel from a location of one inbound node to a location associated with another inbound node may be determined by determining the distance between two locations, such as by using a global positioning system (GPS). Based on the distance and the average speed of a delivery vehicle, for example, a sufficient amount of time may be determined. In some examples, traffic conditions during the scheduled time of travel between the locations of the inbound load may be used to determine what would be a sufficient amount of time. For example, a real-time traffic system may be employed. Other methods of determining a sufficient amount of time between two locations is also contemplated.
For example, assume one inbound node is associated with inbound loads with a same origin, destination, and drop off due time window. Also assume that a second inbound node is associated with inbound loads with a same origin, destination, and pickup due time window. If a vehicle can begin travelling from the destination of the first inbound node at the end of the drop off due time window, and reach the origin of the second inbound node within the pickup due time window, then a directed edge is created between the two inbound nodes. For example, the two inbound nodes are then linked.
As another example, assume that a first inbound node is associated with inbound loads with a same origin, destination, and pickup due time window. Also assume that a second inbound node is associated with inbound loads with a same origin, destination, and drop off due time window. If a vehicle can begin travelling from the destination of the first inbound node at the end of the pickup due time window, and reach the origin of the second inbound node within the drop off due time window, then a directed edge is created between the two nodes. A similar determination is made between all inbound nodes.
At step 508, a graph (e.g., a directed graph) is generated based on the directed edges created between inbound loads at step 506. The graph may be initialized.
At step 510, historical outbound load data is obtained. The historical outbound load data may include data for previous outbound loads that were executed over a period of time (e.g., over the last month, year, year-to-date, same month in the previous year, etc.). The historical outbound data may also include one or more attributes associated with each outbound load.
At step 512, historical outbound load data for outbound loads that have the same one or more same attributes is aggregated (e.g., combined) into a single outbound node. For example, outbound loads with the same origin and destination may be aggregated into one outbound node. In some examples, outbound loads with the same origin, destination, as well as overlapping pickup due time windows, pickup ready time windows, drop off due time windows, and drop off ready time windows are aggregated into one outbound node.
As such, in some examples, a plurality of outbound nodes are generated. Each outbound node is associated with a capacity. The capacity is based on the number of outbound loads associated with the node. For example, if historical outbound load data for 3 outbound loads was aggregated, then the outbound node capacity would be 3. The outbound nodes may be stored as a list.
At step 514, an outbound node is set as an outbound source node. The outbound source node may be, for example, the next outbound node in an outbound node list.
At step 516, the graph is updated by adding the outbound source node and determining directed edges between the outbound source node and any inbound nodes in the graph. Similar to step 506, a “directed edge” is created between the outbound source node and an inbound node if there is a sufficient amount of time to travel between locations associated with the outbound source node and the inbound load while still satisfying at least a time window attribute of at least one of the outbound source node and inbound node. For example, a directed edge may be created it is feasible to travel from the destination of the outbound source node to the origin of the inbound node within the drop off and pickup time window attributes associated with the outbound and inbound loads of the outbound source node and inbound nodes, respectively.
At step 518, the shortest paths between the locations associated with the outbound source node and the inbound nodes are found. For example, an algorithm, such as Dijkstra's algorithm, may be used to find the shortest path between all nodes.
At step 520, a determination is made as to whether the shortest paths found in step 518 satisfy one or more rules, such as business requirements. For example, one rule may require a path to be associated with at least a minimum number of loads, such as two. Thus, paths that do not include the minimum number of loads are removed from the graph. Another rule may require a maximum number of loads, such as five, per path. Any paths with a greater number of loads are removed from the graph. Yet another rule may require a maximum number of outbound loads, and a maximum number of inbound loads.
At step 522, an optimal path of the remaining paths is determined based on a Key Performance Indicator (KPI). The optimal path with the most favorable KPI is determined. For example, the optimal path with the most favorable KPI is selected and all other paths are removed from the graph.
One KPI may be an empty miles ratio. The empty miles ratio KPI may be determined by dividing the number of unloaded miles by the addition of unloaded miles and loaded miles, as shown below in equation 1:
EMR=unloaded miles/(unloaded miles+loaded miles) (Eq. 1)
Unloaded miles may be the number of miles that would be driven by a vehicle along the associated path with little or no cargo. Loaded miles may be the number of miles driven by the vehicle with cargo. For example, miles between any two consecutive loads are driven with an empty truck and are counted towards unloaded miles. The miles between any pickup and drop off location in a load are counted as loaded miles, as a truck would be driving cargo from the pickup location to the drop off location.
Another KPI may be the cost savings per path. For example, the cost savings for each path may be calculated as shown below in equation 2:
Cost savings=sum of individual load costs−(max((rate-per-mile*total mileage),minimum charge)+stop charge) (Eq. 2)
The sum of individual load costs is the costs of all loads associated with the associated path. The rate-per-mile corresponds to the amount per mile charged to a customer for the delivery of goods, and the total mileage includes the total number of miles to be driven along the associated path. The minimum charge is the minimum amount charged to a customer for the pickup and delivery of the associated loads. The stop charge is the amount charged to a customer per truck stop (e.g., for every destination).
At step 524, the inbound node capacity for each remaining inbound node in the graph is compared to the maximum inbound capacity for that inbound node to determine if the inbound node can include any more inbound loads. For example, a maximum capacity for each remaining inbound node is reduced by the number of inbound loads associated with each remaining inbound node. If the capacity for the inbound node reaches no capacity (e.g., 0), then the inbound node is removed along with any associated directed edges along the optimal path.
Similarly, the outbound node capacity for the outbound source node in the graph is compared to the maximum outbound capacity for that outbound source node to determine if the outbound source node can include any more outbound loads. If the capacity for the outbound source node reaches no capacity (e.g., 0), then the outbound source node is removed along with any associated directed edges along the optimal path.
At step 526, a determination is made as to whether the outbound source node has been removed from the graph (e.g., the outbound source node has no capacity). If the outbound source node has been removed from the graph, the method proceeds to step 528. Otherwise, the method proceeds back to step 518.
At step 528, a determination is made as to whether there are any inbound nodes or outbound nodes remaining. For example, a determination as to whether any outbound nodes remain may be performed by determining whether there are any outbound nodes remaining in the outbound node list generated in step 514. If there are any more inbound or outbound loads, the method proceeds back to step 514, where the next outbound load is set as the outbound source node. Otherwise, if there are no more inbound or outbound loads, the method proceeds to step 530, where all remaining optimal paths are provided.
At step 606, a determination is made as to whether the live load has already been assigned to a tour execution. This may be accomplished, for example, by searching all existing tour executions to determine if this particular live load has already been assigned. The search may be accomplished by comparing a load identification of the live load to the load identifications of loads in all existing tour executions. If the load has been assigned, the method proceeds to step 608, where the tour execution already assigned to the load is returned. Otherwise, the method proceeds to step 610.
As step 610, a determination is made as to whether each tour template can be matched to the live load. The determination can be made by determining whether attributes of the live load match attributes of the tour template. In some examples, for a match to be successful, an origin and destination of the live load matches an origin and destination, respectively, of the tour template. For locations (e.g., an origin of the live load and an origin of the tour template, on the one hand, or a destination of the live load and a destination of the tour template, on the other hand) to match, in some embodiments, the two locations can match when the two locations are identical (e.g., the two locations refer to the same node). In other embodiments, the two locations can match when the two locations have the same region cluster identifier, as assigned in geo clustering model 416 (
At step 612, any tour templates that were matched are stored in a tour template list. At step 614, tour executions associated with the matched tour templates in step 612 are stored in a tour template list. At step 616, the tour template list, which includes the tour executions yet to be assigned, are ranked (e.g., sorted) by their fill rate. The fill rate may be the proportion of live loads matched to a particular tour template to the total number of live loads. In some examples, a tour execution with a higher fill rate is ranked above a tour execution with a lower fill rate.
At step 618, an attempt is made to assign the live load to a tour execution from the tour template list. In some examples, an attempt is made to assign the live load to the tour execution in the tour template list with the highest fill rate. If the assignment is successful, the assigned tour execution is returned in step 624. Otherwise, the method proceeds back to step 618, where the next tour execution from the tour template list is obtained to attempt an assignment in step 620.
If, at step 618, there are no more tour executions to attempt assignments to in step 618, the method proceeds to attempt the creation of a new tour execution 626 by proceeding to step 628. At step 628, if there are no more tour templates in the tour template list, the method proceeds to step 630, where an error, such as “NULL,” is returned. Otherwise, the method obtains the next tour template from the tour template list at step 632.
At step 634, a determination is made as to whether the assignment of the live load to the tour execution associated with the current tour template would exceed a capacity. If the capacity would be exceeded, the method proceeds back to step 628, where a determination is made as to whether there is another tour template in the tour template list. Otherwise, if the capacity would not be exceeded, the method proceeds to step 636.
At step 636, a determination is made as to whether the tour template satisfies one or more rules. For example, one rule may be whether the tour template has already expired. Another rule may be whether the tour template will become effective at a later time (e.g., is not effective now). For example, the tour template may not be effective until a later day in the week, and therefore is not available for live loads that need to be assigned now or in the near future. If the tour template does not satisfy one or more of the rules, the method proceeds back to step 528. Otherwise, the method proceeds to step 638, where a new tour execution is instantiated. For example, a new tour execution is created for live load assignment.
Proceeding to step 640 from step 638, the method assigns the live load to the newly created tour execution. At step 642, a determination is made as to whether the assignment was successful. If the assignment was not successful, the method proceeds back to step 628. Otherwise, the assigned tour execution is returned at step 644.
Turning ahead in the drawings,
In many embodiments, load and route assignment computing device 102 (
In some embodiments, method 900 and other blocks in method 900 can include using a distributed network including distributed memory architecture to perform the associated activity. This distributed architecture can reduce the impact on the network and system resources to reduce congestion in bottlenecks while still allowing data to be accessible from a central location.
Referring to
In several embodiments, method 900 also can include a block 910 of performing a first-level clustering of the nodes based on zip codes of the nodes to generate first-level clusters. In some embodiments, the first-level clustering can be a rule-based clustering based on all five digits of each of the zip codes of the nodes. For example, in a number of embodiments, each of the first-level clusters in the first-level clustering is associated with a different five-digit zip code, such that there is a one-to-one relationship between first-level clusters and five-digit zip codes. In other embodiments, the first-clusters can be based on the first four digits of the zip codes or on the first three digits of the zip codes. In a number of embodiments, the number of digits to use from the zip code can be determined based on evaluating the percentile of a cumulative distribution of a diameter of the first-level clusters, with respect to a cluster diameter parameter desired, as explained below in connection with
In a number of embodiments, method 900 additionally can include a block 915 of setting a cluster diameter parameter. In many embodiments, the cluster diameter parameter can be a design parameter specified by a user, such as based on business criteria. In many embodiments, the cluster diameter parameter can be chosen based on considerations of broadening matching for live loads while limiting empty miles (or unloaded miles) traveled with an empty (or unloaded) truck. For example, in some embodiments, the cluster diameter parameter can be approximately 30 miles. In other embodiments, the cluster diameter parameter can be another suitable distance. In many embodiments, block 915 of setting a cluster diameter parameter can be performed by first-level clustering module 418 (
In several embodiments, method 900 further can include a block 920 of determining a cluster number for a second-level clustering based on the cluster diameter parameter. In some embodiments, the cluster number can be determined using a binary search, and in several embodiments, can be determined using the binary search by comparing the cluster diameter parameter to a first diameter of a first second-level cluster at a predetermined percentile of a cumulative distribution of diameters of the second-level clusters. In several embodiments, the second-level clusters can be generated in block 925 of performing the second-level clustering of the first-level clusters in the first-level clustering based on the cluster number to generate second-level clusters, as described below, and blocks 920 and 925 can be performed iteratively until the cluster number is determined. In many embodiments, each of the diameters of each second-level cluster of the second-level clusters can be calculated based on a maximum distance between any two nodes of the nodes within the second-level cluster. In several embodiments, a distance between any two nodes of the nodes within the second-level cluster can be determined based on the latitude and the longitude of each of the any two nodes of the nodes within the second-level cluster. In many embodiments, block 920 of determining a cluster number for a second-level clustering based on the cluster diameter parameter can be performed by second-level clustering module 420 (
In several embodiments, the cluster number can be found once the diameter of the second-level clusters at P100 is less than or equal to the cluster diameter parameter. P100 (percentile 100) can refer to the percentile of a cumulative distribution plot of the diameters of the second-level clusters, such that the diameter is above the 99th percentile, as explained below in connection with
In a number of embodiments, method 900 additionally can include a block 925 of performing the second-level clustering of the first-level clusters in the first-level clustering based on the cluster number to generate second-level clusters. In many embodiments, the second-level clustering can be performed using a hierarchical clustering of the first-level clusters. For example, a hierarchical clustering can produce a hierarchy of the first-level clusters to create a dendrogram. A suitable height can be chosen to cut the branches of the dendrogram to form the second-level clusters. The number of cuts can be the number of clusters, which can be set to the cluster number determined in block 925.
In some embodiments, a location of each first-level cluster of the first-level clusters can be calculated based on a centroid of the nodes in the first-level cluster, such that distances between first-level clusters can be based on the centroid locations of the first-level clusters. In various embodiments, methods for determining linkages between first-level clusters can be based on single-linkage, complete-linkage, average-linkage, centroid, Ward.D (Ward's minimum variance method), or another suitable clustering method.
In other embodiments, the second-level clustering can be performed using K-means clustering, which can classify the first-level clusters into a user-anticipated number of clusters by centering the first-level clusters about the means of the clusters, which can be sensitive to outliers. In yet other embodiments, the second-level clustering can be performed using a partitioning around medoids (PAM) clustering method, which can be similar to K-means clustering, but can minimize the absolute distance between points instead of minimizing the square distance, which can be robust to noise and outliers.
In many embodiments, the hierarchical clustering method can be reproducible and can produce stable results despite changes to nodes. For example, when a facility opens (or is added) or closes, the second-level clustering can be more stable with hierarchical clustering. The second-level clusters can be similar or identical to the second-level clusters shown in
In many embodiments, as described above, blocks 920 and 925 can be performed iteratively to determine the cluster number evaluating the performance of the second-level clustering. For example, the second-level clustering performance can be based on the P100 statistics for the diameters D* of the second-level clusters, the number of stores in each of the second-level clusters, the number of vendors in each of the second-level clusters, and/or other suitable factors, as described below in connection with
In several embodiments, method 900 further can include a block 930 of assigning a region cluster identifier to each of the second-level clusters and each of the nodes within each of the first-level clusters that are within each of the second-level clusters. In several embodiments, each of the second-level clusters generated in block 925 can be assigned a unique identifier, which can be a region cluster identifier. In several embodiments, each of the first-level clusters within the second-level cluster also can be assigned the region cluster identifier for that second-level cluster, and/or each of the nodes within the second-level cluster also can be assigned the region cluster identifier for that second-level cluster. In several embodiments, the stores and vendor locations can be assigned the region cluster identifier, but the distribution centers are not assigned a region cluster identifier. In many embodiments, block 930 of assigning a region cluster identifier to each of the second-level clusters and each of the nodes within each of the first-level clusters that are within each of the second-level clusters can be performed by second-level clustering module 420 (
In a number of embodiments, method 900 additionally can include a block 935 of matching at least one of a plurality of tour templates with at least one live load assignment request based at least in part on the region cluster identifiers associated with the nodes. In many embodiments, block 935 can be similar or identical to step 610 (
Turning ahead in the drawings,
Turning ahead in the drawings,
Another consideration when evaluating the clustering approach is the distribution of types of nodes. For example, with the Starbucks exemplary dataset, there are company-owned nodes and licensed nodes. In other approaches, there can be physical stores and vendor locations, for example, which can exhibit similar results. With the Starbucks exemplary dataset, at the first-level clustering using the zip5 approach, among the 5633 clusters, 2282 (40%) include both nodes that are company-owned and nodes that are licensed, 2061 (37%) include only company-owned nodes, and 1290 (23%) include only licensed nodes. At the second-level clustering using the zip5 approach for the first-level clustering, among the 1647 clusters, 920 (56%) include both nodes that are company-owned and nodes that are licensed, 317 (19%) include only company-owned nodes, and 410 (25%) include only licensed nodes. So, with the second-level clustering on the zip5 first-level clusters, the cluster number drops from 5633 to 1647 when performing the second-level clustering, and the percentage of clusters that include both ownership types increases from 40% to 56%.
Turning ahead in the drawings,
Continuing in the drawings,
In many embodiments, by clustering the locations, there can be fewer unique routes, which can increase the likelihood of finding a machined lane for a live load. For example, in some embodiments and with a certain dataset, the number of unique routes without clustering can be 13,499. After first-level clustering using the zip5 approach, the number of unique routes can decrease to 12,164. After second-level clustering on the first-level clusters creating with the zip5 approach, the number of unique routes can decrease to 7,405. Using first-level clustering with the zip3 approach would decrease the number of unique routes after first-level clustering to 5,938, but the likelihood of empty miles is increased significantly with this approach. Accordingly, for many datasets, the zip5 approach to the first-level clustering, with further second-level clustering, can provide a better overall approach for routes in terms of coverage and diversity, which creates a good balance between generalizing for efficiency while limiting the amount of empty miles.
Although the methods described above are with reference to the illustrated flowcharts, it will be appreciated that many other ways of performing the acts associated with the methods can be used. For example, the order of some operations may be changed, and some of the operations described may be optional.
In addition, the methods and system described herein can be at least partially embodied in the form of computer-implemented processes and apparatus for practicing those processes. The disclosed methods may also be at least partially embodied in the form of tangible, non-transitory machine-readable storage media encoded with computer program code. For example, the steps of the methods can be embodied in hardware, in executable instructions executed by a processor (e.g., software), or a combination of the two. The media may include, for example, RAMs, ROMs, CD-ROMs, DVD-ROMs, BD-ROMs, hard disk drives, flash memories, or any other non-transitory machine-readable storage medium. When the computer program code is loaded into and executed by a computer, the computer becomes an apparatus for practicing the method. The methods may also be at least partially embodied in the form of a computer into which computer program code is loaded or executed, such that, the computer becomes a special purpose computer for practicing the methods. When implemented on a general-purpose processor, the computer program code segments configure the processor to create specific logic circuits. The methods may alternatively be at least partially embodied in application specific integrated circuits for performing the methods.
The foregoing is provided for purposes of illustrating, explaining, and describing embodiments of these disclosures. Modifications and adaptations to these embodiments will be apparent to those skilled in the art and may be made without departing from the scope or spirit of these disclosures.
Although load and route assignments with region clustering in a delivery system has been described with reference to specific embodiments, it will be understood by those skilled in the art that various changes may be made without departing from the spirit or scope of the disclosure. Accordingly, the disclosure of embodiments is intended to be illustrative of the scope of the disclosure and is not intended to be limiting. It is intended that the scope of the disclosure shall be limited only to the extent required by the appended claims. For example, to one of ordinary skill in the art, it will be readily apparent that any element of
Replacement of one or more claimed elements constitutes reconstruction and not repair. Additionally, benefits, other advantages, and solutions to problems have been described with regard to specific embodiments. The benefits, advantages, solutions to problems, and any element or elements that may cause any benefit, advantage, or solution to occur or become more pronounced, however, are not to be construed as critical, required, or essential features or elements of any or all of the claims, unless such benefits, advantages, solutions, or elements are stated in such claim.
Moreover, embodiments and limitations disclosed herein are not dedicated to the public under the doctrine of dedication if the embodiments and/or limitations: (1) are not expressly claimed in the claims; and (2) are or are potentially equivalents of express elements and/or limitations in the claims under the doctrine of equivalents.
This application is a continuation-in-part of U.S. patent application Ser. No. 16/129,708, filed Sep. 12, 2018, and U.S. patent application Ser. No. 16/129,690, filed Sep. 12, 2018. This application also claims the benefit of U.S. Provisional Application No. 62/799,209, filed Jan. 31, 2019. U.S. patent application Ser. Nos. 16/129,708 and 16/129,690, and U.S. Provisional Application No. 62/799,209, are incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
62799209 | Jan 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16129708 | Sep 2018 | US |
Child | 16713387 | US | |
Parent | 16129690 | Sep 2018 | US |
Child | 16129708 | US |