The present patent application claims the priority benefit of the filing date of Chinese Application (SIPO) No. 201310532551.8 filed Oct. 31, 2013, the entire content of which is incorporated herein by reference.
The present disclosure relates, generally, to logistics. In an example embodiment, the disclosure relates to time and location based optimization of delivery tasks.
Package delivery companies often need to deliver an item to a customer during a specific period of time. For example, some customers may only be able to receive a delivery at home when they return from work. In regard to the supply chain of retail stores, some stores may only be able to receive supplies, such as new products, during certain periods of time. For example, a store may only be able to receive supplies when there are only a few customers in the store, when they have enough available inventory space, and/or when personnel are available to receive a shipment.
In common logistics practices, the schedule and route of delivery vehicles may consider customers' locations, but may ignore considerations of detailed timing. The schedule and route may be fixed for a certain period of time (such as several weeks or months) and may not be able to consider changes in customers' demands, such as temporal constraints. For example, a fixed schedule may not be able to accommodate customers that may require different delivery time(s) on different days. As a result, service quality and customer loyalty may be reduced, and reduced efficiency may lead to higher costs. For example, if delivery optimization ignores detailed timing, more vehicles and drivers may be needed to accomplish delivery tasks.
The present disclosure is illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
The description that follows includes illustrative systems, methods, techniques, instruction sequences, and computing program products that embody example embodiments of the present invention. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide an understanding of various embodiments of the inventive subject matter. It will be evident, however, to those skilled in the art, that embodiments of the inventive subject matter may be practiced without these specific details. In general, well-known instruction instances, protocols, structures and techniques have not been shown in detail.
Generally, methods, systems, apparatus, and computer program products for logistics management are disclosed. In one example embodiment, package delivery may be managed and the location and the timing constraints of each delivery may be considered in managing the overall package delivery schedule. In one example embodiment, an objective of managing package delivery may include: 1) meeting the delivery time requirement for each delivery; 2) minimizing the number of trucks that are needed for all deliveries; 3) maximizing the profit of a fleet of one or more trucks for executing the delivery route(s); and 4) minimizing the overall delivery time, travel distance, and/or travel time.
A delivery time requirement from a customer may comprise a time window requirement: the truck should arrive at the delivery point during a specified period of time. This delivery time may be required by the customer directly (e.g., the time period between the customer returning from work and before retiring for the night) or may be an implicit requirement (e.g., a reasonable delivery time period for a typical customer (for instance, 8 AM-8 PM)). Such an on time delivery may improve service quality and reduce the waiting time of the delivery driver. In certain situations, such an on time delivery may reduce the package unloading time as the customer may be more prepared for collecting deliveries.
Minimizing the number of trucks and/or deliverymen that are needed for all deliveries may be very important for cost control. A lower number of trucks may mean a lower asset investment and lower maintenance costs. In addition, fewer truck drivers may be needed to fulfill all the tasks, which may mean reduced personal costs, increased personal utilization, and higher employee loyalty.
Profit maximization may require more deliveries, shorter total travel distance, and/or less total trip time for a route. More deliveries may mean less unused capacity, which may lead to less waste. Shorter total travel distance may lead to lower fuel consumption, and may reduce cost and pollution.
Minimizing delivery time, total trip time and/or total trip distance may lead to lower personal costs and reduced fatigue of truck drivers, which may help improve driving safety. In one example embodiment, profit may be used as the index to incorporate the factors described above.
In one example embodiment, a tree structure may be used to find feasible delivery routes for the package delivery. A feasible delivery route is a route that meets one or more of the defined scheduling constraints, such as truck capacity, customer availability, and the like. Similarly, a path to a delivery point is feasible if it meets defined scheduling constraints, such as truck capacity, customer availability, and the like. Based on the feasible delivery routes, one or more optimal routes may be determined. An optimal route is a route that may rank high in terms of one or more of low delivery cost, low total travel time, total number of deliveries, truck utilization, route profit, and the like. One or more routes may then be selected from the optimal routes based on certain factors and the selected routes may be used for the final delivery schedule.
In one example embodiment, a tree of feasible delivery routes may be pruned during and/or after the construction process. Some non-optimal feasible routes (e.g., routes with high cost, long total travel time, and the like) may be removed from the tree so that the construction speed of the tree may be improved. The search for optimal routes may be faster based on a smaller set of feasible routes.
The “business logic” component of the application 108 may represent the core program code of the application 108, i.e., the rules governing the underlying business process (or other functionality) provided by the application 108. The “presentation logic” may describe the specific manner in which the results of the business logic are formatted for display on the user interface. The “database” 116 may include data access logic used by the business logic to store and retrieve data.
In response to limitations associated with the two-tiered client-server architecture, a multi-tiered architecture has been developed, as illustrated in
This separation of logical components and the user interface 154 may provide a more flexible and scalable architecture compared to that provided by the two-tiered model of the system 100 in
In one example embodiment, the input to the system may include:
In one example embodiment, there may be one home base H for all delivery trucks. In one example embodiment, the intermediate data may include:
In one example embodiment, the output of the system may be multiple route assignments, each of which may include:
An execution method 316 may be used to compare optimal routes and select one or more of the optimal routes. For example, the execution method 316 may automatically select the highest ranking routes determined by the optimization method 312 or may assist a user in comparing the optimal routes and selecting one or more of the optimal routes for package delivery. The output 320 may comprise the selected optimal route(s) and a delivery schedule that may be sent to each truck's driver.
The apparatus 400 is shown to include a processing system 402 that may be implemented on a server, client, or other processing device that includes an operating system 404 for executing software instructions. In accordance with an example embodiment, the apparatus 400 may includes a user interface module 406, a tree construction module 410, an optimization module 414, and an execution module 422. In accordance with an example embodiment, the apparatus 400 may include a data interface module 426.
The user interface module 406 may import input information, such as a list of delivery points and package characteristics, fleet availability and truck characteristics, delivery time constraints, and the like, as described more fully above.
The tree construction module 410 may construct the tree structure 500, as described more fully below in conjunction with
The optimization module 414 may optimize the selection of truck delivery routes. In one example embodiment, the optimization module 414 may identify one or more optimal truck delivery routes by optimizing one or more delivery objectives, such as maximizing revenue, maximizing profit, minimizing travel distance, and the like.
The execution module 422 may select an optimal route from a set of optimal routes. In one example embodiment, the execution module 422 may assist a user in selecting the final delivery route for each truck. For example, the execution module 422 may assist the user in identifying the most profitable route(s) for a selected delivery truck.
As noted above, the root node 504 may be a home base. The capacity of the root node 504 may, therefore, be the whole capacity of the truck. The FDTW of the root node 504 may be the time window that the truck is fully loaded and may leave its home base. The tree structure 500 may be constructed in depth first or breadth first fashion, as described more fully below. For each node n in the tree structure 500, the system searches for reachable and deliverable unvisited points if the truck leaves the node during its feasible departure time window. For an unvisited point m, its arrival time window is [LSn+Tnm, LEn+Tnm] and its feasible arrival time window is:
[ASm,AEm]=[LSn+Tnm,LEn+Tnm]∩[TSm−TW,TEm]
For this point to be reachable, it should satisfy:
[LSn+Tnm,LEn+Tnm]∩[TSm−TW,TEm]≠Ø
This may mean that the truck could arrive at that point during its required delivery time window or within a certain time before the start of the time window (not larger than TW, however). For this point to be deliverable, it should satisfy:
W
m
≦C
n
This means that the truck should have enough remaining capacity for point m. If point m satisfies these requirements, it may be added to the tree structure 500 as a child of node n. (Points m and n are two consecutive delivery points in a feasible path.) Some reachable and deliverable unvisited points of node n may not be added as its child if a related feasible path would not be acceptable. For example, if the travel time from n to m (Tnm) is too long the path may not be acceptable. (In one example embodiment, a user may define Tnm) In this case, one or more trucks should be dispatched in order to make delivery for those unvisited points. The same process can be used to find optimal routes for newly added trucks. Other pruning techniques may be applied during the tree construction process. If point m is added to the tree structure 500 as a child of node n, its feasible departure time window is:
[LSm,LEm]=[max(ASm,TSm)+TUm,max(AEm,TSm)+TUm]
The whole construction process may be ended if no more nodes can be added to the tree structure 500.
In one example embodiment, there may not be a single feasible route that can cover all deliveries. In this case, a set of routes for a set of trucks may be determined. The process may, therefore, be a greedy way to assign delivery tasks to different trucks. In one example embodiment, in each iteration, the method searches for the best route for each selected truck.
In one example embodiment, a node for the home base may be established with the node indicating the capacity of the truck at the home base (operation 704) and a tree level index may be set to zero (operation 708).
For each unassigned delivery point, the delivery point is added as a child of the root node if the path to the delivery point is feasible (operation 712). The tree level index, i, may then be incremented (operation 716).
For each unassigned delivery point for each path from the root node to each node in the tree level i, the delivery point may be added as a child of a node in the tree level index i if the path to the delivery point is feasible (operation 720).
The tree level index i may be incremented (operation 724).
A test is then performed to determine if tree level index i is equal to the number of delivery points (operation 728). If the tree level index i is greater than the number of delivery points, the method may end; otherwise the method proceeds with operation 720.
In order to efficiently find an optimal route, the size of the tree structure 500 may be reduced as a large tree may result in a time consuming construction and searching. The tree pruning may occur during and/or after construction of the tree structure 500. Several tree pruning techniques may be applied during the tree construction process:
1. pruning routes that contain only a few number of nodes, as such types of routes may require a larger number of trucks to cover all deliveries (for example, routes containing a number of nodes less than a node count threshold may be pruned);
2. pruning routes where the total weights of deliveries on the routes are lower than a weight threshold (low utilization);
3. if two routes contain the same set of nodes, prune the route whose finish time is later; and
4. if two routes contain the same set of nodes, prune the route whose travel distance is longer.
In one example embodiment, a constructed tree may be obtained (operation 804). Routes that contain a count of nodes less than a node count threshold may be pruned from the tree (operation 808). Routes that comprise a total delivery weight of less than a weight threshold may be pruned from the tree (operation 812). In one example embodiment, a user may set the node count threshold and the weight threshold.
A pair of routes from the tree may be selected, each selected route beginning at the root node and ending at a leaf node (operation 816) and delivery points of the pair of selected routes may be compared (operation 820). A test may be performed to determine if the sets of delivery points are the same (operation 824). If the sets of delivery points are the same, the route of the pair of routes corresponding to the later delivery finish time may be deleted (operation 828); otherwise, the method may proceed with operation 832.
During operation 832, a test may be performed to determine if all the pairs of routes beginning at the root node (e.g., root node 504) and ending at a leaf node (e.g., leaf node 512-1, 512-2) have been processed. If all pairs of routes beginning at the root node (e.g., root node 504) and ending at a leaf node (e.g., leaf node 512-1, 512-2) have not been processed, the method may proceed with operation 816; otherwise, the method may end.
Each leaf node in a tree may represent a feasible delivery route, which traverses a path through the tree from the root node to the leaf node and returns from the leaf node to the home base directly. The total distance s is the sum of travel distances between all two consecutive nodes on the path and the direct distance from the leaf node to the home base. The actual departure time window from the home base may be computed through computation from the leaf node to the root node. The total travel times may be the same for different departure times of a route. However, an optimal time point or time window may be found by minimizing the total wait time of the route. The optimal total travel time may be represented as e. The total delivery revenue of a route may be the sum of delivery fees (revenues) for the deliveries at demand points along the path. This may be denoted as r. The profit o for the route may be computed as follows:
o=r−s G−t P
An objective may be to find the routes with largest profits. In one example embodiment, the profits of all routes are computed and the optimal routes are selected by ranking the routes based on profit.
In one embodiment, profits of all routes may be computed. The optimal routes may be selected by ranking the profits of the computed routes. Some constraints (e.g. maximal working time) may be used to reduce the number of candidate routes.
In addition to being sold or licensed via traditional channels, embodiments may also, for example, be deployed by Software-as-a-Service (SaaS), Application Service Provider (ASP), or by utility computing providers. The computer may be a server computer, a personal computer (PC), a tablet PC, a set-top box (STB), a personal digital assistant (PDA), cellular telephone, or any processing device capable of executing a set of instructions (sequential or otherwise) that specify actions to be taken by that device. Further, while only a single computer is illustrated, the term “computer” shall also be taken to include any collection of computers that, individually or jointly, execute a set (or multiple sets) of instructions to perform any one or more of the methodologies discussed herein.
The example computer processing system 900 includes a processor 902 (e.g., a central processing unit (CPU), a graphics processing unit (GPU) or both), a main memory 904 and static memory 906, which communicate with each other via a bus 908. The computer processing system 900 may further include a video display unit 910 (e.g., a plasma display, a liquid crystal display (LCD) or a cathode ray tube (CRT)). The computer processing system 900 also includes an alphanumeric input device 912 (e.g., a keyboard), a user interface (UI) navigation device 914 (e.g., a mouse, touch screen, or the like), a drive unit 916, a signal generation device 918 (e.g., a speaker), and a network interface device 920.
The drive unit 916 includes machine-readable medium 922 on which is stored one or more sets of instructions 924 and data structures embodying or utilized by any one or more of the methodologies or functions described herein. The instructions 924 may also reside, completely or at least partially, within the main memory 904, static memory 906, and/or within the processor 902 during execution thereof by the computer processing system 900, the main memory 904, static memory 906, and the processor 902 also constituting machine-readable, tangible media.
The instructions 924 may further be transmitted or received over network 926 via a network interface device 920 utilizing any one of a number of well-known transfer protocols (e.g., Hypertext Transfer Protocol).
While the machine-readable medium 922 is shown in an example embodiment to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions 924. The term “machine-readable medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions 924 for execution by the computer and that cause the computer to perform any one or more of the methodologies of the present application, or that is capable of storing, encoding or carrying data structures utilized by or associated with such a set of instructions 924. The term “machine-readable medium” shall accordingly be taken to include, but not be limited to, solid-state memories, and optical and magnetic media.
While the invention(s) is (are) described with reference to various implementations and exploitations, it will be understood that these embodiments are illustrative and that the scope of the invention(s) is not limited to them. In general, techniques for maintaining consistency between data structures may be implemented with facilities consistent with any hardware system or hardware systems defined herein. Many variations, modifications, additions, and improvements are possible.
Plural instances may be provided for components, operations or structures described herein as a single instance. Finally, boundaries between various components, operations, and data stores are somewhat arbitrary, and particular operations are illustrated in the context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within the scope of the invention(s). In general, structures and functionality presented as separate components in the exemplary configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the invention(s).
Number | Date | Country | Kind |
---|---|---|---|
201310532551.8 | Oct 2013 | CN | national |