WO2018079443A1 - 配送計画システム、配送計画方法及びプログラム - Google Patents
配送計画システム、配送計画方法及びプログラム Download PDFInfo
- Publication number
- WO2018079443A1 WO2018079443A1 PCT/JP2017/038040 JP2017038040W WO2018079443A1 WO 2018079443 A1 WO2018079443 A1 WO 2018079443A1 JP 2017038040 W JP2017038040 W JP 2017038040W WO 2018079443 A1 WO2018079443 A1 WO 2018079443A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- delivery
- time
- base
- plan
- demand
- Prior art date
Links
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/04—Forecasting or optimisation specially adapted for administrative or management purposes, e.g. linear programming or "cutting stock 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
Definitions
- the present invention relates to a delivery planning system, a delivery planning method, and a program.
- This application claims priority based on Japanese Patent Application No. 2016-213838 filed in Japan on October 31, 2016, the contents of which are incorporated herein by reference.
- Car sharing is a system in which, for example, a vehicle is shared between members, a fee is paid according to the boarding time, and the vehicle is used at any time.
- a drop-off type one-way type
- the user can use the common vehicle to a predetermined parking lot near the destination and leave the car as it is in the parking lot.
- after-service patrols in which a service person visits a customer in order to provide after-sales service for products purchased by a customer, the same situation arises regarding the movement of the service person and parts necessary for providing the service.
- products that are subject to after-sales service are installed at each of multiple customers, and service personnel procure parts to be used for after-sales service of the products at a certain location and carry them to customers.
- service personnel procure parts to be used for after-sales service of the products at a certain location and carry them to customers.
- a service person who performs various types of after-sales service moves from one customer to another customer who needs the same parts to provide the service, and then returns the used parts to the original It is necessary to select a patrol method.
- Patent Document 1 discloses a technique for creating a transportation plan for transporting a package from a plurality of delivery bases using a plurality of transportation means at a date and time designated as a plurality of delivery destinations. There is.
- a transportation plan in which a vehicle used by a user is loaded on a transportation means such as a truck and transported to each parking lot.
- a delivery plan for delivering the parts used for the service to the customer can be created.
- linear relaxation a technique that solves a problem once by replacing it with a continuous value problem and finds an optimal solution from the obtained relaxation solution. If there are many complicated constraints like this, it will take too much calculation time as it is, and thus a device for solving in a practical time is required.
- an object of the present invention is to provide a delivery planning system, a delivery planning method, and a program that can solve the above-described problems.
- the delivery planning system includes a dividing unit that divides a delivery problem indicated by initial conditions into a smaller delivery problem in a delivery problem of delivering a delivery to a delivery base in demand.
- a delivery plan generation unit that generates a delivery plan for the delivery problem after the division unit divides.
- the dividing unit includes one demand point included in a distribution base group having a demand for the delivery item and one supply point included in a delivery base group serving as a supply source of the delivery item.
- a set of the combinations of the demand point and the supply point associated with each other is generated, and the initial condition indicates
- the delivery problem may be divided into a delivery problem from a demand point group included in the generated set to a supply point group.
- the delivery area is divided into delivery area units for each set of delivery bases that exist at a short distance, and a delivery plan is created for each delivery area after the division. By calculating, a delivery plan can be generated in a practical time.
- the dividing unit is configured such that the movement time from one supply point to one demand point in the correspondence relationship between the plurality of supply points and the plurality of demand points included in the generated set.
- a delivery route from a supply point to a demand point that is less than or equal to a predetermined value is calculated, and the delivery plan generator generates a travel time of the delivery route from the supply point group to the demand point group included in the generated set.
- a delivery plan for the delivery problem with a small scale may be generated using a delivery route that is less than or equal to the predetermined threshold. Since the delivery plan is generated using the information on the delivery route between the delivery bases whose movement time is equal to or less than the threshold value, the amount of calculation required for generating the delivery plan can be reduced.
- the dividing unit performs delivery according to a preset delivery route from a departure base to delivery between some delivery bases and returning to the departure base, and the delivery route.
- a minimum combination is calculated, a set of departure bases and delivery bases included in the combination is generated, and a delivery problem indicated by the initial condition is expressed as a demand point group included in the generated start base and delivery bases set. May be divided into problems of delivery from point to point.
- a combination of delivery routes that satisfies the demands at a plurality of delivery bases within a predetermined number and minimizes the delivery cost is calculated, and a set of the plurality of delivery bases and the departure base is taken as one delivery area.
- the delivery plan can be made in a practical time. Can be generated.
- the dividing unit according to the fifth aspect of the present invention calculates a combination of the unit path information by a column generation method.
- a column generation method By using the column generation method, a delivery area can be generated at high speed.
- the dividing unit divides a delivery problem indicated by the initial condition into a delivery problem for each divided time by dividing a delivery restriction time of the delivery item into a plurality of times,
- the delivery plan generator generates a delivery plan in which the delivery item is delivered to a base having the highest demand within each time after the division from the delivery status of the delivery item at the first time of each time after the division. May be generated.
- the delivery plan generation unit is indicated by the initial condition until the last time ends with respect to a delivery problem related to the last time generated by the division unit.
- a delivery plan may be generated so that the delivery is delivered to all the delivery bases in demand.
- a delivery plan is generated in a practical time by dividing a delivery limit time given by an initial condition and calculating a delivery plan for a delivery problem in time units after the division. be able to.
- the dividing unit determines that the delivery problem indicated by the initial condition is a first delivery time limit shorter than the delivery time limit included in the initial condition by a predetermined time as a new delivery time limit.
- the delivery plan generation unit may generate a delivery plan in which the delivery items are delivered to a site with as much demand as possible within the first delivery time limit.
- the division unit sets a predetermined length of time following the first delivery limit time as a second delivery limit time, and the delivery plan generation unit includes the second delivery limit time
- a delivery plan may be generated so that the delivery is delivered to a base where there is as much demand as possible.
- the delivery plan generating unit includes a completion time when the generated delivery plan is executed as a start time, and is included in the initial condition on the basis of the start time of the first delivery time limit.
- a delivery plan that finishes delivering a delivery that has not been delivered as a result of execution of the delivery plan may be generated within the last time whose end time is the time when the delivery limit time elapses.
- a time shorter than the delivery limit time given in the initial condition is set as the delivery limit time, and the delivery plan is generated while extending the delivery limit time.
- a delivery plan can be generated in a practical time by dividing the delivery problem indicated by the initial condition into smaller delivery problems for each delivery limit time set or extended.
- the delivery plan generation unit executes the delivery plan as a result of executing the delivery plan.
- a delivery plan may be generated on the condition that necessary delivery staff and delivery means do not remain at the delivery base.
- the delivery plan generator generates a delivery entity that delivers the delivery and a starting location that indicates an initial position of the delivery means or delivery means that moves the delivery entity, and the delivery location and delivery start.
- a delivery entity that delivers the delivery and a starting location that indicates an initial position of the delivery means or delivery means that moves the delivery entity, and the delivery location and delivery start.
- the delivery plan generation unit includes, in the spatio-temporal network model, point information relating to an entrance that is a set of an entrance of the delivery site and a time for one delivery site. , Generating point information related to the exit that sets the exit of the delivery base and time, and point information related to the location of the delivery that sets the time for each deliverable related to the delivery base , Between the point information related to the entrance and the point information related to the delivery, and between the point information related to the exit and the point information related to the delivery, the value of the flow rate of the delivery subject and the delivery It may be set to 0 or 1.
- the delivery base is treated as a 0-1 integer programming problem. It becomes possible to handle and can speed up the calculation process.
- the delivery planning system divides a delivery problem indicated by initial conditions into a smaller delivery problem in a delivery problem of delivering a delivery to a delivery base in demand, This is a delivery planning method for generating a delivery plan for a delivery problem after the delivery.
- the program causes the computer of the delivery planning system to change the delivery problem indicated by the initial condition to a smaller delivery problem in the delivery problem of delivering the delivery to a delivery base in demand. It functions as a means for dividing and a means for generating a delivery plan for the delivery problem after the division.
- FIG. 1 is a functional block diagram showing an example of a delivery planning system in the first embodiment of the present invention.
- the delivery planning system is configured by a computer device such as a single PC or a server device, for example.
- the computer device includes a calculation unit such as a CPU (Central Processing Unit), a storage unit such as a ROM (Read Only Memory), a RAM (Random Access Memory), and an HDD (Hard Disk Drive), and other hardware such as a network interface. It is comprised including the wear.
- a CPU Central Processing Unit
- ROM Read Only Memory
- RAM Random Access Memory
- HDD Hard Disk Drive
- the delivery planning device 10 is a device that calculates a delivery means, a delivery route, and the like that minimize the cost with respect to a delivery plan including boarding transportation.
- a method of planning an optimal delivery plan that realizes delivery in a scene where a user jointly uses a vehicle that is used jointly in a drop-off type car sharing is delivered to a place where the user starts using the vehicle.
- delivering a delivery item for example, it is required to select a delivery means and delivery route that minimize the cost.
- Various methods have been provided in the past for planning delivery plans that minimize costs.
- the delivery of vehicles in car sharing is different from the case where packages are delivered by, for example, a home delivery service.
- a person when a vehicle is delivered, a person can get on the vehicle and move. For example, it is assumed that there is a state where the vehicle is left or short at each of the base A, the base B, the base C, the base D, and the base E. In such a state, for example, the following method is conceivable in order to move the vehicle from the base where the vehicle is surplus to the base where the vehicle is insufficient to meet the needs of the user.
- One delivery staff travels to each site with a truck on which vehicles can be loaded, and the surplus vehicles are loaded onto the truck and delivered to a location where there is a shortage.
- a plurality of delivery staff board the delivery vehicle and move from one location to another.
- the delivery planning apparatus 10 of the present embodiment introduces a mathematical model and constraints based on mathematical knowledge to a delivery plan when boarding transportation is possible, thereby minimizing cost, for example, at high speed.
- a method for generating a delivery plan is provided.
- the delivery planning device 10 of the present embodiment In generating a delivery plan for delivering a delivery to a delivery base, the delivery planning device 10 of the present embodiment generates a demand quantity (a missing quantity) of the delivery for each delivery base given as an initial condition for the delivery. ) And the supply quantity (remaining quantity), the entire delivery problem indicated by the initial condition is divided into partial delivery problems of small scale. Thereby, even if the number of vehicles and bases to deliver is large, a delivery plan can be drawn up in practical time (for example, 10 minutes).
- the delivery planning apparatus 10 includes an initial condition setting unit 11, a delivery plan generating unit 12, an input / output unit 13, a first area dividing unit 14, and a storage unit 15.
- the initial condition setting unit 11 is a delivery item (for example, a vehicle used by a user) that can be carried by a delivery subject (eg, a delivery staff), a delivery subject, a delivery item that moves the delivery subject, or a delivery subject (eg, a delivery subject).
- the delivery plan generation unit 12 is a delivery related to the delivery between the point information obtained by combining the delivery base and the departure base and the time based on the delivery start time, and the two pieces of point information relating to the delivery among the point information.
- the departure base and delivery base are collectively referred to as a base.
- the input / output unit 13 receives an input operation by the user.
- the input / output unit 13 outputs information on a delivery plan based on the set of branch information generated by the delivery plan generation unit 12 to a display or the like.
- the first area dividing unit 14 determines one demand point included in a distribution base group having a demand for a delivery item and one supply point included in a distribution base group serving as a supply source of the delivery item.
- a set of combinations of demand points and supply points associated with each other is generated so as to minimize the travel time from the point to the one supply point.
- the first area dividing unit 14 includes the entire delivery problem to all the delivery base groups having the demand for the delivery based on the initial condition (the delivery problem in the delivery area indicated by the generated set (included in the set). (Distribution problem from demand point group to supply point group).
- generation part 12 produces
- the storage unit 15 stores various pieces of information necessary for generating a delivery plan.
- the initial condition setting unit 11, the delivery plan generating unit 12, and the first area dividing unit 14 are, for example, a CPU (Central Processing Unit) included in the delivery planning device 10 reads out and executes a program from the storage unit 15. It is realized with.
- a CPU Central Processing Unit
- the delivery planning device 10 generates a delivery plan for the given delivery problem using a spatio-temporal network model.
- a spatio-temporal network model and a delivery plan generation method using the spatio-temporal network model will be described, and then a distribution problem dividing method when the problem becomes large will be described.
- FIG. 2 is a diagram illustrating an example of a delivery plan in the first embodiment of the present invention.
- a delivery example of a delivery item (vehicle) in a drop-off type car sharing will be described with reference to FIG.
- the center is a base where a delivery staff of delivery goods exists and starts delivery of the delivery goods (departure base).
- the parking lot A, the parking lot B, and the parking lot C are bases (delivery bases) that serve as delivery sources or delivery destinations of deliveries.
- the user of the delivery item reserves the delivery item using a predetermined reservation system or the like. The user inputs information such as the number of deliverables to be used and the use start location (for example, parking lot B) from the reservation system.
- the delivery staff needs to move the delivery item from another parking lot to the parking lot B.
- drop-off type car sharing for example, when a user uses a delivery item from the parking lot B to the parking lot A, the user drops the delivery item into the parking lot A as it is. Then, a situation where many users use, for example, delivery items are ubiquitous in the parking lot A may occur.
- the center delivery staff delivers ubiquitous deliveries to parking lots A to C where the user needs. In the case of the example in FIG.
- FIG. 2 shows an implementation example of delivery satisfying this condition.
- two delivery staff (k, l) from the center board a single delivery vehicle 1 (delivery means) and move to parking lot A (1).
- the delivery staff k gets on one delivery item out of the two remaining and moves to the parking lot B.
- Other delivery staff l also board the delivery vehicle 1 and move to the parking lot B (2).
- the delivery staff k parks the delivery items in the parking lot B, and gets on the delivery vehicle 1 driven by the delivery staff l.
- the delivery staffs k and l return from the parking lot B to the parking lot A (3).
- the delivery staff k moves to the parking lot C after boarding the remaining delivery item.
- the delivery staff l gets on the delivery car 1 as it is and moves to the parking lot C (4).
- the delivery staff k parks the delivery item in the parking lot C, and gets on the delivery vehicle 1 driven by the delivery staff l. Delivery staffs k and l return from parking lot B to the center (5).
- the delivery method in such a situation is formulated as a minimum cost flow problem of the spatio-temporal network model, and a method that minimizes the cost among the feasible delivery methods is obtained.
- FIG. 3 is a diagram for explaining a first spatiotemporal network model according to the delivery plan in the first embodiment of the present invention.
- FIG. 3 is a diagram in which the delivery example described in FIG. 2 is modeled as a spatio-temporal network.
- the vertical axis in FIG. 3 indicates the passage of time, and the horizontal axis indicates the location of each base.
- the points on the spatiotemporal represent each base at each time.
- an arrow connecting two points indicates movement of a delivery item, a delivery vehicle (delivery means), and a delivery staff (person) in time and space.
- Each arrow represents a movement source base, a movement destination base, and a time required for movement.
- a solid line arrow indicates movement between bases, and a double line arrow indicates a delivery, a delivery vehicle, and a delivery staff who stay at the same base (moving time).
- Each element of the matrix displayed along with each arrow represents the quantity of deliveries, delivery vehicles, and delivery staff moved by the delivery indicated by the arrows.
- the quantity of deliveries moved in order from the top and the delivery cars moved Represents the number of delivery staff moved.
- the reason that the delivery items in the parking lot A have changed from two to one is that the delivery staff boarded one of the two deliveries and moved to the parking lot B. The same applies to the other arrows.
- a single arrow is called a branch.
- the set of branches in FIG. 3 corresponds to the delivery plan described in FIG.
- a time-related action such as waiting for a delivery staff member or delivery means at some parking lot.
- models are often modeled with bases as points and the movement of delivery vehicles between bases as branches.
- modeling is performed with a two-dimensional space-time network. Thereby, not only the spatial movement between bases but the movement of a vehicle or a person who intervenes time can be expressed.
- ⁇ Delivery plan generation method based on the first spatiotemporal network model> a delivery plan that minimizes the cost of delivery in a delivery plan delivery that satisfies the demand within the time limit described with reference to FIGS. 2 and 3 is obtained.
- This problem can be formulated as an integer programming problem shown below.
- [Objective function] Minimize the total cost of deliverables, delivery methods, and delivery staff [Restrictions] (1) The flow rate at each site satisfies the flow rate conservation law. (2) The number of vehicles in the parking lot does not exceed the parking space of the parking lot. (3) A delivery staff is always on the delivery means except at the departure base. (4) A delivery staff always gets on the delivery item or delivery means when moving, and the number of people at the time of movement is equal to or less than the total number of people who can board the delivery item and delivery means.
- the delivery plan generating unit 12 In order to solve the integer programming problem, the delivery plan generating unit 12 generates two-dimensional space-time information as illustrated in FIG. 3 based on the initial condition information received by the initial condition setting unit 11, Generate branches between points related to delivery, and generate multiple sets of branch information that can deliver deliveries to the base where the demand quantity is set so that the demand quantity of each base is met within the delivery deadline. . Then, the delivery plan generation unit 12 selects a set of branch information that minimizes the cost from a set of multiple branch information.
- ⁇ Second space-time network model> a graph in the delivery base (point information and branch information indicating movement of delivery staff, delivery items, and delivery means) is further added to the first spatio-temporal network model.
- the delivery base can be treated as a 0-1 integer programming problem.
- the 0-1 integer programming problem is more restrictive than the integer programming problem, and can constitute a tight relaxation problem. As a result, it becomes easy to enter a reasonable inequality (cut), and the calculation process can be speeded up (calculation time is shortened).
- the delivery plan generating unit 12 When the delivery plan generating unit 12 generates a delivery plan using the second spatiotemporal network model, in addition to the spatiotemporal information described in the case of the first spatiotemporal network model, Point information that sets the entrance and time of the pair, point information that sets the exit and time of the delivery base, and point information that sets the time for each delivery item related to the delivery base .
- the delivery plan generation unit 12 sets the value of the flow rate of the delivery staff and the delivery item between the point information related to the entrance and the point information related to the delivery item to 0 or 1.
- the delivery plan generation unit 12 sets the value of the flow rate of the delivery staff and the delivery item between the point information related to the exit and the point information related to the delivery item to 0 or 1.
- Input parameters include the following items.
- Loading capacity (cp) of delivery means cost cx (yen / minute) of delivery goods, cost cy (yen / minute) of delivery means, cost cz (yen / minute) of delivery staff, travel time matrix M (for example, ,
- the moving time from the delivery base w1 to w2 by the delivery means d is m [d] [w1] [w2])
- the supply quantity supply at each base for example, the supply quantity of d at the delivery base w is supply [w] , D]
- the demand quantity demand of each delivery base for example, the demand quantity of d at the delivery base w is demand [w, d
- the delivery plan generation unit 12 includes the flow rate x ((v, s), (w, t)) of the delivery items flowing through the spatio-temporal network in the optimized delivery plan, and the flow rate y ((v , S), (w, t)) and the flow rate z ((v, s), (w, t)) of the delivery staff are output to the input / output unit 13.
- a branch that departs the delivery base v at time s and arrives at the delivery base w at time t is represented by ((v, s), (w, t)).
- the output items include other costs for delivery.
- FIG. 4 is a first diagram illustrating a second space-time network model according to a delivery plan in the first embodiment of the present invention.
- the second space-time network will be described with reference to FIG.
- the place set is N
- the time set is T
- the spatiotemporal network graph G (V, E).
- V is a point set and E is a branch set.
- the point set V is defined as follows.
- V ⁇ (w, d, p, t)
- Swd takes values of 0, 1, 2, and 3.
- the port indicates a place where one delivery item d is placed.
- the branch set E will be described with reference to FIG.
- FIG. 5 is a second diagram illustrating a second space-time network model according to the delivery plan in the first embodiment of the present invention.
- E x is a branch set of delivery items
- E y is a branch set of delivery means
- E z is a branch set of delivery staff.
- the branch set Ex of the deliverable is defined as follows.
- E wwx E wwx ⁇ E wx ⁇ E wpx ⁇ E pwx ⁇ E px E wwx is a set of branches indicating the movement of the delivery item between the bases, E wx is a set of branches (such as waiting) remaining on the road of the delivery point of the delivery item, and E wpx is a movement of the delivery item from the road to the port A set of branches, E pwx, is a set of branches indicating movement of the delivery from the port to the road, and E px is a set of branches where the delivery remains at the port.
- the branch set E y of the delivery means is defined as follows.
- E y E wwy ⁇ E wy ⁇ E wpy ⁇ E pwy
- E wwy shows a set of branches showing the movement between the base of the delivery means, the set of E wy branches that remain in the way of delivery base of the delivery means (such as waiting), the movement of the E wpy is to port from the way of the delivery means
- a set of branches, E pwy is a set of branches indicating movement from the port of the delivery means to the road.
- the branch set E z of the delivery staff is defined as follows.
- E z E wwz ⁇ E wz ⁇ E wpz ⁇ E pwz
- E wwz is a set of branches indicating movement between delivery staff bases
- E wz is a set of branches (such as waiting) remaining on the delivery staff delivery base road
- E wpz is movement from the delivery staff road to the port.
- a set of branches, E pwz is a set of branches indicating the movement of the delivery staff from the port to the road.
- FIG. 5 shows a display example of the branch set defined above.
- the solid line arrows in the diagonal direction indicate branches corresponding to the respective sets of Ewx , Ewwy , and Ewwz .
- a vertical double line arrow indicates a branch corresponding to each set of E wx , E wy , and E wz .
- the two-dot chain arrow in the horizontal direction indicates a branch corresponding to each set of E wpx , E wpy , and E wpz .
- the one-dot chain arrows in the oblique direction indicate branches corresponding to the respective sets of E pwx , E pwy , and E pwz .
- a vertical dashed arrow indicates a branch corresponding to a set of Epx .
- the inside of the delivery base is treated as a 0-1 integer problem, but the branch of the horizontal two-dot chain line arrow, the diagonal one-dot chain line arrow, and the vertical dashed arrow is the 0-1 integer. This is a branch added in the present embodiment in relation to the problem.
- FIG. 6 is a third diagram illustrating the second space-time network model according to the delivery plan in the first embodiment of the present invention.
- a flow vector set for each branch will be described with reference to FIG. As shown in FIG. 6A, each branch e has a flow vector.
- the branch e shown in FIG. 6B shows the movement of one a, one delivery car (car), and two delivery staff (persons).
- the flow vector is
- the branch e shown in FIG. 6C shows the movement of one a, one b, one delivery vehicle (car), one motorcycle, and two delivery staff (people).
- FIG. 7 is a fourth diagram illustrating the second space-time network model according to the delivery plan in the first embodiment of the present invention.
- FIG. 7 shows that the flow vector is
- two delivery staff personnel and one delivery car (car) move from the Depot exit to the delivery base 1 (solid arrow 91).
- one delivery staff moves to the place (port 0) for the delivery item a (two-dot chain arrow 92).
- delivery item a exists from time 0 to time 1 (broken line arrow 93).
- one delivery staff and one delivery item a move to the exit of the delivery base 1 (one-dot chain arrow 94).
- one delivery item a, one delivery vehicle, and two delivery staff move from the exit of the delivery base 1 to the entrance of the delivery base 2 (solid arrow 95).
- one delivery staff and one delivery item a move to port 0 of the delivery base 2 (two-dot chain arrow 96).
- one delivery staff moves from port 0 to the exit of delivery base 2 (one-dot chain arrow 97).
- two delivery staff and one delivery vehicle move from the exit of the delivery base 2 to the Depot entrance (solid arrow 98).
- a delivery item a exists from time 2 to time 3 (dashed arrow 100). As shown in FIG.
- a point is assigned to each delivery item a1, and a point is assigned to each of the entrance and the exit of the delivery base. Therefore, the value of each element of the flow vector in the delivery base 1 and the delivery base 2 is 0 or 1. As a result, the inside of the delivery base can be handled as a 0-1 integer programming problem, and the calculation time can be shortened.
- FIG. 8 is a fifth diagram illustrating the second space-time network model according to the delivery plan in the first embodiment of the present invention.
- FIG. 8 shows the first space-time network model illustrated in FIG. 3 using the second space-time network model.
- the point set represented by the column of the parking lot A in FIG. 3 is further subdivided into (1, 0, 0, 0), (1, a, 0, 0), (1, a, 1, 0) is represented by a point set in each column.
- Each of the center and parking lots A to C is given a point set corresponding to the entrance / exit.
- ⁇ Delivery plan generation method based on second space-time network model> As described above, as a countermeasure against the high-speed processing in the second spatio-temporal network model, it has been explained that the delivery base is made a 0-1 integer programming problem. Next, a method for generating a delivery plan will be described.
- delivery means a case of delivery by delivery vehicle and bicycle (including delivery by only a delivery vehicle) and a case of delivery by truck (with delivery items loaded) will be described.
- the bicycle of the delivery means the delivery staff rides on the bicycle and moves to the delivery base where the supply is made, and then the surplus vehicles are loaded on the bicycle, and the delivery staff drives the surplus vehicles and moves to the delivery base in demand. How to use.
- the objective function will be described.
- FIG. 3 the case where cost is minimized has been described as an example.
- the case where the travel time required for delivery is minimized will be described.
- the objective function in the case of minimizing the cost for delivery is assumed to be the cost per hour for each of the deliverables, delivery vehicles, and delivery staff multiplied by the travel time.
- the objective function for minimizing the travel time required for delivery is the sum of the travel times of deliveries, delivery vehicles, and delivery staff.
- Flow rate of delivery vehicles At the time of delivery start, the flow rate from the road where delivery vehicles exist is equal to the number of delivery vehicles. At the time of completion of delivery, the flow rate entering the road where the delivery vehicle exists is equal to the number of delivery vehicles. In other respects, the outgoing flow rate and the incoming flow rate are equal. (3) Flow rate of delivery staff At the start of delivery, the flow rate from the road where the delivery staff exists is equal to the number of delivery staff members. At the time of completion of delivery, the flow rate entering the road where the delivery staff exists is equal to the number of delivery staff. In other respects, the outgoing flow rate and the incoming flow rate are equal. 2. Capacity constraint The amount of deliveries and people moving within the delivery base is 1 or less.
- a constraint expression called cut can be applied.
- an inequality that can be satisfied by a feasible region point is called a valid inequality. Since the integer programming problem is difficult to solve, it is often handled as a linear relaxation problem excluding the integer condition. Adding a reasonable inequality that reduces the solution space of a linear relaxation problem is called adding a cut. By adding a cut, the linear relaxation solution approaches an integer optimal solution, which has a powerful effect on speeding up the calculation. Since the feasible region is not cut by adding the cut, the optimality of the solution is guaranteed. For example, a cut that stipulates that one or more delivery vehicles come is added.
- the inside of the delivery base can be modeled as a 0-1 integer programming problem. Therefore, in addition to the effect when the delivery plan is generated using the first spatiotemporal network, the calculation of the delivery plan is performed. It is possible to reduce the time required for the process. Furthermore, the calculation time can be significantly shortened by adding a cut. Thereby, for example, it is possible to compare delivery plans generated under various initial conditions and to select a delivery plan at a lower cost, thereby improving the convenience of the planner.
- FIG. 9 is a diagram showing an example of a delivery problem in the first embodiment of the present invention.
- FIG. 10 is a diagram illustrating an example of a delivery plan generated for a delivery problem.
- a point c0 (depot) in FIG. 9 is a starting point.
- the other points w1 to w9 are delivery bases. For example, “d1: 2” at the point w7 indicates a state in which two delivery items d1 are left, and “d2: ⁇ 1” at the point w5 indicates that one delivery item d2 is insufficient. It shows the state.
- the point “d1: ⁇ 1, d2: 1” at the point w2 indicates that one delivery item d1 is insufficient and one delivery item d2 is left.
- Input / depot includes 1 delivery vehicle, 3 bicycles, 3 delivery staff, delivery deadline: 120 minutes, delivery vehicle cost: 1.5 yen / minute, delivery staff Cost: 17 yen / min ⁇ d1, d2, d3 cost: 1.5 yen / min ⁇ Number of passengers in delivery vehicle: 4 people, Bicycle capacity: 1 vehicle ⁇ D1 passenger capacity: 1 person , Number of bicycles that can be loaded: 0 • Number of people that can be boarded in d2: 4 people, Number of bicycles that can be loaded: 1 unit • Number of people that can be boarded in d3: 2 people, Number of bicycles that can be loaded: 0 (2) Objective function Cost minimization
- the generation of a delivery plan using the first spatiotemporal network or the second spatiotemporal network by the delivery planning device 10 can also be applied to delivery, procurement, and after-service patrol of deliverables that can be boarded and transported.
- the after-sales service it is necessary to provide the service by procuring parts necessary for the after-sales service and then heading to the customer or traveling to a plurality of customers.
- Products that are used for after-sales service such as parts that use the delivered goods for after-sales service, such as delivery vehicles necessary for transporting vehicles and parts that are used for transportation by the service person and the delivery means that the service person uses for transportation, etc.
- the above mathematical model can be applied to solve the integer programming problem, and when a service person performs after-sales service at multiple customers, a traveling method that minimizes the traveling cost and traveling time ( (Traveling means, travel route) can be calculated.
- Travel means travel route
- FIG. 2 parking lots A to C (delivery bases), customers who provide after-sales service, vehicles (delivery items) are parts, passenger cars (delivery means) are means for use by a serviceman, A delivery person (delivery subject) may be a service person.
- after-sales service not only patrol the customer, but also work such as inspection and repair at the customer.
- the delivery planning apparatuses 10, 10 ⁇ / b> A, and 10 ⁇ / b> B using the spatio-temporal network model it is possible to model the traveling behavior of the service person taking these work times into consideration.
- the present invention can also be applied to delivery of deliveries that are not boarded and transported.
- milk run means that when a manufacturer of a product purchases raw materials and parts used for the product from multiple suppliers, the manufacturer visits each supplier and collects the raw materials, etc., instead of bringing them into each supplier. It is a procurement method.
- collecting by a milk run for example, by collecting with one truck, it is possible to reduce costs, reduce traffic congestion around the factory, and reduce environmental load compared with the case of delivering to each supplier.
- a factory of a product manufacturer's delivery destination is a delivery base with demand in car sharing, a factory of a supplier of raw materials and parts, etc. Is a delivery base where vehicles are left over
- a delivery plan can be calculated by setting the same objective function, constraint conditions, and the like as in the case of “delivery by truck” described above.
- the restriction condition that “the total volume of delivered items must be less than or equal to the load capacity of the truck” when delivering by the above-mentioned truck “(Raw material weight ⁇ Raw material amount + Part weight ⁇ Number of parts)” To be less than the load capacity ”.
- a collection time frame of a certain supplier When a collection time frame of a certain supplier is designated, it can be dealt with by adding information of the designated collection time frame to the constraint condition. For example, if the arrival time at a certain supplier must be 30 minutes later (from the start of the collection), the following constraints can be added to generate a collection plan that complies with the time frame constraints of the supplier. be able to. Arrival time at a supplier ⁇ 30 minutes later
- the delivery planning device 10 can obtain a strict optimum solution for the delivery problem.
- the first area dividing unit 14 divides the delivery base for each delivery area, and divides the given delivery problem into delivery problems for each divided area.
- an area division process (first area division process) by the first area division unit 14 will be described.
- FIG. 11 is a first diagram illustrating the first area division processing in the first embodiment of the present invention.
- the left diagram of FIG. 11 shows the positions of the delivery base and the departure base that exist in the area targeted for the delivery plan.
- circles indicate delivery bases (w1 to w17), and square points indicate departure bases (c1 to c3).
- the delivery bases w1 to w17 have a demand or surplus of deliverables, and the departure bases c1 to c3 have delivery vehicles and delivery staff.
- the first area dividing unit 14 generates a set in which a delivery base (demand point) in demand in the vicinity and a delivery base (supply point) in surplus are associated with each other, and further sets a pair of demand point and supply point.
- One or a plurality of collected areas are divided into one area.
- the area generation by the first area dividing unit 14 is referred to as a first area dividing process.
- the right figure of FIG. 11 shows the result of the first area dividing unit 14 performing the first area dividing process.
- Delivery bases w1 to w5 belong to area j1
- delivery bases w6 to w9 belong to area j2
- delivery bases w10 to w17 belong to area j3.
- the delivery plan generating unit 12 generates a delivery plan for each of the divided areas j1 to j3 by the above method.
- Each of the areas j1 to j3 includes less than 10 delivery bases and is relatively small. Therefore, the delivery plan generation unit 12 can generate a delivery plan in a practical time using the above-described space-time network model.
- the first area dividing unit 14 divides the delivery bases w1 to w17 into demand points, supply points, and delivery bases that are neither demand points nor supply points.
- the 1st area division part 14 matches a demand point and a supply point 1: 1.
- the first area dividing unit 14 associates the demand points and the supply points that are close to each other (movement time).
- the delivery base w4 in FIG. 11 has less than one delivery item d1, and the delivery base w5 does not have one delivery item d1.
- the first area dividing unit 14 associates the delivery bases whose supply and demand are the same and whose distance is short. That is, the first area dividing unit 14 associates the delivery base w4 and the delivery base w5 (set 1), associates the delivery base w6 and the delivery base w7 (sets 2), and sets the delivery base w8.
- the delivery base w9 is associated (set 3). The other demand points and supply points are similarly associated.
- the first area dividing unit 14 generates a single area by collecting a plurality of pairs having close distances with respect to the associated pairs of demand points and supply points. At this time, if there is no other group with a short distance, one group may be used as one area. For example, in the case of the example given above, the first area dividing unit 14 calculates the distance between the delivery base w4 of the set 1 and the delivery base w6 of the set 2. If the calculated distance is smaller than the predetermined threshold, the group 1 and the group 2 are classified into the same area, and if the calculated distance is larger than the predetermined threshold, the group 1 and the group 2 are determined as different areas. .
- the distance between the delivery base w4 and the delivery base w7 may be calculated, or between the delivery base w4 and the delivery base w6.
- the distances between w4 and delivery base w7, between delivery base w5 and delivery base w6, and between delivery base w5 and delivery base w7 may be calculated, and the average of the calculated distances may be used as the distance between pair 1 and pair 2.
- the longest (or smallest) distance among the calculated distances may be set as the distance between the set 1 and the set 2. In the case of the example in FIG.
- the first area dividing unit 14 classifies the group 2 and the group 3 into the same area j2, and classifies the group 1 into another area j1.
- the first area division unit 14 performs the same processing for other delivery bases, classifies the delivery bases w1 to w17 for each area, and generates areas j1 to j3 shown in FIG.
- the delivery plan generating unit 12 sets the supply quantity, the demand quantity, etc. of the delivery items at each delivery base in each area as initial conditions for each of the areas j1 to j3.
- the delivery plan may be generated using the first spatiotemporal network model or the second spatiotemporal network model, but the calculation using the spatiotemporal network model is performed from the very initial state. Even if it does not perform, the correlation of the demand point and supply point in the case of the 1st area division
- the first area dividing unit 14 performs a process of adding a delivery route that may be selected when the delivery plan generating unit 12 generates branch information. Then, the delivery plan generation unit 12 selects an appropriate delivery route from all candidate delivery routes including a delivery route that may be selected and added to the delivery route that connects the nearest delivery bases that satisfy the demand and supply. Branch information is generated by selecting a proper delivery route, and a delivery plan for each area is created.
- the demand point and the supply point have been described as the delivery bases. However, the demand point and the supply port may be used.
- FIG. 12 is a second diagram illustrating the first area division processing in the first embodiment of the present invention.
- Delivery routes e 11 to e 19 are created from A to B, and a cost function c (e) is defined based on the travel time when delivery is performed for each delivery route via the route indicated by the delivery route. 4).
- a delivery route is created from s to A and from B to t, and their cost is set to zero.
- a set of delivery routes from s to A and B to t is E 2, and a union of E 1 and E 2 is E. 5).
- the bipartite graph G (V, E) is configured by the processing so far. 6).
- a minimum weight maximum matching of G, that is, a route from s to t that minimizes the cost is calculated.
- the condition is that the number of delivery routes coming from each supply point included in the set A is 1, and the number of delivery routes entering each demand point included in the set B is 1.
- the distribution route is calculated when the total cost of the distribution route connecting s, each supply point of set A, each demand point of set B, and t is the minimum (main problem). 4). Since the cost from s to each supply point in set A and the cost from each demand point in set B to t are 0, supply point a1 to supply point a3 and demand point b1 to demand when the cost is minimum It is possible to determine how to associate with the point b3.
- a one-to-one matching between the supply point and the demand point with the shortest distance can be obtained.
- a combination of a delivery route e 11 linking a1 and b1, a delivery route e 16 linking a2 and b3, and a delivery route e 18 linking a3 and b2 has a minimum cost.
- a1 and b1, a2 and b3, and a3 and b2 are associated one-to-one. 7).
- all ports are divided by area so that the two associated ports are included in the same area.
- the area is classified into one area.
- a1 and b1 are one area (j4)
- a2 and b3, and a3 and b2 are one area (j5).
- the delivery plan generation unit 12 When the first area division processing is completed, the delivery plan generation unit 12 generates a delivery plan for each divided area. At that time, the delivery plan generation unit 12 generates a delivery plan that satisfies the conditions using the delivery route candidates obtained by the first area division processing. Specifically, in addition to the above-mentioned “1. Flow conservation rule” to “6. Restrictions on branches remaining in the delivery base”, the delivery route candidates (e 11 , e obtained by the first area division processing) 16 , e 18 , e 19 ) is used as a constraint, and a set of branch information is calculated.
- FIG. 13 is a flowchart showing an example of a delivery plan generation process in the first embodiment of the present invention.
- the delivery staff who performs the delivery plan inputs the initial conditions of the delivery plan to the delivery plan device 10.
- the input / output unit 13 receives the input, and outputs the received information to the initial condition setting unit 11.
- the initial condition setting unit 11 acquires information on initial conditions input by the delivery staff (step S11).
- the initial condition setting unit 11 sets the acquired initial condition information as the initial condition of the delivery plan.
- the initial conditions are, for example, the supply quantity (remaining quantity) at each base, demand quantity (shortage quantity), the number of delivery vehicles at the departure base, the number of delivery staff, and between each base.
- the first area dividing unit 14 performs a first area dividing process using the supply quantity and the demand quantity of the deliverables at each delivery base (or port) included in the initial condition information (step S12). .
- the first area division processing is as described with reference to FIGS.
- the delivery plan generation unit 12 sets branch information so as to satisfy the above-described constraint conditions on the spatiotemporal network model illustrated in FIG. 3 and FIG.
- a plurality of sets of branch information that are generated and satisfy the conditions such as the delivery deadline are generated (step S13).
- the delivery plan generation unit 12 adds information on the quantity of deliverables, the number of delivery vehicles, and the number of delivery staff to the delivery route candidates obtained by the first area division processing, and sets each constraint condition.
- Branch information satisfying (“1. Flow conservation law” to “6. Restrictions on branches staying in the delivery base”) is generated.
- the delivery plan generation unit 12 generates a plurality of sets of branch information indicating delivery that satisfies the demand quantity of each base by the delivery deadline by combining the generated branch information.
- the delivery plan generation unit 12 calculates the total cost for each set of generated branch information for each area (step S14). For example, the unit cost generated per unit time for each delivery vehicle, delivery staff, and delivery item is recorded in the storage unit 15 in advance, and the delivery plan generation unit 12 determines the unit cost of the delivery vehicle, delivery staff, and delivery item. Multiply the time indicated by each branch to calculate the cost for each branch (sum of costs for delivery vehicles, delivery staff, and delivery items). The delivery plan generation unit 12 calculates the cost for each branch included in the set of branch information and totals them. The total cost is the cost for one set of branch information. The delivery plan generator 12 calculates the cost for each set of all branch information for each area.
- the delivery plan generation unit 12 compares the calculated costs for each calculated set for each area, and selects a set of branch information that minimizes the total cost (step S15).
- the set of selected branch information represents the movement of delivery items, delivery means, and delivery staff over time from the state of the departure base and each delivery base indicated by the initial conditions (FIGS. 3 and 8). Therefore, if delivery is executed based on a set of branch information, delivery according to demand from the user becomes possible. That is, this set of branch information is a delivery plan to be obtained for one divided area.
- the delivery plan generating unit 12 finishes generating the delivery plan for each area, the delivery plan for all the delivery bases given as the initial conditions is generated.
- the size of the delivery problem can be reduced by dividing the entire delivery base given by the initial condition into a set (area) of delivery bases at a short distance. It is possible to reduce the calculation amount of the generation process of the delivery plan. Since the delivery route candidates are calculated when the area is divided, and the branch information is generated by selecting the delivery route from these candidates, the amount of calculation can be further reduced. As a result, even when the number of deliverables and delivery bases is large and the delivery problem becomes large-scale, a delivery plan can be generated in a practical time (for example, 10 minutes).
- the delivery plan generation unit 12 may generate branch information without using a delivery route candidate in step S13 to generate a delivery plan.
- the area may be reconfigured in consideration of the cost of the area delivery plan. For example, for a pair of areas where the difference in delivery costs is significantly distant, the overall cost can be reduced by increasing the area where delivery is completed earlier and reducing the area where delivery is completed later There is.
- a delivery plan system for generating a delivery plan for a large-scale delivery problem in a practical time will be described with reference to FIGS.
- first embodiment attention is paid to demand points and supply points that are relatively close to each other, and a pair of demand points and supply points are collected to generate a small area.
- second embodiment area division processing is performed centering on the departure base, and a delivery plan is generated in each divided area.
- the area division process in the second embodiment is referred to as a second area division process.
- FIG. 14 is a functional block diagram showing an example of a delivery plan system in the second embodiment of the present invention.
- the delivery planning apparatus 10A according to the second embodiment includes a second area dividing unit 16 instead of the first area dividing unit 14 in the configuration of the first embodiment.
- the second area division unit 16 departs from the departure base, performs delivery related to some delivery bases, and returns to the original departure base, and the cost of delivery using the delivery route.
- the second area dividing unit 16 selects a combination in which the number of delivery bases included in the combination is within a predetermined number and the cost is minimum, from among a plurality of combinations of unit route information.
- a set of departure bases and delivery bases included in this unit route information combination is an area after division.
- the second area dividing unit 16 is realized by the CPU included in the delivery planning apparatus 10 ⁇ / b> A reading out the program from the storage unit 15 and executing it.
- FIG. 15 is a first diagram illustrating a second area division process for a delivery problem in the second embodiment of the present invention.
- circles indicate delivery bases w1 to w17
- square points indicate departure bases c1 to c3.
- first, all possible demand / supply patterns are listed, and a number of simple delivery routes satisfying the demand / supply of each pattern are created for each departure base.
- a sufficient amount of delivery vehicles (trucks) and delivery staff exist at the departure bases c1 to c3, and the delivery bases w1, w3, w6, w8, and w10 are the supply points, the delivery bases w2, and so on.
- w5, w7, w9, and w11 are demand points.
- a simple delivery route that satisfies the demand and supply for each departure base is, for example, starting from the departure base c1 to the delivery base w1 (R1), taking a delivery item at the delivery base w1, and sending it to the delivery base w2.
- This is a delivery route (referred to as delivery route 1) that carries the delivery (R2) and returns to the departure point c1 when delivery is completed (R3).
- the route from the departure point c1 to the departure point c1 via the delivery point w3 and the delivery point w5 (referred to as the delivery route 2), the departure point c1 to the departure point c6 via the delivery point w6 and the delivery point w7.
- a delivery route (referred to as delivery route 3), a delivery route (referred to as delivery route 4) returning from the departure location c2 to the departure location c2 via the delivery location w8, a delivery location w9, a delivery location w10 from the departure location c3,
- a large number of these simple routes are created in advance and recorded in the storage unit 15.
- the following route is also created and recorded in the storage unit 15 in advance. From the departure base c1 to the delivery route back to the departure base c1 via the delivery base w1 and the delivery base w5, from the departure base c1 to the departure base c1 via the delivery base w1 and the delivery base w7, from the departure base c1 A delivery route returning to the departure base c1 via the delivery base w3 and the delivery base w2, a delivery route returning from the departure base c1 to the departure base c1 via the delivery base w10 and the delivery base w11, and a delivery base w1 from the departure base c2. A delivery route returning to the departure base c2 via the delivery base w2, a delivery route returning from the departure base c3 to the departure base c3 via the delivery base w1 and the delivery base w2.
- a simple delivery route refers only to a delivery route that returns to the original departure point via one supply point and one demand point (a route that circulates two delivery points and returns to the original departure point). Instead, the delivery route starts from the departure base c1, takes two deliveries at the delivery base w1, and delivers the deliveries to the delivery base w2 and the delivery base w4 one by one and returns to the departure base c1. Good (example of three delivery bases). Alternatively, the vehicle departs from the departure base c1, picks up one delivery at the delivery base w1, delivers it to the delivery base w2, and then picks up one delivery at the delivery base w3 and delivers it to the delivery base w4. It may be a delivery route that returns (example of four delivery bases).
- FIG. 16 is a second diagram for explaining the second area division processing of the delivery problem in the second embodiment of the present invention.
- the storage unit 15 stores a plurality of simple delivery routes prepared in advance.
- the cost for delivery using the delivery route is recorded.
- the cost is given as a function of travel time, for example.
- the more pre-recorded simple delivery route and cost information the more accurate the delivery plan (close to the exact optimal solution) can be generated.
- Information including a simple delivery route illustrated in FIG. 16 and a cost corresponding to the delivery route is referred to as unit route information.
- FIG. 17 is a third diagram for explaining the second area division processing of the delivery problem in the second embodiment of the present invention.
- the unit route information illustrated in FIG. 16 is recorded in the storage unit 15. Assume that initial conditions for delivery requirements (demand quantity for each delivery base, supply quantity, number of delivery vehicles at the departure base, number of delivery staff, etc.) are given. 1. First, the second area dividing unit 16 reads out unit route information including a delivery route that satisfies a part of the delivery request (demand) given by the initial condition from the storage unit 15. 2.
- the second area dividing unit 16 creates a route that satisfies all the delivery requests by combining the delivery routes included in the read unit route information and sets it as a provisional solution.
- a mathematical method called a set partitioning approach is used as a method for finding a combination that satisfies all the requirements and has the lowest cost by combining simple delivery routes recorded in advance.
- the second area dividing unit 16 generates an initial solution using a small number of delivery routes among many simple delivery routes stored in the storage unit 15, and uses a mathematical method called a column generation method. Find the optimal solution while adding a simple delivery route.
- a few simple delivery routes for generating the initial solution may be selected in any way.
- a generally provided solver can be used.
- a restriction for example, within 6 bases including a demand point and a supply point
- the restriction (upper limit) is set on the number of delivery bases in order to reduce the calculation amount and speed up the processing.
- the number of delivery bases to be restricted for example, an actual calculation may be performed and the number of delivery bases when a solution is obtained within a practical time may be set as an upper limit.
- the initial solution for example, the solutions (delivery route 1 to delivery route 5) shown in FIG. 15 are obtained.
- the second area dividing unit 16 selects one or a plurality of delivery routes from among unselected simple delivery routes by a sequence generation method (a well-known mathematical method), and some simple delivery that has already been selected. Calculate the reduction cost when replacing the route with the selected simple delivery route.
- the reduced cost is the original simple delivery selected before replacement from the sum of the costs recorded in association with the simple delivery route newly selected as a solution by replacement (cost column in FIG. 16). It is a value obtained by subtracting the total cost recorded in association with the route.
- the second area dividing unit 16 includes: 2. If the reduction cost calculated in step 1 is negative (it is cheaper after replacement), Update a part of all existing delivery routes with the simple delivery route selected in. For example, regarding the delivery to the delivery base w7, the delivery route 3 is selected in the initial solution shown in FIG. 15. However, the second area dividing unit 16 replaces the delivery route 3 with the delivery base 3 from the delivery base c2. The reduction cost is calculated when the route is changed to the route (delivery route 6) that returns to the departure location c2 via w6 and the delivery location w7. According to FIG. 16, the cost of the delivery route 3 is 2500, and the cost of the delivery route 6 is 1500, so the reduction cost is ⁇ 1000.
- the second area dividing unit 16 updates the delivery route 3 with the delivery route 6.
- FIG. 17 shows a simple combination of delivery routes after updating. Also in the case of calculating the reduction cost, the second area dividing unit 16 selects a delivery route so that the number of bases handled by one departure base is within the constraints.
- a simple delivery route is moved from the assigned range of the departure point c1 to the assigned range of the departure point c3.
- the update of the delivery route is not limited to this example.
- a combination of the delivery route 1 and the delivery route 2 in the route that the departure base c1 is in charge of is a route that returns from the departure base c1 to the departure base c1 via the delivery base w3 and the delivery base w2.
- a method of updating to a combination of routes from the departure base c1 to the departure base c1 via the delivery base w1 and the delivery base w5 may be used.
- the combination of the delivery route 1 and the delivery route 2 is changed from the departure base c1 to the delivery base w1, the delivery base w2, the delivery base w3, and the delivery base w5. Then, a method of updating the delivery route back to the departure base c1 may be used.
- the second area dividing unit 16 includes: ⁇ 4. This process is repeated, and the second area division process is terminated when there is no route whose cost can be reduced.
- a delivery base within the restriction condition for example, 6 bases
- a set of a plurality of associated delivery bases and departure bases for example, each of area j6 to area j8, is an area obtained by the second area division process.
- FIG. 18 is a flowchart showing an example of delivery plan generation processing in the second embodiment of the present invention.
- the initial condition setting unit 11 acquires information on initial conditions input by a delivery staff or the like (step S11).
- the second area dividing unit 16 uses the supply quantity, the demand quantity, the number of delivery staff at the departure base, the type and number of delivery vehicles included in the initial condition information, A two-area division process is performed (step S121).
- the second area division processing is as described with reference to FIGS.
- the delivery plan generation unit 12 performs the following operation for each area obtained by the second area division process (a set of a plurality of delivery bases associated with the departure base and the departure base obtained by the second area division process).
- branch information is generated so as to satisfy the above constraint conditions, and a plurality of sets of branch information satisfying conditions such as delivery deadlines are generated (step S131).
- the delivery plan generation unit 12 generates a plurality of sets of branch information for each of the areas j6 to j8.
- the delivery plan generation unit 12 may generate the branch information regardless of the simple delivery route and the combination used in the second area division process, or the branch plan information may be generated using the simple delivery route and the combination thereof. Generation may be performed.
- generation part 12 calculates a total cost for every set of produced
- the delivery plan generating unit 12 calculates the total cost for each set of generated branch information for each of the areas j6 to j8.
- the delivery plan generation unit 12 compares the calculated total costs, and selects a set of branch information that minimizes the total costs (step S15).
- the delivery plan generating unit 12 selects a set of branch information that minimizes the total cost for each of the areas j6 to j8.
- the set of selected branch information indicates a delivery plan in each area. That is, when the delivery plan generation unit 12 finishes generating the delivery plan for each area, the delivery plan for all the delivery bases before the division is generated.
- each delivery base for each departure base by associating each of the delivery bases with the demand and supply given in the initial conditions with the departure base.
- a delivery plan is created for all delivery bases with demand given in the initial conditions by dividing the delivery area into smaller areas and generating a delivery plan for each delivery area.
- the amount of calculation required for generating a delivery plan can be reduced. Thereby, even when the number of deliverables and delivery bases is large and the delivery problem becomes large-scale, a delivery plan can be made in a practical time (for example, 10 minutes).
- a delivery plan system for generating a delivery plan in a practical time for a large-scale delivery problem will be described with reference to FIGS.
- the distribution problem is divided into small-scale distribution problems by spatially dividing (area division) based on the supply and demand information for each distribution base included in the initial conditions. It was a method that realized high-speed processing by solving a small-scale delivery problem.
- the delivery problem is subdivided by time division based on the information on the delivery time limit of the delivery included in the initial condition, and a delivery plan is generated for each time after division.
- FIG. 19 is a functional block diagram showing an example of a delivery plan system in the third embodiment of the present invention.
- the delivery planning apparatus 10B according to the third embodiment includes a time division unit 17 instead of the first area division unit 14 in the configuration of the first embodiment.
- the delivery plan apparatus 10B includes a delivery plan generation unit 12a instead of the delivery plan generation unit 12.
- the time division unit 17 divides the delivery restriction time given in the initial condition into a plurality of times, thereby dividing the delivery problem into smaller delivery problems for each time.
- the delivery plan generation unit 12a generates a delivery plan by solving a delivery problem in which different objective functions and constraints are set according to the section formed by the time division unit 17. For example, the delivery plan generation unit 12a starts delivery from the delivery status (delivery progress when the previous segment is finished) at the first time of each segment after the division, A delivery plan is generated so that the delivery items are delivered to a delivery base in demand as much as possible. For the last section of the divided sections, the time division unit 17 selects all the delivery bases that have not been delivered among the delivery bases in demand indicated by the initial conditions in the last section. A delivery plan for delivering the delivery to is generated. The time division unit 17 and the delivery plan generation unit 12a are realized by the CPU included in the delivery plan apparatus 10B reading out and executing the program from the storage unit 15.
- FIG. 20 is a first diagram illustrating a time division process for a delivery problem in the third embodiment of the present invention.
- the left diagram in FIG. 20 shows an initial state of a delivery problem.
- the delivery base w1 has two extra items d1 and the delivery base w2 has three extra items d1.
- At delivery base w3, four deliveries d1 are insufficient, and at delivery base w4, one delivery d1 is missing.
- the delivery base w1 to the delivery base w4 are divided for each area. In this embodiment, the delivery limit time of 120 minutes given as the initial condition is divided.
- the time division unit 17 divides the delivery limit time of 120 minutes into a plurality of times (sections). For example, the time division unit 17 divides the delivery limit time 120 minutes into two sections of the first half 60 minutes and the second half 60 minutes.
- the time length of one section and the number of sections that can be divided by the time dividing unit 17 may be arbitrary.
- the time division unit 17 may divide 120 minutes into 90 minutes and 30 minutes, or classify them into three sections every 40 minutes.
- the time division unit 17 may set a time shorter than a delivery limit time given by the initial condition by a predetermined time as the first section after the division and the remaining time as the last section.
- the right diagram in FIG. 20 shows that the time dividing unit 17 has divided the delivery limit time 120 minutes into two sections each having 60 minutes.
- the delivery plan generating unit 12a When the time dividing unit 17 divides the delivery time limit, the delivery plan generating unit 12a generates a delivery plan for the first section generated by the division. At this time, the delivery plan generating unit 12a does not aim to satisfy all requests, but generates a delivery plan that can satisfy as many requests as possible at the end of the first section. In this example, aiming to satisfy all the requirements is to deliver the delivery d1 in 60 minutes so as to satisfy the demand quantity of the delivery base w3 and the delivery base w4.
- a delivery plan that can satisfy as many requests as possible is, for example, that there are three shortages of deliveries d1 at the delivery base w3 and shortages of deliveries d1 at the delivery base w4 60 minutes after the start of delivery.
- the latter delivery plan That means.
- the objective function and constraints set for the first section will be described. More generally, the objective function and the like to be described next are, when the time dividing unit 17 divides the delivery limit time into N pieces, all sections (time intervals) except for the last section (Nth section). The objective function and the like used for the first section to the (N-1) th section in order along the flow.
- Port number to supply when meeting demand Demand is reduced by prompting supply from a lower numbered port (even if there is no problem even if it is delivered to a higher numbered port, the lowest numbered port This can reduce the choice of solutions and the amount of calculation.)
- Number of people and delivery means that are not used in later sections (g [w]) At the last time of the section being calculated, it is urged to move an extra person / delivery means that is not used for delivery in the next section to the departure point. For example, at the last time of the first section, if there is no delivery means that can move on a bicycle, the bicycle is not used for delivery in the second section, so it is moved to the departure point.
- the delivery plan is calculated independently for each section that has been time-divided (the delivery status in the previous section is taken over), so extra delivery staff not used in the subsequent section It is also possible that the delivery means remain at the delivery base. Therefore, (4) and (5) are added to prevent extra delivery staff from remaining at the delivery base.
- the objective function is expressed as minimizing the sum of the functions corresponding to the contents of the items (1) to (7).
- An arbitrary coefficient is assigned to each term of the objective function (the function of each item). Weighting may be performed by multiplication.
- the flow rate from the road is the number of delivery staff members present at the base.
- the flow rate entering the road is the number of delivery staff in demand at the base.
- the outgoing flow rate and the incoming flow rate are equal.
- Capacity constraint The amount of deliveries and people moving within the delivery base is 1 or less.
- Restrictions on branches staying in the delivery base Restrictions are placed on the fact that cars must be on board, bicycles cannot be parked, and the total volume of deliveries is less than the load capacity of the truck.
- the delivery plan generator 12a solves the delivery problem (integer planning problem) formulated with these objective functions and constraints using the first or second spatiotemporal network. In actual calculations, a cut may be added to further increase the speed.
- the right diagram of FIG. 20 shows an example of a result of the delivery plan generation unit 12a generating a delivery plan for the first section. According to this plan, after 60 minutes from the start of delivery, the delivery base w1 and the delivery base w2 have one more delivery item d1, and the delivery base w3 has two delivery items d1 that are insufficient. It can be seen that at w4, the shortage of the delivery item d1 is resolved.
- FIG. 20 shows an example in which both the number of delivery bases and the number of deliverables are small.
- the number of variables can be reduced to 14000 and the number of constraints to about 18000, for example.
- FIG. 21 is a second diagram illustrating the time division processing for the delivery problem in the third embodiment of the present invention.
- FIG. 21 shows a delivery plan generation process performed using the latter half 60 minutes after the division.
- the demand quantity and supply quantity at each delivery base at the start of the second half 60 minutes will be organized.
- the delivery item d1 is more than one, and the delivery point w3 is short of two delivery items d1.
- the delivery plan that the delivery plan generating unit 12a must generate using the latter half 60 minutes satisfies the demand at the delivery base w3 for the delivery items d1 of the delivery base w1 and the delivery base w2 within the remaining 60 minutes.
- the shortage of the delivery base w4 has been resolved in the first half 60 minutes, so it is not included in the delivery problem for the second half 60 minutes.
- the objective function and restrictions set for the delivery problem for the last section when the delivery time limit is divided into N will be described.
- the objective functions and constraints in this case are the same as those described using the first spatiotemporal network model (FIG. 3) and the second spatiotemporal network model (FIG. 8).
- the delivery plan generation unit 12a minimizes the cost and the travel time required for delivery among the delivery plans that finish delivering deliveries so as to satisfy all demands by the last time of the last section. Is generated.
- the advantages of the latter half of 60 minutes are as follows: First, as with the first half 60 minutes, the delivery limit time is set to 60 minutes, thereby reducing the number of parameters and the amount of calculation. The point which can speed up a process can be mentioned. Furthermore, because the remaining demand is reduced by a delivery plan that satisfies as many requests as possible calculated in each section up to the last section, the size of the delivery problem that must be solved is reduced. Can be mentioned. For example, in the examples shown in FIGS. 20 and 21, not only the demand quantity at each demand point is reduced, but also the demand at the delivery base w4 is satisfied, so that the number of delivery bases is successfully reduced. This further reduces the size of the delivery problem.
- the number of variables is 8000 and the number of constraints is 12000.
- the size of the delivery problem in the subsequent section can be reduced by the reduction of the parameters due to the time division and the delivery plan generated in the previous section in terms of time.
- the generation process of the delivery plan can be speeded up. Since the third embodiment does not divide the area, the delivery plan can be generated while ensuring the globality of the distribution base distribution as compared with the first embodiment and the second embodiment, and a more optimized delivery plan. Can be generated.
- FIG. 22 is a flowchart showing an example of delivery plan generation processing in the third embodiment of the present invention. Processing similar to that in FIGS. 13 and 18 will be briefly described.
- the delivery staff who performs the delivery plan inputs the initial conditions of the delivery plan to the delivery plan device 10B.
- the input / output unit 13 receives the input, and outputs the received information to the initial condition setting unit 11.
- the initial condition setting unit 11 acquires information on initial conditions input by the delivery staff (step S11).
- the time division unit 17 performs a time division process using the delivery time limit included in the initial condition information (step S122). The time division processing is as described with reference to FIG.
- the time division unit 17 divides the delivery limit time of the initial condition into two or three.
- the time division unit 17 sets the time unit (for example, 75 minutes) according to the user setting. ) May be used to divide the original delivery time limit and the remaining time may be the last section.
- the time division unit 17 may set a time shorter than the delivery limit time given by the initial condition by a predetermined time as the first section after the division and the remaining time as the last section.
- generation part 12a produces
- the delivery plan generating unit 12a sets 1 to the counter variable n (step S123).
- generation part 12a sets the delivery problem of the nth area (step S124).
- the delivery plan generation unit 12a includes the demand quantity and supply quantity of each delivery base included in the initial condition information, the quantity of delivery means existing at the departure base, the number of delivery staff, Using the time of the second interval as a delivery time limit, we formulate an integer programming problem with objective functions and constraints for generating a delivery plan that satisfies as many requests as possible and has the lowest cost.
- the delivery plan generation unit 12a uses the first or second spatio-temporal network model illustrated in FIG. 3 or FIG. 8 for the formulated integer programming problem, and satisfies each constraint while delivering each delivery.
- a plurality of sets of branch information that satisfy the demand of the base as much as possible are generated (step S132).
- generation part 12a calculates a total cost for every set of produced
- the delivery plan generation unit 12a compares the calculated total costs, and selects a set of branch information that minimizes the total costs (step S15). As a result, a delivery plan for the nth (this time the first) section is generated.
- the delivery plan generation unit 12a determines whether n is equal to N (step S16). When n is equal to N (step S16; Yes), since the delivery plan for all the sections after the division is generated, the delivery plan generation process is terminated. When n is not equal to N (step S16; No), the delivery plan generating unit 12a adds 1 to n (step S17), and repeats the processing from step S124.
- the delivery plan generating unit 12a performs the delivery plan generated as a result of executing the delivery plan generated for the first section in step S124.
- An integer programming problem is formulated using the demand quantity, supply quantity, quantity of delivery means existing at the departure base, number of delivery staffs, and time of the second section as delivery time limits.
- the delivery plan generation unit 12a formulates an integer programming problem with objective functions and constraints for generating a delivery plan that satisfies all requirements (first embodiment, second implementation). Objective function similar to form).
- the delivery plan generator 12a formulates an integer programming problem with objective functions and constraints for generating a delivery plan that can satisfy as many requests as possible.
- the delivery plan generating unit 12a solves the integer planning problem and generates a delivery plan for the nth section.
- the delivery plan generation unit 12a repeats the processing from step S124 to step S17 until a delivery plan is generated for all sections (until n becomes equal to N).
- the entire delivery plan generated in order for each of the first to Nth (last) sections is a delivery plan that satisfies the request given by the initial condition.
- the delivery limit time initially given as the initial condition is divided into several sections.
- the delivery plan process may be configured as follows. 1. First, a section (first delivery limit time) shorter than the delivery limit time given in the initial condition is set, and a delivery plan that can be delivered as much as possible and cheaply within the section is generated. 2. Next, for deliverables that cannot be delivered within the first delivery time limit, a section with a predetermined length (second delivery time limit) following the first delivery time limit is set, and within the set section A delivery plan for delivering as many deliveries as possible is generated. 3.1. ⁇ 2. This step is repeated while the total length of the section from the start of delivery does not exceed the delivery time limit.
- the length of the first section or the section to be extended may be arbitrarily set according to the delivery status. 4). If the total time from the start of delivery is likely to exceed the delivery limit time, the next section will be the last, within the last section (the time when the delivery plan generated immediately before will be the start time, the first delivery limit A delivery plan is generated so that all demands are satisfied and the cost is minimized within a time period in which the delivery limit time included in the initial condition elapses with respect to the start time of time as the end time.
- a suboptimal solution (strictly accurate) is obtained in a practical time (within 10 minutes) for a delivery problem with 20 delivery bases and 20 deliveries.
- the difference in the value of the objective function was 10% or less compared to the optimal solution).
- the delivery plan generation method of this embodiment can also be used in the following situations. For example, when all vehicles must be delivered to a demanding parking lot in 120 minutes, a delivery plan is first generated for the first 60 minutes. When the delivery plan is generated, the vehicle delivery is actually started based on the delivery plan. While delivering the vehicle, a delivery plan for the remaining 60 minutes is generated. In this way, by performing the delivery plan generation process and the delivery in parallel, time can be used effectively, for example, at a site where a car sharing service is provided.
- Each process in the delivery planning apparatuses 10, 10A, and 10B described above is stored in a computer-readable recording medium in the form of a program, and this program is read and executed by the computer of the delivery planning system. Processing is performed.
- the computer-readable recording medium means a magnetic disk, a magneto-optical disk, a CD-ROM, a DVD-ROM, a semiconductor memory, or the like.
- the computer program may be distributed to the computer via a communication line, and the computer that has received the distribution may execute the program.
- the above program may be for realizing a part of the functions described above. Furthermore, what can implement
- the delivery planning apparatuses 10, 10 ⁇ / b> A, and 10 ⁇ / b> B may be configured by a single computer or may be configured by a plurality of computers that are communicably connected.
- the delivery staff is an example of a delivery subject
- a delivery vehicle, a truck, and a bicycle are examples of delivery means
- a shared vehicle in car sharing is an example of delivery.
- Each of the first area dividing unit 14, the second area dividing unit 16, and the time dividing unit 17 is an example of a dividing unit.
Landscapes
- Business, Economics & Management (AREA)
- Engineering & Computer Science (AREA)
- Economics (AREA)
- Human Resources & Organizations (AREA)
- Strategic Management (AREA)
- Physics & Mathematics (AREA)
- Entrepreneurship & Innovation (AREA)
- Marketing (AREA)
- Operations Research (AREA)
- Quality & Reliability (AREA)
- Tourism & Hospitality (AREA)
- Development Economics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Game Theory and Decision Science (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- General Factory Administration (AREA)
Abstract
配送計画システムは、配送物を需要のある配送拠点に配送する配送問題において、初期条件に含まれる配送拠点ごとの需要および供給の情報、又は、配送物の配送制限時間の情報に基づいて、初期条件が示す配送問題をより規模の小さな配送問題に分割する分割部と、分割部が分割した後の配送問題について配送計画を生成する配送計画生成部と、を備える。
Description
本発明は、配送計画システム、配送計画方法及びプログラムに関する。
本願は、2016年10月31日に、日本に出願された特願2016-213838号に基づき優先権を主張し、その内容をここに援用する。
本願は、2016年10月31日に、日本に出願された特願2016-213838号に基づき優先権を主張し、その内容をここに援用する。
カーシェアリングへのニーズが高まっている。カーシェアリングとは、例えば、会員の間などで車両を共同で利用し、搭乗時間などに応じて料金を負担し、自分の好きな時に車両を利用するシステムである。カーシェアリングの一つの形態として、乗り捨て型(ワンウェイ型)と呼ばれる利用形態が存在する。乗り捨て型のカーシェアリングでは、ユーザは、目的地近くの所定の駐車場まで共同の車両を利用し、その自動車を駐車場にそのまま乗り捨てておくことができる。このような形態のカーシェアリングでは、ユーザが利用し終えた車両を、新たな利用ニーズがある他の駐車場に配送する必要が生じる。
顧客が購入した製品に対するアフターサービスを行うために、サービスマンが客先を回る、いわゆるアフターサービス巡回の場合にも、サービスマン及びサービスの提供に必要な部品等の移動について同様の事情が生じる。例えば、複数の客先のそれぞれにアフターサービス対象となる製品が設置されており、サービスマンがその製品のアフターサービスに使う部品をある場所で調達して客先に運んだり、1回の巡回で様々な種類のアフターサービスを行うサービスマンが、サービスの提供に同じ部品を必要とするある客先から他の客先へ移動し、さらに使用後の部品を元へ戻したりといった場面で効率的な巡回方法を選択する必要が生じる。
このような問題に対し、例えば特許文献1には、複数の配送拠点から、複数の輸送手段を用いて、複数の配送先に指定された日時に荷物を輸送する輸送計画を作成する技術について開示がある。この技術を用いれば、カーシェアリングの場合、ユーザが利用する車両をトラック等の輸送手段に積載して各駐車場に輸送する輸送計画を作成することができる。アフターサービス巡回においても、サービスに用いる部品を客先に配送する配送計画を作成することができる。
しかし、カーシェアリングで車両を配送する場合、配送スタッフが配送対象の車両に搭乗し、目的の駐車場まで運転するという車両の配送方法も存在する。このように配送物自身に搭乗して配送する方法を搭乗輸送という。搭乗輸送を含む配送において、最適な配送計画を行う技術は提供されていない。
アフターサービス巡回においても、サービスマンが部品を持って移動する場合や、ある客先から他の客先へ部品を配送する場合や、余った部品をサービスマンが持って次の客先に向かう場合などについては、搭乗輸送の場合と同様に、サービスマンの最適な巡回計画を行う技術は提供されていない。
一般に離散値の組合せ最適化問題は、線形緩和と呼ばれる手法、すなわち一旦、問題を連続値問題に置き換えて解き、得られる緩和解から最適解を求める手法、を用いることが多いが、配送問題のように複雑な制約が多いとそのままでは計算時間が掛かりすぎてしまうため、実用的な時間で解くための工夫が必要となる。
アフターサービス巡回においても、サービスマンが部品を持って移動する場合や、ある客先から他の客先へ部品を配送する場合や、余った部品をサービスマンが持って次の客先に向かう場合などについては、搭乗輸送の場合と同様に、サービスマンの最適な巡回計画を行う技術は提供されていない。
一般に離散値の組合せ最適化問題は、線形緩和と呼ばれる手法、すなわち一旦、問題を連続値問題に置き換えて解き、得られる緩和解から最適解を求める手法、を用いることが多いが、配送問題のように複雑な制約が多いとそのままでは計算時間が掛かりすぎてしまうため、実用的な時間で解くための工夫が必要となる。
ところで、本願の出願人は、上記した搭乗輸送を含む配送において配送計画を行うという課題を解決することができる配送計画システムに関する出願を既に行っている(特願2016-051550)。この配送計画システムを用いると搭乗輸送を含んだ配送問題に対する最適な配送計画を、実用的な時間で求めることができる。
この配送計画システムに関し、配送対象の車両や配送先の増加により問題の規模が大きくなった場合でも、最適な配送計画を実用的な時間で求めることができるよう、計算時間のさらなる短縮化が望まれていた。
この配送計画システムに関し、配送対象の車両や配送先の増加により問題の規模が大きくなった場合でも、最適な配送計画を実用的な時間で求めることができるよう、計算時間のさらなる短縮化が望まれていた。
そこでこの発明は、上述の課題を解決することのできる配送計画システム、配送計画方法及びプログラムを提供することを目的とする。
本発明の第1の態様によれば、配送計画システムは、配送物を需要のある配送拠点に配送する配送問題において、初期条件が示す配送問題をより規模の小さな配送問題に分割する分割部と、前記分割部が分割した後の配送問題について配送計画を生成する配送計画生成部と、を備える。
大規模な配送問題を規模の小さな配送問題に分割し、小さな配送問題の単位で配送計画を算出することで、実用的な時間で配送計画を生成することができる。
大規模な配送問題を規模の小さな配送問題に分割し、小さな配送問題の単位で配送計画を算出することで、実用的な時間で配送計画を生成することができる。
本発明の第2の態様における前記分割部は、前記配送物の需要がある配送拠点群に含まれる一つの需要点と、前記配送物の供給元となる配送拠点群に含まれる一つの供給点とを、当該一つの需要点から当該一つの供給点への移動時間が最小となるように対応付け、対応付けた前記需要点および前記供給点の組み合わせの集合を生成し、前記初期条件が示す配送問題を、前記生成した集合内に含まれる需要点群から供給点群への配送問題に分割してもよい。
初期条件に含まれる配送拠点ごとの需要と供給の情報に基づいて、配送エリアを、近距離に存在する配送拠点の集合ごとの配送エリア単位に分割し、分割後の配送エリア単位で配送計画を算出することで、実用的な時間で配送計画を生成することができる。
初期条件に含まれる配送拠点ごとの需要と供給の情報に基づいて、配送エリアを、近距離に存在する配送拠点の集合ごとの配送エリア単位に分割し、分割後の配送エリア単位で配送計画を算出することで、実用的な時間で配送計画を生成することができる。
本発明の第3の態様における前記分割部は、生成した集合内に含まれる複数の供給点と複数の需要点との対応関係のうち、一つの供給点から一つの需要点への移動時間が所定の値以下となる供給点から需要点への配送ルートを計算し、前記配送計画生成部は、前記生成した集合内に含まれる供給点群から需要点群への配送ルートのうち移動時間が前記所定の閾値以下となる配送ルートを用いて、前記規模の小さな配送問題に対する配送計画を生成してもよい。
移動時間が閾値以下となる配送拠点間の配送ルートの情報を用いて配送計画を生成するので、配送計画の生成に必要な計算量を減らすことができる。
移動時間が閾値以下となる配送拠点間の配送ルートの情報を用いて配送計画を生成するので、配送計画の生成に必要な計算量を減らすことができる。
本発明の第4の態様における前記分割部は、出発拠点を出発して一部の配送拠点間に係る配送を行って前記出発拠点に戻るまでの予め設定された配送ルートとその配送ルートで配送したときのコストとを示す単位経路情報を複数取得し、前記複数の単位経路情報の組み合わせのうち、当該組み合わせに含まれる前記配送拠点の数が所定の数以内で、且つ、前記コストの合計が最小となる組み合わせを算出し、その組み合わせに含まれる出発拠点と配送拠点の集合を生成し、前記初期条件が示す配送問題を、前記生成した出発拠点と配送拠点の集合内に含まれる需要点群から供給点群への配送問題に分割してもよい。
ある出発拠点を基準に、所定の数以内の複数の配送拠点における需要を満たしつつ配送コストが最小になる配送ルートの組み合わせを算出し、それら複数の配送拠点と出発拠点の集合を1つの配送エリアとする。初期条件で与えられた全ての配送拠点を対象とする配送エリアを、このようにして生成した配送エリアに分割し、配送エリア単位で配送計画を算出することで、実用的な時間で配送計画を生成することができる。
ある出発拠点を基準に、所定の数以内の複数の配送拠点における需要を満たしつつ配送コストが最小になる配送ルートの組み合わせを算出し、それら複数の配送拠点と出発拠点の集合を1つの配送エリアとする。初期条件で与えられた全ての配送拠点を対象とする配送エリアを、このようにして生成した配送エリアに分割し、配送エリア単位で配送計画を算出することで、実用的な時間で配送計画を生成することができる。
本発明の第5の態様における前記分割部は、列生成法により、前記単位経路情報の組み合わせを算出する。
列生成法を用いることで高速に配送エリアを生成することができる。
列生成法を用いることで高速に配送エリアを生成することができる。
本発明の第6の態様における前記分割部は、前記配送物の配送制限時間を複数の時間に分割することにより前記初期条件が示す配送問題を前記分割した時間ごとの配送問題に分割し、前記配送計画生成部は、前記分割後の各時間の最初の時刻における前記配送物の配送状況から当該分割後の各時間内に前記配送物がなるべく多く需要のある拠点に配送されるような配送計画を生成してもよい。
本発明の第7の態様における前記配送計画生成部は、前記分割部が分割してできた最後の時間に係る配送問題について、前記最後の時間が終了するまでに、前記初期条件で示された需要のある配送拠点の全てに前記配送物が配送されるよう配送計画を生成してもよい。
第6、7の態様によれば、初期条件で与えられた配送制限時間を分割し、分割後の時間単位の配送問題について配送計画を算出することで、実用的な時間で配送計画を生成することができる。
第6、7の態様によれば、初期条件で与えられた配送制限時間を分割し、分割後の時間単位の配送問題について配送計画を算出することで、実用的な時間で配送計画を生成することができる。
本発明の第8の態様における前記分割部は、前記初期条件が示す配送問題を、前記初期条件に含まれる配送制限時間よりも所定の時間だけ短い第一配送制限時間を新たな配送制限時間とする配送問題に分割し、前記配送計画生成部は、前記第一配送制限時間内に前記配送物がなるべく多く需要のある拠点に配送されるような配送計画を生成してもよい。
本発明の第9の態様における前記分割部は、前記第一配送制限時間に続く所定長さの時間を第二配送制限時間として設定し、前記配送計画生成部は、当該第二配送制限時間内に前記配送物がなるべく多く需要のある拠点に配送されるような配送計画を生成してもよい。
本発明の第10の態様における前記配送計画生成部は、前記生成した配送計画を実行した場合の完了時点を開始時刻とし、前記第一配送制限時間の開始時刻を基準にして前記初期条件に含まれる配送制限時間が経過する時刻を終了時刻とする最後の時間内に、前記配送計画の実行の結果、配送が完了していない配送物について配送し終える配送計画を生成してもよい。
第8~10の態様によれば、初期条件で与えられた配送制限時間より短い時間を配送制限時間に設定し、配送制限時間を延長しながら配送計画を生成する。初期条件が示す配送問題を設定または延長した配送制限時間ごとの規模の小さな配送問題に分割することで、実用的な時間で配送計画を生成することができる。
第8~10の態様によれば、初期条件で与えられた配送制限時間より短い時間を配送制限時間に設定し、配送制限時間を延長しながら配送計画を生成する。初期条件が示す配送問題を設定または延長した配送制限時間ごとの規模の小さな配送問題に分割することで、実用的な時間で配送計画を生成することができる。
本発明の第11の態様では、前記配送物がなるべく多く需要のある拠点に配送されるような配送計画の生成にあたり、前記配送計画生成部は、前記配送計画を実行した結果、前記配送計画に必要な配送スタッフと配送手段が前記配送拠点に残らないことを条件に配送計画を生成してもよい。
なるべく多くの配送物を配送するだけではなく、分割後の時間のうち後の時間に使用しない余分な配送スタッフと配送手段が配送拠点に残らないような配送計画を生成することができる。
なるべく多くの配送物を配送するだけではなく、分割後の時間のうち後の時間に使用しない余分な配送スタッフと配送手段が配送拠点に残らないような配送計画を生成することができる。
本発明の第12の態様における前記配送計画生成部は、前記配送物を配送する配送主体と前記配送物または前記配送主体を移動する配送手段の初期位置を示す出発拠点および前記配送拠点と配送開始の時を基準とする各時刻とを組にした点情報と、前記点情報のうち前記配送物の配送に係る2つの点情報の間の、前記配送に係る前記配送物および前記配送主体および前記配送手段の流量を示す枝情報と、で構成される時空間ネットワークモデルに基づく整数計画問題を解いて、前記分割部による分割後の配送問題における前記配送に係る枝情報の集合を少なくとも1つ生成してもよい。
配送問題を時空間ネットワークモデルでモデル化することで搭乗輸送を含む配送問題について配送計画を生成することができる。
配送問題を時空間ネットワークモデルでモデル化することで搭乗輸送を含む配送問題について配送計画を生成することができる。
本発明の第13の態様によれば、前記配送計画生成部は、前記時空間ネットワークモデルにおいて、一つの前記配送拠点について、その配送拠点の入口と時刻とを組にした入口に係る点情報と、その配送拠点の出口と時刻とを組にした出口に係る点情報と、その配送拠点に係る配送物1個ずつに対して時刻を組にした配送物の置き場に係る点情報とを生成し、前記入口に係る点情報と前記配送物に係る点情報との間、前記出口に係る点情報と前記配送物に係る点情報との間、における前記配送主体および前記配送物の流量の値を0または1に設定してもよい。
配送拠点内を入口、出口、配送物一つずつの置き場に分けて扱うことで、それらの場所それぞれの状況を0と1で表すことができるので、配送拠点内を0-1整数計画問題として扱えるようになり計算処理を高速化できる。
配送拠点内を入口、出口、配送物一つずつの置き場に分けて扱うことで、それらの場所それぞれの状況を0と1で表すことができるので、配送拠点内を0-1整数計画問題として扱えるようになり計算処理を高速化できる。
本発明の第14の態様によれば、配送計画システムが、配送物を需要のある配送拠点に配送する配送問題において、初期条件が示す配送問題をより規模の小さな配送問題に分割し、前記分割した後の配送問題について配送計画を生成する、配送計画方法である。
本発明の第15の態様によれば、プログラムは、配送計画システムのコンピュータを、配送物を需要のある配送拠点に配送する配送問題において、初期条件が示す配送問題をより規模の小さな配送問題に分割する手段、前記分割した後の配送問題について配送計画を生成する手段、として機能させる。
上記した配送計画システム、配送計画方法及びプログラムによれば、実用的な時間で、大規模な配送問題に対するコストや移動時間を最小にする配送計画を立案することができる。
<第一実施形態>
以下、本発明の一実施形態による配送計画システムを図1~図13を参照して説明する。
図1は、本発明の第一実施形態における配送計画システムの一例を示す機能ブロック図である。本実施形態において、配送計画システムは、例えば、1台のPCやサーバ装置などのコンピュータ装置によって構成される。コンピュータ装置は、CPU(Central Processing Unit)などの演算部、及び、ROM(Read Only Memory)、RAM(Random Access Memory)、HDD(Hard Disk Drive)などの記憶部、および、ネットワークインタフェースなどその他のハードウェアを含んで構成されている。
以下、本発明の一実施形態による配送計画システムを図1~図13を参照して説明する。
図1は、本発明の第一実施形態における配送計画システムの一例を示す機能ブロック図である。本実施形態において、配送計画システムは、例えば、1台のPCやサーバ装置などのコンピュータ装置によって構成される。コンピュータ装置は、CPU(Central Processing Unit)などの演算部、及び、ROM(Read Only Memory)、RAM(Random Access Memory)、HDD(Hard Disk Drive)などの記憶部、および、ネットワークインタフェースなどその他のハードウェアを含んで構成されている。
図1の配送計画装置10は、配送計画システムの一例である。配送計画装置10は、搭乗輸送を含めた配送計画に対して、コストを最小にする配送手段、配送ルートなどを算出する装置である。本実施形態では、乗り捨て型のカーシェアリングにおいてユーザが共同で利用する車両をユーザが利用を開始する場所へ配送する場面で、その配送を実現する最適な配送計画を立案する方法を例として取り上げる。配送物を配送する場合、例えば、コストを最小にする配送手段、配送ルートを選択することが求められる。コストを最小にする配送計画の立案については、これまでも様々な方法が提供されてきた。しかし、カーシェアリングにおける車両の配送には、例えば、宅配便等で荷物を配送する場合と異なる点がある。それは、車両を配送する場合には、車両に人が搭乗して移動することができるという点である。例えば、拠点A、拠点B、拠点C、拠点D、拠点Eのそれぞれの拠点において、車両が余った状態、または、不足した状態があるとする。このような状態の中、車両が余っている拠点から不足している拠点へ車両を移動し、ユーザのニーズに応えられるようにするためには例えば、以下のような方法が考えられる。(1)一人の配送スタッフが、車両を積載することができるトラックで各拠点を回り、余った車両をトラックに搭載し、不足がある拠点まで配送する。(2)配送車に複数の配送スタッフが搭乗し、各拠点を移動する。配送車に搭乗した配送スタッフの一部は、車両が余っている拠点に到着すると、余剰の車両に乗り換え、その車両を車両が不足している拠点まで運転して配送する(搭乗輸送)。このような場合、どちらの配送手段で配送を行えば良いのか、どのようなルートで配送を行えばコストを最小にできるのかを知ることは容易ではない。本実施形態の配送計画装置10は、搭乗輸送が可能な場合の配送計画に対して、数学的知見に基づいた数理モデルや制約を導入することで、高速で効率的に例えばコストを最小にする配送計画を生成する方法を提供する。本実施形態の配送計画装置10は、配送物を配送拠点に配送する配送計画を生成するにあたり、当該配送の初期条件として与えられた、配送拠点ごとの配送物の需要数量(不足している数量)および供給数量(余っている数量)に基づいて、初期条件が示す配送問題の全体を部分的な規模の小さな配送問題に分割する。これにより、配送する車両や拠点の数が大規模であっても、実用的な時間(例えば10分)で配送計画を立案することができる。
図1が示すように、配送計画装置10は、初期条件設定部11と、配送計画生成部12と、入出力部13と、第一エリア分割部14と、記憶部15とを備えている。
初期条件設定部11は、配送主体(例えば配送スタッフ)が搭乗して移動することが可能な配送物(例えばユーザが利用する車両)、配送主体、配送物または配送主体を移動する配送手段(例えばトラック等の配送車)の何れかが留まる場所である配送拠点ごとの配送物の需要数量および供給数量と、配送主体と配送手段の初期位置を示す一つ又は複数の出発拠点(例えばカーシェアリングのサービスを提供する企業の運用拠点)の情報と、出発拠点における利用可能な配送手段および配送主体の情報と、配送期限の情報、などの情報を、配送計画を生成するうえでの初期条件として設定する。これらのパラメータについては後に詳しく説明する。
配送計画生成部12は、配送拠点および出発拠点と配送開始の時を基準とする時刻とを組にした点情報と、点情報のうち配送に係る2つの点情報の間の、配送に係る配送物および配送主体および配送手段の流量を示す枝情報を計算し、配送期限内に需要数量を満たす配送物を当該需要数量が設定された配送拠点に配送する場合の枝情報の集合を少なくとも1つ生成する。出発拠点と配送拠点を総称して拠点と呼ぶ。
入出力部13は、ユーザによる入力操作を受け付ける。入出力部13は、配送計画生成部12が生成した枝情報の集合に基づく配送計画の情報などをディスプレイ等に出力する。
第一エリア分割部14は、配送物の需要がある配送拠点群に含まれる一つの需要点と、配送物の供給元となる配送拠点群に含まれる一つの供給点とを、当該一つの需要点から当該一つの供給点への移動時間が最小となるように対応付け、対応付けた需要点および供給点の組み合わせの集合を生成する。つまり、第一エリア分割部14は、初期条件に基づく配送物の需要がある全ての配送拠点群への配送問題の全体を、生成した集合が示す配送エリア単位の配送問題(集合内に含まれる需要点群から供給点群への配送問題)に分割する。そして、配送計画生成部12は、分割後の規模の小さな配送問題のそれぞれについて、枝情報の集合を生成する。
記憶部15は、配送計画の生成に必要な諸々の情報を記憶する。
初期条件設定部11、配送計画生成部12、第一エリア分割部14は、例えば配送計画装置10が備えるCPU(Central Processing Unit、中央処理装置)が、記憶部15からプログラムを読み出して実行することで実現される。
初期条件設定部11は、配送主体(例えば配送スタッフ)が搭乗して移動することが可能な配送物(例えばユーザが利用する車両)、配送主体、配送物または配送主体を移動する配送手段(例えばトラック等の配送車)の何れかが留まる場所である配送拠点ごとの配送物の需要数量および供給数量と、配送主体と配送手段の初期位置を示す一つ又は複数の出発拠点(例えばカーシェアリングのサービスを提供する企業の運用拠点)の情報と、出発拠点における利用可能な配送手段および配送主体の情報と、配送期限の情報、などの情報を、配送計画を生成するうえでの初期条件として設定する。これらのパラメータについては後に詳しく説明する。
配送計画生成部12は、配送拠点および出発拠点と配送開始の時を基準とする時刻とを組にした点情報と、点情報のうち配送に係る2つの点情報の間の、配送に係る配送物および配送主体および配送手段の流量を示す枝情報を計算し、配送期限内に需要数量を満たす配送物を当該需要数量が設定された配送拠点に配送する場合の枝情報の集合を少なくとも1つ生成する。出発拠点と配送拠点を総称して拠点と呼ぶ。
入出力部13は、ユーザによる入力操作を受け付ける。入出力部13は、配送計画生成部12が生成した枝情報の集合に基づく配送計画の情報などをディスプレイ等に出力する。
第一エリア分割部14は、配送物の需要がある配送拠点群に含まれる一つの需要点と、配送物の供給元となる配送拠点群に含まれる一つの供給点とを、当該一つの需要点から当該一つの供給点への移動時間が最小となるように対応付け、対応付けた需要点および供給点の組み合わせの集合を生成する。つまり、第一エリア分割部14は、初期条件に基づく配送物の需要がある全ての配送拠点群への配送問題の全体を、生成した集合が示す配送エリア単位の配送問題(集合内に含まれる需要点群から供給点群への配送問題)に分割する。そして、配送計画生成部12は、分割後の規模の小さな配送問題のそれぞれについて、枝情報の集合を生成する。
記憶部15は、配送計画の生成に必要な諸々の情報を記憶する。
初期条件設定部11、配送計画生成部12、第一エリア分割部14は、例えば配送計画装置10が備えるCPU(Central Processing Unit、中央処理装置)が、記憶部15からプログラムを読み出して実行することで実現される。
配送計画装置10は、与えられた配送問題に対して、時空間ネットワークモデルを用いて配送計画を生成する。まず、時空間ネットワークモデルと時空間ネットワークモデルを用いた配送計画の生成方法について説明し、その後、問題が大規模になった場合の配送問題の分割方法について説明する。
図2は、本発明の第一実施形態における配送計画の一例を説明する図である。
図2を用いて、乗り捨て型のカーシェアリングにおける配送物(車両)の配送例について説明する。図2においてセンターとは、配送物の配送スタッフが存在し、配送物の配送を開始する拠点である(出発拠点)。駐車場A、駐車場B、駐車場Cは配送物の配送元または配送先となる拠点(配送拠点)である。配送物のユーザは、所定の予約システムなどで配送物の予約を行う。ユーザは、配送物の利用台数、利用開始場所(例えば、駐車場B)などの情報を予約システムから入力する。ユーザが駐車場Bから配送物を利用したい場合、既に駐車場Bに配送物が存在すれば、利用者はその配送物を利用することができる。しかし、駐車場Bに配送物が存在しない場合、配送スタッフが他の駐車場から駐車場Bに配送物を移動する必要がある。乗り捨て型のカーシェアリングにおいては、ユーザは、例えば、駐車場Bから駐車場Aへ配送物を利用すると、駐車場Aへ配送物をそのまま乗り捨ててしまう。すると、多くのユーザが利用する、例えば、駐車場Aに配送物が遍在するような状況が生じ得る。センターの配送スタッフは、遍在した配送物をユーザのニーズがある駐車場A~駐車場Cに配送する。図2の例の場合、駐車場Aでは配送物が2台余り、駐車場B、駐車場Cでは配送物が1台ずつ不足している。センターの配送スタッフは、駐車場Aで余った2台の配送物を、それぞれ駐車場B、駐車場Cに1台ずつ配送し、ユーザが希望通り配送物を利用できるようにする。図2は、この条件を満たす配送の実現例を示している。
図2を用いて、乗り捨て型のカーシェアリングにおける配送物(車両)の配送例について説明する。図2においてセンターとは、配送物の配送スタッフが存在し、配送物の配送を開始する拠点である(出発拠点)。駐車場A、駐車場B、駐車場Cは配送物の配送元または配送先となる拠点(配送拠点)である。配送物のユーザは、所定の予約システムなどで配送物の予約を行う。ユーザは、配送物の利用台数、利用開始場所(例えば、駐車場B)などの情報を予約システムから入力する。ユーザが駐車場Bから配送物を利用したい場合、既に駐車場Bに配送物が存在すれば、利用者はその配送物を利用することができる。しかし、駐車場Bに配送物が存在しない場合、配送スタッフが他の駐車場から駐車場Bに配送物を移動する必要がある。乗り捨て型のカーシェアリングにおいては、ユーザは、例えば、駐車場Bから駐車場Aへ配送物を利用すると、駐車場Aへ配送物をそのまま乗り捨ててしまう。すると、多くのユーザが利用する、例えば、駐車場Aに配送物が遍在するような状況が生じ得る。センターの配送スタッフは、遍在した配送物をユーザのニーズがある駐車場A~駐車場Cに配送する。図2の例の場合、駐車場Aでは配送物が2台余り、駐車場B、駐車場Cでは配送物が1台ずつ不足している。センターの配送スタッフは、駐車場Aで余った2台の配送物を、それぞれ駐車場B、駐車場Cに1台ずつ配送し、ユーザが希望通り配送物を利用できるようにする。図2は、この条件を満たす配送の実現例を示している。
まず、センターから配送スタッフ2名(k、l)が1台の配送車1(配送手段)に搭乗して駐車場Aへ移動する(1)。駐車場Aでは、配送スタッフkが余っている2台のうち1台の配送物に搭乗して駐車場Bへ移動する。他の配送スタッフlも、そのまま配送車1に搭乗して駐車場Bへ移動する(2)。駐車場Bでは、配送スタッフkが配送物を駐車場Bに駐車し、配送スタッフlの運転する配送車1に搭乗する。配送スタッフk、lは駐車場Bから駐車場Aへ戻る(3)。駐車場Aへ戻ると、配送スタッフkは、余っている1台の配送物に搭乗して駐車場Cへ移動する。配送スタッフlは、そのまま配送車1に搭乗して駐車場Cへ移動する(4)。駐車場Cでは、配送スタッフkが配送物を駐車場Cに駐車し、配送スタッフlの運転する配送車1に搭乗する。配送スタッフk、lは駐車場Bからセンターへ戻る(5)。このような手順で配送を行うと、ユーザの要求を満たすことができる。本実施形態では、このような状況における配送物の配送方法を、時空間ネットワークモデルの最小コストフロー問題として定式化して、実行可能な配送方法のうちコストが最小になる方法を求める。
<第1の時空間ネットワークモデル>
図3は、本発明の第一実施形態における配送計画に係る第1の時空間ネットワークモデルを説明する図である。
図3は、図2で説明した配送の実施例を時空間ネットワークにモデル化した図である。
図3の縦軸は時間経過、横軸は各拠点の場所を示している。図中、時空間上の点は、各時刻における各拠点を表したものである。図中、2つの点を結んだ矢印は、配送物、配送車(配送手段)、配送スタッフ(人)の時空間上の移動を示している。各矢印は、移動元拠点と移動先拠点、移動に要する時間を表している。実線矢印は拠点間の移動を表し、二重線矢印は同一拠点に留まる配送物、配送車、配送スタッフを示している(時間を移動)。各矢印に添えて表示された行列の各要素は、矢印が示す配送によって移動した配送物、配送車、配送スタッフの数量を表しており、上から順に移動した配送物の数量、移動した配送車の数量、移動した配送スタッフの人数を表す。例えば、実線矢印31の場合、センターから駐車場Aへ、配送物が0台、配送車が1台、配送スタッフが2名、時刻t=0からt=1の間に移動したことを示している。二重線矢印32は、駐車場Aにおいて、配送物が2台、配送車が0台、配送スタッフが0名、時刻t=0からt=1の間留まっていたことを示している。実線矢印33の場合、駐車場Aから駐車場Bへ、配送物が1台、配送車が1台、配送スタッフが2名、時刻t=1からt=2の間に移動したことを示している。二重線矢印34は、駐車場Aにおいて、配送物が1台、配送車が0台、配送スタッフが0名、時刻t=1からt=2の間留まっていたことを示している。駐車場Aにおける配送物が2台から1台に変化したのは、配送スタッフが、2台のうちの配送物1台に搭乗して、駐車場Bへ移動したためである。他の矢印についても同様である。一本の矢印を枝と呼ぶ。図3の枝の集合は、図2で説明した配送計画に対応したものである。配送物を配送する場合、どこかの駐車場で配送スタッフや配達手段を待ち合わせるなど時間が関係したアクションが伴う場合がある。配送計画に関する既存の数理モデルでは、拠点を点とし、拠点間の配送車の移動を枝としてモデル化することが多かった。本実施形態では、2次元の時空間ネットワークでモデル化する。これにより、拠点間の空間的な移動だけでなく、時間が介在する車両や人の移動を表すことができる。
図3は、本発明の第一実施形態における配送計画に係る第1の時空間ネットワークモデルを説明する図である。
図3は、図2で説明した配送の実施例を時空間ネットワークにモデル化した図である。
図3の縦軸は時間経過、横軸は各拠点の場所を示している。図中、時空間上の点は、各時刻における各拠点を表したものである。図中、2つの点を結んだ矢印は、配送物、配送車(配送手段)、配送スタッフ(人)の時空間上の移動を示している。各矢印は、移動元拠点と移動先拠点、移動に要する時間を表している。実線矢印は拠点間の移動を表し、二重線矢印は同一拠点に留まる配送物、配送車、配送スタッフを示している(時間を移動)。各矢印に添えて表示された行列の各要素は、矢印が示す配送によって移動した配送物、配送車、配送スタッフの数量を表しており、上から順に移動した配送物の数量、移動した配送車の数量、移動した配送スタッフの人数を表す。例えば、実線矢印31の場合、センターから駐車場Aへ、配送物が0台、配送車が1台、配送スタッフが2名、時刻t=0からt=1の間に移動したことを示している。二重線矢印32は、駐車場Aにおいて、配送物が2台、配送車が0台、配送スタッフが0名、時刻t=0からt=1の間留まっていたことを示している。実線矢印33の場合、駐車場Aから駐車場Bへ、配送物が1台、配送車が1台、配送スタッフが2名、時刻t=1からt=2の間に移動したことを示している。二重線矢印34は、駐車場Aにおいて、配送物が1台、配送車が0台、配送スタッフが0名、時刻t=1からt=2の間留まっていたことを示している。駐車場Aにおける配送物が2台から1台に変化したのは、配送スタッフが、2台のうちの配送物1台に搭乗して、駐車場Bへ移動したためである。他の矢印についても同様である。一本の矢印を枝と呼ぶ。図3の枝の集合は、図2で説明した配送計画に対応したものである。配送物を配送する場合、どこかの駐車場で配送スタッフや配達手段を待ち合わせるなど時間が関係したアクションが伴う場合がある。配送計画に関する既存の数理モデルでは、拠点を点とし、拠点間の配送車の移動を枝としてモデル化することが多かった。本実施形態では、2次元の時空間ネットワークでモデル化する。これにより、拠点間の空間的な移動だけでなく、時間が介在する車両や人の移動を表すことができる。
<第1の時空間ネットワークモデルに基づく配送計画の生成方法>
本実施形態では、図2、図3で説明したような制限時間内に需要を満たすような配送計画配送物において配送に掛かるコストを最小化する配送計画を求める。この問題は、以下に示す整数計画問題として定式化することができる。
[目的関数]
配送に掛かる配送物、配送手段、配送スタッフのコストの合計を最小化
[制約条件]
(1)各拠点の流量は流量保存則を満たす。
(2)駐車場に存在する車両台数は駐車場の駐車スペースは超えない。
(3)配送手段には、出発拠点以外では必ず配送スタッフが乗る。
(4)移動時には配送物または配送手段に必ず配送スタッフが乗り、移動時の人数は配送物および配送手段に搭乗可能な人数の合計以下である。
本実施形態では、図2、図3で説明したような制限時間内に需要を満たすような配送計画配送物において配送に掛かるコストを最小化する配送計画を求める。この問題は、以下に示す整数計画問題として定式化することができる。
[目的関数]
配送に掛かる配送物、配送手段、配送スタッフのコストの合計を最小化
[制約条件]
(1)各拠点の流量は流量保存則を満たす。
(2)駐車場に存在する車両台数は駐車場の駐車スペースは超えない。
(3)配送手段には、出発拠点以外では必ず配送スタッフが乗る。
(4)移動時には配送物または配送手段に必ず配送スタッフが乗り、移動時の人数は配送物および配送手段に搭乗可能な人数の合計以下である。
上記の整数計画問題を解くために、配送計画生成部12は、初期条件設定部11が受け付けた初期条件の情報に基づいて、図3で例示したような2次元の時空間情報を生成し、配送に係る点の間の枝を生成し、配送期限内に各拠点の需要数量を満たすように、配送物を当該需要数量が設定された拠点に配送できるような枝情報の集合を複数生成する。そして、配送計画生成部12は、複数の枝情報の集合の中からコストを最小にする枝情報の集合を選択する。
これまでに提供されてきた配送計画の数理モデルやプログラムは、配送物をトラックや鉄道などの輸送手段に積荷して配送する場合に限られている。車両の配送のように、搭乗輸送を含む場合に対しては、既存技術でも制約条件を追加することで解ける可能性があるが、制約条件が複雑になる上に、手段や経路の組合せ数が指数関数的に増大するために実用的ではないと考えられる。本実施形態によれば、搭乗輸送が可能な配送物の配送計画を生成するにあたり、時空間ネットワークモデルの最小コストフロー問題として定式化することで、実行可能な配送方法のうちコストが最小になる配送計画を求めることができる。
<第2の時空間ネットワークモデル>
第2の時空間ネットワークモデルでは、第1の時空間ネットワークモデルに対して、さらに配送拠点内のグラフ(点情報と配送スタッフ、配送物、配送手段の移動を表す枝情報)を追加する。これにより、配送拠点内を0-1整数計画問題として扱えるようにする。0-1整数計画問題は、整数計画問題より変数の幅が制限され、タイトな緩和問題を構成することができる。それにより、妥当不等式(カット)を入れやすくなり、計算処理の高速化(計算時間の短縮化)が図れる。
第2の時空間ネットワークモデルでは、第1の時空間ネットワークモデルに対して、さらに配送拠点内のグラフ(点情報と配送スタッフ、配送物、配送手段の移動を表す枝情報)を追加する。これにより、配送拠点内を0-1整数計画問題として扱えるようにする。0-1整数計画問題は、整数計画問題より変数の幅が制限され、タイトな緩和問題を構成することができる。それにより、妥当不等式(カット)を入れやすくなり、計算処理の高速化(計算時間の短縮化)が図れる。
配送計画生成部12が第2の時空間ネットワークモデルを用いて配送計画を生成する場合、第1の時空間ネットワークモデルの場合に説明した時空間情報に加え、一つの配送拠点について、その配送拠点の入口と時刻とを組にした点情報、その配送拠点の出口と時刻とを組にした点情報、その配送拠点に係る配送物1個ずつに対して時刻を組にした点情報を生成する。配送計画生成部12は、入口に係る点情報と配送物に係る点情報との間における配送スタッフおよび配送物の流量の値を0または1に設定する。配送計画生成部12は、出口に係る点情報と配送物に係る点情報との間における配送スタッフおよび配送物の流量の値を0または1に設定する。
ここで、配送計画立案者が、配送計画装置10へ入力するパラメータについて説明する。入力パラメータには以下の項目がある。
つまり、出発拠点の集合(Depot)、配送拠点の集合(W)、配送期限(dl)、1区間の時間(h)、配送物の種類の集合(P)、配送手段の種類の集合(D)、配送手段の積載量(cp)、配送物のコストcx(円/分)、配送手段のコストcy(円/分)、配送スタッフのコストcz(円/分)、移動時間マトリクスM(例えば、配送手段dによる配送拠点w1からw2への移動時間はm[d][w1][w2]とする)、各拠点の供給数量supply(例えば、配送拠点wにおけるdの供給数量はsupply[w、d]とする)、各配送拠点の需要数量demand(例えば、配送拠点wにおけるdの需要数量はdemand[w、d]とする)である。初期条件設定部11は、これらのパラメータを取得し、配送計画の初期条件として設定する。
つまり、出発拠点の集合(Depot)、配送拠点の集合(W)、配送期限(dl)、1区間の時間(h)、配送物の種類の集合(P)、配送手段の種類の集合(D)、配送手段の積載量(cp)、配送物のコストcx(円/分)、配送手段のコストcy(円/分)、配送スタッフのコストcz(円/分)、移動時間マトリクスM(例えば、配送手段dによる配送拠点w1からw2への移動時間はm[d][w1][w2]とする)、各拠点の供給数量supply(例えば、配送拠点wにおけるdの供給数量はsupply[w、d]とする)、各配送拠点の需要数量demand(例えば、配送拠点wにおけるdの需要数量はdemand[w、d]とする)である。初期条件設定部11は、これらのパラメータを取得し、配送計画の初期条件として設定する。
出力項目として、配送計画生成部12は、最適化された配送計画における時空間ネットワークを流れる配送物の流量x((v,s),(w,t))、配送手段の流量y((v,s),(w,t))、配送スタッフの流量z((v,s),(w,t))を入出力部13へ出力する。配送拠点vを時刻sに出発し、配送拠点wへ時刻tに到着する枝を((v,s),(w,t))で表すものとする。出力項目には、他に配送に掛かるコストなどがある。
図4は、本発明の第一実施形態における配送計画に係る第2の時空間ネットワークモデルを説明する第一の図である。
図4を用いて第2の時空間ネットワークを説明する。以下、場所集合をN、時間集合をT、時空間ネットワークのグラフG=(V、E)とする。Vは点集合、Eは枝集合である。点集合Vは以下のように定義する。
V = {(w,d,p,t)|w∈W,d∈{0}∪P,p∈Swd,t∈T}ここで、Swd={0,1}(d=0),Swd={0,1,...,m}(d≠0)である。d=0は、配送拠点の出入り口の道を示している。d=0のとき、Swdは0又は1の値を取るが、Swd=0は入口、Swd=1は出口を示している。d≠0の場合、dは配送物の種類を示し、Swdは0~mの値を取る。mは配送拠点wの配送物dに対する供給数量-1または需要数量-1である。例えば、配送拠点wで配送物aが3個余っている場合(供給数量=3)、Swdは0、1、2の値を取る。例えば、配送拠点wで配送物aが4個足りない場合(需要数量=4)、Swdは0、1、2、3の値を取る。ある配送拠点wについて、d=0の点を道、d≠0の点をポートとも呼ぶ。ポートは、配送物dを1個置く場所を示している。
図4を用いて第2の時空間ネットワークを説明する。以下、場所集合をN、時間集合をT、時空間ネットワークのグラフG=(V、E)とする。Vは点集合、Eは枝集合である。点集合Vは以下のように定義する。
V = {(w,d,p,t)|w∈W,d∈{0}∪P,p∈Swd,t∈T}ここで、Swd={0,1}(d=0),Swd={0,1,...,m}(d≠0)である。d=0は、配送拠点の出入り口の道を示している。d=0のとき、Swdは0又は1の値を取るが、Swd=0は入口、Swd=1は出口を示している。d≠0の場合、dは配送物の種類を示し、Swdは0~mの値を取る。mは配送拠点wの配送物dに対する供給数量-1または需要数量-1である。例えば、配送拠点wで配送物aが3個余っている場合(供給数量=3)、Swdは0、1、2の値を取る。例えば、配送拠点wで配送物aが4個足りない場合(需要数量=4)、Swdは0、1、2、3の値を取る。ある配送拠点wについて、d=0の点を道、d≠0の点をポートとも呼ぶ。ポートは、配送物dを1個置く場所を示している。
図4は、Depot={0}、W={1,2}、P={a}、T={0,1,2}、S1a={0}(配送拠点1で配送物aに対する供給数量1個)、S2a={0}(配送拠点2で配送物aに対する需要数量1個)の場合の時空間ネットワークである。次に枝集合Eについて図5を用いて説明する。
図5は、本発明の第一実施形態における配送計画に係る第2の時空間ネットワークモデルを説明する第二の図である。
以下、枝集合Eを、E=Ex∪Ey∪Ezとする。Exは配送物の枝集合、Eyは配送手段の枝集合、Ezは配送スタッフの枝集合である。
配送物の枝集合Exは以下のように定義する。
Ex=Ewwx∪Ewx∪Ewpx∪Epwx∪Epx
Ewwxは配送物の拠点間の移動を示す枝の集合、Ewxは配送物の配送拠点の道に留まる枝(待ち合わせなど)の集合、Ewpxは配送物の道からポートへの移動を示す枝の集合、Epwxは配送物のポートから道への移動を示す枝の集合、Epxは配送物がポートに留まる枝の集合である。
以下、枝集合Eを、E=Ex∪Ey∪Ezとする。Exは配送物の枝集合、Eyは配送手段の枝集合、Ezは配送スタッフの枝集合である。
配送物の枝集合Exは以下のように定義する。
Ex=Ewwx∪Ewx∪Ewpx∪Epwx∪Epx
Ewwxは配送物の拠点間の移動を示す枝の集合、Ewxは配送物の配送拠点の道に留まる枝(待ち合わせなど)の集合、Ewpxは配送物の道からポートへの移動を示す枝の集合、Epwxは配送物のポートから道への移動を示す枝の集合、Epxは配送物がポートに留まる枝の集合である。
配送手段の枝集合Eyは以下のように定義する。
Ey=Ewwy∪Ewy∪Ewpy∪Epwy
Ewwyは配送手段の拠点間の移動を示す枝の集合、Ewyは配送手段の配送拠点の道に留まる枝(待ち合わせなど)の集合、Ewpyは配送手段の道からポートへの移動を示す枝の集合、Epwyは配送手段のポートから道への移動を示す枝の集合である。
Ey=Ewwy∪Ewy∪Ewpy∪Epwy
Ewwyは配送手段の拠点間の移動を示す枝の集合、Ewyは配送手段の配送拠点の道に留まる枝(待ち合わせなど)の集合、Ewpyは配送手段の道からポートへの移動を示す枝の集合、Epwyは配送手段のポートから道への移動を示す枝の集合である。
配送スタッフの枝集合Ezは以下のように定義する。
Ez=Ewwz∪Ewz∪Ewpz∪Epwz
Ewwzは配送スタッフの拠点間の移動を示す枝の集合、Ewzは配送スタッフの配送拠点の道に留まる枝(待ち合わせなど)の集合、Ewpzは配送スタッフの道からポートへの移動を示す枝の集合、Epwzは配送スタッフのポートから道への移動を示す枝の集合である。
Ez=Ewwz∪Ewz∪Ewpz∪Epwz
Ewwzは配送スタッフの拠点間の移動を示す枝の集合、Ewzは配送スタッフの配送拠点の道に留まる枝(待ち合わせなど)の集合、Ewpzは配送スタッフの道からポートへの移動を示す枝の集合、Epwzは配送スタッフのポートから道への移動を示す枝の集合である。
図5に、上記で定義した枝集合の表示例を示す。斜め方向の実線矢印は、Ewwx、Ewwy、Ewwzの各集合に対応する枝を示している。縦方向の二重線矢印は、Ewx、Ewy、Ewzの各集合に対応する枝を示している。横方向の二点鎖線矢印は、Ewpx、Ewpy、Ewpzの各集合に対応する枝を示している。斜め方向の一点鎖線矢印は、Epwx、Epwy、Epwzの各集合に対応する枝を示している。縦方向の破線矢印は、Epxの集合に対応する枝を示している。
第2の時空間ネットワークモデルでは配送拠点内を0-1整数問題として扱うが、横方向の二点鎖線矢印、斜め方向の一点鎖線矢印、縦方向の破線矢印の枝が、この0-1整数問題化に関連して、本実施形態で追加された枝である。
第2の時空間ネットワークモデルでは配送拠点内を0-1整数問題として扱うが、横方向の二点鎖線矢印、斜め方向の一点鎖線矢印、縦方向の破線矢印の枝が、この0-1整数問題化に関連して、本実施形態で追加された枝である。
図6は、本発明の第一実施形態における配送計画に係る第2の時空間ネットワークモデルを説明する第三の図である。
図6を用いて、各枝に対して設定される流量ベクトルについて説明する。図6(a)に示すように各枝eには流量ベクトル
図6を用いて、各枝に対して設定される流量ベクトルについて説明する。図6(a)に示すように各枝eには流量ベクトル
が設定される。この流量ベクトルのうち、x[d、e](d∈P,e∈Ex)は配送物の流量、y[d、e](d∈D,e∈Ey)は配送手段の流量、z[e](e∈Ez)は配送スタッフの流量を示している。いくつか例を挙げる。P={a}、D={車}の場合、流量ベクトルは、
となる。図6(b)に示す枝eは、aが1個、配送車(車)が1台、配送スタッフ(人)が2人の移動を示す。P={a,b}、D={車,バイク}の場合、流量ベクトルは、
となる。図6(c)に示す枝eは、aが1個、bが1個、配送車(車)が1台、バイクが1台、配送スタッフ(人)が2人の移動を示す。
図7は、本発明の第一実施形態における配送計画に係る第2の時空間ネットワークモデルを説明する第四の図である。
図7は、流量ベクトルが以下であって、
図7は、流量ベクトルが以下であって、
配送物aを1個、配送拠点1から配送拠点2へ移動させる場合の時空間ネットワークモデルである。まず、配送スタッフ(人)2人と配送車(車)1台がDepot出口から配送拠点1へ移動する(実線矢印91)。配送拠点1では、配送スタッフ1人が配送物aの置き場(ポート0)へ移動する(2点鎖線矢印92)。配送物aのポート0では、配送物aが時刻0~1まで存在する(破線矢印93)。続いて配送スタッフ1人と配送物a1個が配送拠点1の出口へ移動する(1点鎖線矢印94)。次に配送物aが1個、配送車1台、配送スタッフ2人が配送拠点1の出口から配送拠点2の入口へ移動する(実線矢印95)。次に配送スタッフ1人と配送物a1個が配送拠点2のポート0へ移動する(2点鎖線矢印96)。続いて配送スタッフ1人がポート0から配送拠点2の出口へ移動する(1点鎖線矢印97)。次に配送スタッフ2人と配送車1台が配送拠点2の出口からDepot入口へ移動する(実線矢印98)。配送拠点2のポート0では配送物aが時刻2~3まで存在する(破線矢印100)。図7に示すように本実施形態では、配送拠点1および配送拠点2において、配送物a1個ごとに点を割り当て、また、配送拠点の入口、出口それぞれに点を割り当てている。そのため、配送拠点1内および配送拠点2内における流量ベクトルの各要素の値は0か1となる。これにより、配送拠点内を0-1整数計画問題として扱えるようになり、計算時間を短縮化できる。
図8は、本発明の第一実施形態における配送計画に係る第2の時空間ネットワークモデルを説明する第五の図である。
図8は、図3で例示した第1の時空間ネットワークモデルを第2の時空間ネットワークモデルを用いて表したものである。図8では、図3では駐車場Aの列で表した点集合を、さらに細分化した(1,0,0,0)、(1,a,0,0)、(1,a,1,0)の各列の点集合で表している。駐車場B、駐車場Cについても同様である。センター、駐車場A~駐車場Cのそれぞれには出入口に対応する点集合が与えられている。
図8は、図3で例示した第1の時空間ネットワークモデルを第2の時空間ネットワークモデルを用いて表したものである。図8では、図3では駐車場Aの列で表した点集合を、さらに細分化した(1,0,0,0)、(1,a,0,0)、(1,a,1,0)の各列の点集合で表している。駐車場B、駐車場Cについても同様である。センター、駐車場A~駐車場Cのそれぞれには出入口に対応する点集合が与えられている。
<第2の時空間ネットワークモデルに基づく配送計画の生成方法>
以上、第2の時空間ネットワークモデルにおける処理の高速化に対する対策として、配送拠点内を0-1整数計画問題とすることについて説明した。次に配送計画の生成方法について説明する。配送手段として、配送車と自転車で配送する場合(配送車だけで配送する場合も含む)、トラックで(配送物を積載して)配送する場合のそれぞれについて説明を行う。配送手段の自転車は、配送スタッフが自転車に乗って供給のある配送拠点へ移動し、そこで余剰の車両に自転車を積んで、配送スタッフが余剰車両を運転して需要のある配送拠点へ移動するといった用いられ方をする。
以上、第2の時空間ネットワークモデルにおける処理の高速化に対する対策として、配送拠点内を0-1整数計画問題とすることについて説明した。次に配送計画の生成方法について説明する。配送手段として、配送車と自転車で配送する場合(配送車だけで配送する場合も含む)、トラックで(配送物を積載して)配送する場合のそれぞれについて説明を行う。配送手段の自転車は、配送スタッフが自転車に乗って供給のある配送拠点へ移動し、そこで余剰の車両に自転車を積んで、配送スタッフが余剰車両を運転して需要のある配送拠点へ移動するといった用いられ方をする。
まず、目的関数について説明する。図3では、コストを最小化する場合を例に説明を行った。ここでは、配送に掛かる移動時間を最小化する場合も含めて説明する。
(配送車と自転車で配送する場合)
1.配送に掛かるコストを最小化する場合の目的関数は、配送物、配送車、配送スタッフそれぞれの時間当たりのコストに移動時間を掛けて足したものとする。
2.配送に掛かる移動時間を最小化する場合の目的関数は配送物、配送車、配送スタッフそれぞれの移動時間を足したものとする。
(配送車と自転車で配送する場合)
1.配送に掛かるコストを最小化する場合の目的関数は、配送物、配送車、配送スタッフそれぞれの時間当たりのコストに移動時間を掛けて足したものとする。
2.配送に掛かる移動時間を最小化する場合の目的関数は配送物、配送車、配送スタッフそれぞれの移動時間を足したものとする。
(トラックで配送する場合)
1.配送に掛かるコストを最小化する場合の目的関数は、配送トラック、配送スタッフそれぞれの時間当たりのコストに移動時間を掛けて足したものとする。
2.配送に掛かる移動時間を最小化する場合の目的関数は、配送トラック、配送スタッフそれぞれの移動時間を足したものとする。
1.配送に掛かるコストを最小化する場合の目的関数は、配送トラック、配送スタッフそれぞれの時間当たりのコストに移動時間を掛けて足したものとする。
2.配送に掛かる移動時間を最小化する場合の目的関数は、配送トラック、配送スタッフそれぞれの移動時間を足したものとする。
次に制約条件について説明する。
(配送車と自転車で配送する場合とトラックで配送する場合に共通)1.流量保存則
(1)配送物の流量について
配送開始時点においては、供給が存在するポートから出る流量は1となる。配送完了時点においては、需要が存在するポートに入る流量が1となる。その他の点では、出ていく流量と入る流量は等しい。
(配送車と自転車で配送する場合とトラックで配送する場合に共通)1.流量保存則
(1)配送物の流量について
配送開始時点においては、供給が存在するポートから出る流量は1となる。配送完了時点においては、需要が存在するポートに入る流量が1となる。その他の点では、出ていく流量と入る流量は等しい。
(2)配送車の流量について
配送開始時点においては、配送車が存在する道から出る流量は、配送車の存在台数分となる。配送完了時点においては、配送車が存在する道に入る流量は、配送車の存在台数分となる。その他の点では、出ていく流量と入る流量は等しい。
(3)配送スタッフの流量について
配送開始時点においては、配送スタッフが存在する道から出る流量は、配送スタッフの人数分となる。配送完了時点においては、配送スタッフが存在する道に入る流量は、配送スタッフの人数分となる。その他の点では、出ていく流量と入る流量は等しい。
2.容量制約
配送拠点内の配送物、人の移動量は1以下である。
配送開始時点においては、配送車が存在する道から出る流量は、配送車の存在台数分となる。配送完了時点においては、配送車が存在する道に入る流量は、配送車の存在台数分となる。その他の点では、出ていく流量と入る流量は等しい。
(3)配送スタッフの流量について
配送開始時点においては、配送スタッフが存在する道から出る流量は、配送スタッフの人数分となる。配送完了時点においては、配送スタッフが存在する道に入る流量は、配送スタッフの人数分となる。その他の点では、出ていく流量と入る流量は等しい。
2.容量制約
配送拠点内の配送物、人の移動量は1以下である。
3.配送拠点内の制約1
∀e∈Ewp
(Ewpは配送物、配送手段、人の道からポートへの移動を示す枝の集合)
(1)eの行き先がdの供給点のとき
配送物は道からポートには入ってこない。
(2)eの行き先がdの需要点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
∀e∈Ewp
(Ewpは配送物、配送手段、人の道からポートへの移動を示す枝の集合)
(1)eの行き先がdの供給点のとき
配送物は道からポートには入ってこない。
(2)eの行き先がdの需要点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
4.配送拠点内の制約2
∀e∈Epw
(Epwは配送物、配送手段、人のポートから道への移動を示す枝の集合)
(1)eの出発点がdの供給点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(2)eの出発点がdの需要点のとき
配送物はポートから道には出ない。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
∀e∈Epw
(Epwは配送物、配送手段、人のポートから道への移動を示す枝の集合)
(1)eの出発点がdの供給点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(2)eの出発点がdの需要点のとき
配送物はポートから道には出ない。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
以下、配送車と自転車で配送する場合とトラックで配送する場合に分けて説明する。
(配送車と自転車で配送する場合)
5.拠点から別の拠点へ移動するときの枝に対する制約
∀e∈Eww
(Ewwは配送物、配送手段、人の拠点間の移動を示す枝の集合)
(1)eが自転車の枝かつ車の枝のとき
自転車と車のそれぞれに配送スタッフが乗って移動している場合と、自転車を車に積載して移動している場合があり、車には必ず配送スタッフが乗ること、配送スタッフの人数は搭乗可能人数以下であること、運転できない自転車の台数は、車に積載可能な台数以下であることを制約とする。
(2)eが自転車の枝であるが車の枝ではないとき(自転車で移動している)
自転車の台数と人数が一致する。
(配送車と自転車で配送する場合)
5.拠点から別の拠点へ移動するときの枝に対する制約
∀e∈Eww
(Ewwは配送物、配送手段、人の拠点間の移動を示す枝の集合)
(1)eが自転車の枝かつ車の枝のとき
自転車と車のそれぞれに配送スタッフが乗って移動している場合と、自転車を車に積載して移動している場合があり、車には必ず配送スタッフが乗ること、配送スタッフの人数は搭乗可能人数以下であること、運転できない自転車の台数は、車に積載可能な台数以下であることを制約とする。
(2)eが自転車の枝であるが車の枝ではないとき(自転車で移動している)
自転車の台数と人数が一致する。
6.配送拠点の中で留まる枝に対する制約
車には必ず人が乗ることを制約とする。
車には必ず人が乗ることを制約とする。
(トラックで配送する場合)
5.配送拠点から別の配送拠点へ移動するときの枝に対する制約
トラックには必ず配送スタッフが乗ること、配送スタッフの人数は搭乗可能人数以下であること、配送物の総体積はトラックの積載量以下であることを制約とする。
5.配送拠点から別の配送拠点へ移動するときの枝に対する制約
トラックには必ず配送スタッフが乗ること、配送スタッフの人数は搭乗可能人数以下であること、配送物の総体積はトラックの積載量以下であることを制約とする。
6.配送拠点の中で留まる枝に対する制約
配送物の総体積はトラックの積載量以下であることを制約とする。
配送物の総体積はトラックの積載量以下であることを制約とする。
さらに、計算時間を短縮化するためにカットと呼ばれる制約式を適用することができる。整数計画問題において、実行可能領域の点が満たすことができる不等式を妥当不等式と呼ぶ。整数計画問題は、解くのが難しいため、まず整数条件を除いた線形緩和問題として扱うことも多い。線形緩和問題の解空間を削る妥当不等式を追加することをカットの追加と呼ぶ。カットの追加によって、線形緩和解が整数最適解に近づくことから、計算の高速化に強力な効果がある。カットの追加によって、実行可能領域は切断されないため、解の最適性は保証される。例えば、配送車は1台以上で来ることを規定するようなカットを加える。すると、配送車が3/4台で来るという現実的ではない場合を計算対象から除外することができ、計算速度を向上することができる。カットの具体例については、本願の出願人による特願2016-051550の明細書に記載されている。カットを追加した場合、カットを追加しない場合で数時間以上を要した整数計画問題について、数分で解くことが可能となった。
配送計画生成部12は、配送拠点の中を、道(d=0)と駐車ポート(d≠0)で分割した時空間ネットワークモデルを生成し、さらに上記制約条件、追加されたカットを用いて枝情報を計算する。本実施形態によれば、配送拠点内を0-1整数計画問題としてモデル化することができるので、第1の時空間ネットワークを用いて配送計画を生成する場合の効果に加え、配送計画の計算に要する時間が削減できるという効果が得られる。さらに、カットの追加により計算時間を大幅に短縮することができる。これにより、例えば、様々な初期条件下で生成された配送計画を比較し、より低コストな配送計画の選択を行うことができるようになるなど、計画立案者の利便性が向上する。
次に第2の時空間ネットワークを用いて配送計画を生成する事例について説明する。
図9は、本発明の第一実施形態における配送問題の一例を示す図である。
図10は、配送問題に対して生成した配送計画の一例を示す図である。
図9の点c0(depot)は出発拠点である。他の点w1~w9は配送拠点である。例えば、点w7において「d1:2」とあるのは、配送物d1が2個余っている状態を示し、点w5において「d2:-1」とあるのは、配送物d2が1個不足している状態を示している。点w2で「d1:-1、d2:1」とあるのは、配送物d1が1個不足し配送物d2が1個余っている状態を示している。図9が示す配送物d1~d3が遍在した状態から、各配送拠点で配送物d1~d3が不足した状態が無くなるように配送物d1~d3を配送する問題を考える。以下に車と自転車で配送する場合、トラックで配送する場合のそれぞれについて、配送計画装置10が生成した配送計画の例を挙げる。
図9は、本発明の第一実施形態における配送問題の一例を示す図である。
図10は、配送問題に対して生成した配送計画の一例を示す図である。
図9の点c0(depot)は出発拠点である。他の点w1~w9は配送拠点である。例えば、点w7において「d1:2」とあるのは、配送物d1が2個余っている状態を示し、点w5において「d2:-1」とあるのは、配送物d2が1個不足している状態を示している。点w2で「d1:-1、d2:1」とあるのは、配送物d1が1個不足し配送物d2が1個余っている状態を示している。図9が示す配送物d1~d3が遍在した状態から、各配送拠点で配送物d1~d3が不足した状態が無くなるように配送物d1~d3を配送する問題を考える。以下に車と自転車で配送する場合、トラックで配送する場合のそれぞれについて、配送計画装置10が生成した配送計画の例を挙げる。
1.車と自転車で配送する場合
(1)入力
・depotには、配送車1台、自転車3台、配送スタッフ3人
・配送期限:120分
・配送車のコスト:1.5円/分
・配送スタッフのコスト:17円/分
・d1、d2、d3のコスト:1.5円/分
・配送車の搭乗可能人数:4人、自転車の積載可能台数:1台
・d1の搭乗可能人数:1人、自転車の積載可能台数:0台
・d2の搭乗可能人数:4人、自転車の積載可能台数:1台
・d3の搭乗可能人数:2人、自転車の積載可能台数:0台
(2)目的関数
コスト最小化
(1)入力
・depotには、配送車1台、自転車3台、配送スタッフ3人
・配送期限:120分
・配送車のコスト:1.5円/分
・配送スタッフのコスト:17円/分
・d1、d2、d3のコスト:1.5円/分
・配送車の搭乗可能人数:4人、自転車の積載可能台数:1台
・d1の搭乗可能人数:1人、自転車の積載可能台数:0台
・d2の搭乗可能人数:4人、自転車の積載可能台数:1台
・d3の搭乗可能人数:2人、自転車の積載可能台数:0台
(2)目的関数
コスト最小化
この目的関数に対して上述の制約条件、カットを加えて、配送計画装置10に計算させると次のような出力結果が得られた。
(3)出力
・配送車1台、自転車1台、配送スタッフ2人で図10に示すようにS1~S7で示される配送ルートとT1~T9で示される配送ルートの2ルートに分かれて配送する。
・配送コスト:2768円
・必要な時間:60分
このように、初期条件で設定した配送手段、配送スタッフ、配送期限の条件内でコストを最小化する配送計画を得ることができる。
(3)出力
・配送車1台、自転車1台、配送スタッフ2人で図10に示すようにS1~S7で示される配送ルートとT1~T9で示される配送ルートの2ルートに分かれて配送する。
・配送コスト:2768円
・必要な時間:60分
このように、初期条件で設定した配送手段、配送スタッフ、配送期限の条件内でコストを最小化する配送計画を得ることができる。
配送計画装置10による第1の時空間ネットワーク又は第2の時空間ネットワークを用いた配送計画の生成は、搭乗輸送が可能な配送物の配送、調達、アフターサービス巡回にも適用可能である。例えば、アフターサービスにおいては、アフターサービスに必要な部品等を調達してから客先に向かったり、複数の客先を回ったりしてサービスを提供する必要がある。配送物をアフターサービスに使う部品等、配送主体をサービスマン、配送手段をサービスマンが移動に用いる車両や部品等の運搬に必要な配送車等、拠点を客先やアフターサービスの対象となる製品の設置場所として、上記の数理モデルを適用して整数計画問題を解くことができ、サービスマンが複数の客先でアフターサービスを行う場合に、その巡回コストや巡回時間を最小にする巡回方法(巡回手段、巡回経路)を算出することができる。図2の場合、例えば、駐車場A~駐車場C(配送拠点)を、アフターサービスを提供する客先、車両(配送物)を部品、乗用車(配送手段)をサービスマンが移動に用いる手段、配送者(配送主体)をサービスマンとすればよい。アフターサービスの場合、単に客先を巡回するだけでなく、客先で点検、修理などの作業を行う。時空間ネットワークモデルを用いた配送計画装置10、10A、10Bによれば、サービスマンの巡回行動を、これら作業時間を考慮に入れてモデル化することができる。
上記の例以外にも搭乗輸送を行わない配送物の配送に対しても適用することができる。例えば、ミルクランと呼ばれる集荷方法が存在する。ミルクランとは、ある製品のメーカが、その製品に使用する原材料や部品を、複数のサプライヤから仕入れる場合、各サプライヤに搬入させるのではなく、メーカが、各サプライヤを巡回して原材料等を集荷する調達方法のことである。ミルクランによって集荷を行うと、例えば、1台のトラックで集荷することで、各サプライヤに納入させる場合と比べてコスト削減、工場周辺の渋滞軽減、環境の負荷軽減を図ることができる。本実施形態の配送計画装置10によってミルクランの最適な巡回方法を算出する場合、例えば、製品メーカの納入先の工場等をカーシェアリングにおける需要のある配送拠点とし、原材料や部品の納入業者の工場等を車両が余っている配送拠点とすれば、上述した「トラックで配送する場合」と同様の目的関数、制約条件等を設定することで、配送計画を算出することができる。上記のトラックで配送する場合の「配送物の総体積はトラックの積載量以下であること」との制約条件については、「(原材料の重み×原材料の量+部品の重み×部品数)はトラックの積載量以下であること」との制約条件に変更する。あるサプライヤの集荷時間枠が指定されている場合、制約条件にその指定された集荷時間枠の情報を加えることで対応することができる。例えば、あるサプライヤへの到着時刻を(集荷の開始から)30分後以降にしなければならない場合、次のような制約条件を追加すれば、当該サプライヤの時間枠制約を守った集荷計画を生成することができる。
あるサプライヤへの到着時刻 ≧ 30分後
あるサプライヤへの到着時刻 ≧ 30分後
これまでに本実施形態の配送計画装置10が、配送計画を生成する処理について説明した。上述した方法によれば、配送計画装置10は、配送問題における厳密な最適解を求めることができる。しかしながら、上記の方法だけでは、問題の規模が大きくなると(例えば、配送拠点が20カ所で、配送する車両が20台)、実用的な時間で解を求めることが難しい場合がある。そこで、第一エリア分割部14は、配送拠点を配送エリアごとに分割して、与えられた配送問題を分割したエリアごとの配送問題に分割する。次に第一エリア分割部14によるエリア分割処理(第一エリア分割処理)について説明する。
図11は、本発明の第一実施形態における第一エリア分割処理を説明する第一の図である。
図11の左図は、配送計画の対象となる地域に存在する配送拠点と出発拠点の位置を示している。図中、丸点は配送拠点(w1~w17)、四角点は出発拠点(c1~c3)を示している。配送拠点w1~w17には、配送物の需要または余剰があり、出発拠点c1~c3には配送車や配送スタッフが存在している。第一エリア分割部14は、近隣に存在する需要のある配送拠点(需要点)と余剰がある配送拠点(供給点)とを対応させた組を生成し、さらに需要点と供給点の組を1つ又は複数集めて分割された一つのエリアを生成する。第一エリア分割部14によるエリアの生成を第一エリア分割処理と呼ぶ。
図11の左図は、配送計画の対象となる地域に存在する配送拠点と出発拠点の位置を示している。図中、丸点は配送拠点(w1~w17)、四角点は出発拠点(c1~c3)を示している。配送拠点w1~w17には、配送物の需要または余剰があり、出発拠点c1~c3には配送車や配送スタッフが存在している。第一エリア分割部14は、近隣に存在する需要のある配送拠点(需要点)と余剰がある配送拠点(供給点)とを対応させた組を生成し、さらに需要点と供給点の組を1つ又は複数集めて分割された一つのエリアを生成する。第一エリア分割部14によるエリアの生成を第一エリア分割処理と呼ぶ。
図11の右図は、第一エリア分割部14が第一エリア分割処理を行った結果を示している。配送拠点w1~w5はエリアj1、配送拠点w6~w9はエリアj2、配送拠点w10~w17はエリアj3にそれぞれ属している。配送計画生成部12は、分割後のエリアj1~エリアj3それぞれについて上記の方法で配送計画の生成を行う。エリアj1~エリアj3には、それぞれ10個未満の配送拠点しか含まれず、比較的小規模である。その為、配送計画生成部12は、上記した時空間ネットワークモデルを用いて実用的な時間で配送計画を生成することができる。
次に図11を用いて第一エリア分割処理の概要を説明する。まず、第一エリア分割部14は、配送拠点w1~w17を需要点と、供給点と、需要点でも供給点でもない配送拠点とに分ける。次に第一エリア分割部14は、需要点と供給点とを1対1に対応付ける。このとき、第一エリア分割部14は、需要点と供給点の距離(移動時間)が近いもの同士を対応付ける。例えば、図11の配送拠点w4では配送物d1が1余り、配送拠点w5では配送物d1が1足りない。配送拠点w6では配送物d1が1余り、配送拠点w7では配送物d1が1足りない。配送拠点w8では配送物d2が1余り、配送拠点w9では配送物d2が1足りないとする。この場合、第一エリア分割部14は、需要と供給が一致し、距離が近い配送拠点同士を対応付ける。すなわち、第一エリア分割部14は、配送拠点w4と配送拠点w5とを対応付け(組1とする)、配送拠点w6と配送拠点w7とを対応付け(組2とする)、配送拠点w8と配送拠点w9とを対応付ける(組3とする)。その他の需要点と供給点についても同様に対応付けを行う。
次に第一エリア分割部14は、対応付けた需要点と供給点の組について、距離の近い組同士を複数集めて1つのエリアを生成する。このとき、距離の近い組が他に無ければ1つの組を1つのエリアとしてもよい。例えば、上に挙げた例の場合、第一エリア分割部14は、組1の配送拠点w4と組2の配送拠点w6との距離を計算する。そして、計算した距離が所定の閾値より小さければ、組1と組2とを同じエリアに分類し、計算した距離が所定の閾値より大きければ、組1と組2とは別のエリアとして判定する。組の間の距離の計算については、例えば、組1と組2の距離の場合、配送拠点w4と配送拠点w7の距離を計算してもよいし、配送拠点w4~配送拠点w6間、配送拠点w4~配送拠点w7間、配送拠点w5~配送拠点w6間、配送拠点w5~配送拠点w7間の距離をそれぞれ計算し、計算した距離の平均を組1と組2との距離としてもよい。あるいは、計算した距離のうち最も大きい(又は最も小さい)距離を組1と組2との距離としてもよい。図11の例の場合、第一エリア分割部14は、例えば、組2と組3を同じエリアj2に分類し、組1をそれとは別のエリアj1に分類する。第一エリア分割部14は、他の配送拠点についても同様の処理を行い、配送拠点w1~w17をエリアごとに分類し、図11に示すエリアj1~エリアj3を生成する。
第一エリア分割処理によってエリアが生成されると、配送計画生成部12は、エリアj1~エリアj3のそれぞれについて、各エリア内の各配送拠点における配送物の供給数量、需要数量などを初期条件とする配送問題に対して、第1の時空間ネットワークモデル又は第2の時空間ネットワークモデルを用いて配送計画の生成を行ってもよいが、全く初期の状態から時空間ネットワークモデルを用いた計算を行わなくても、第一エリア分割処理の際の需要点と供給点の対応付けを枝情報として利用することができる。すなわち、配送計画生成部12は、対応付けた需要点から供給点への枝情報を生成し、それらを繋ぎ合わせることで全ての需要を満たす配送計画が生成できる。しかし、距離が最も近い配送拠点間を結んだ配送ルートだけでは、余りにも限定され過ぎており、複数の拠点間を移動する配送計画全体から見た場合、最適化された状態から遠ざかってしまう可能性がある。そこで、第一エリア分割部14は、配送計画生成部12が枝情報の生成を行う際に選択される可能性がある配送ルートを追加する処理を行う。そして、配送計画生成部12は、需要と供給を満たす最も近い配送拠点間を結ぶ配送ルートに追加された選択される可能性がある配送ルートを加えた全ての候補となる配送ルートの中から適切な配送ルートを選択して枝情報を生成し、エリアごとの配送計画を生成する。
図11では、需要点、供給点を配送拠点として説明したが、それぞれ需要のあるポート、供給のあるポートとしてもよい。
図11では、需要点、供給点を配送拠点として説明したが、それぞれ需要のあるポート、供給のあるポートとしてもよい。
次に第一エリア分割処理について詳しく説明する。
図12は、本発明の第一実施形態における第一エリア分割処理を説明する第二の図である。
以下に本実施形態の第一エリア分割処理のアルゴリズムを説明する。第一エリア分割部14は、以下の手順で各処理を行う。
1.まず、各配送拠点の各ポート(第1の時空間ネットワークモデルの場合は配送拠点)を供給点と需要点に分け、供給点の集合A、需要点の集合Bを生成する。V1=A∪Bとする。
2.次にV1に新しい点s、tを加え、V=V1∪{s,t}とする。
3.AからBに配送ルートe11~e19を作り、各配送ルートに対してその配送ルートが示す経路で配送した場合の移動時間に基づくコスト関数c(e)を定義する。
4.sからA、Bからtに配送ルートを作りそれらのコストを0とする。sからA、Bからtの配送ルートの集合をE2とし、E1とE2の和集合をEとする。
5.ここまでの処理で2部グラフG=(V,E)を構成する。
6.Gの最小重み最大マッチング、すなわちコストが最小となるsからtへの経路を算出する。より具体的には、sからtへの経路のうち、集合Aに含まれる各供給点から出る配送ルートの数が1、集合Bに含まれる各需要点に入る配送ルートの数が1という条件の下で、sと集合Aの各供給点と集合Bの各需要点とtとを結ぶ配送ルートのコストの合計が最小となる場合の配送ルートを算出する(主問題)。4.よりsから集合Aの各供給点へのコスト、集合Bの各需要点からtへのコストは0であるから、コストが最小となる場合の供給点a1~供給点a3と需要点b1~需要点b3との対応付け方を求めることができる。ここでコストは移動時間に基づく関数であるから、最も距離が近い供給点と需要点との1対1マッチングを求めることができる。図12の例では、例えばa1とb1とを結ぶ配送ルートe11、a2とb3とを結ぶ配送ルートe16、a3とb2とを結ぶ配送ルートe18の組み合わせがコストの合計が最小となる配送ルートであって、その場合、a1とb1、a2とb3、a3とb2が1対1で対応付けられる。
7.次に対応付けられた2つのポートが同じエリアに含まれるように、全てのポートをエリアで分割する。このとき、対応付けられた2つのポート間の移動時間が所定の値以下であれば1つのエリアに分類する。図12の例では、例えば、対応付けたa1とb1、a2とb3、a3とb2のうち、a1とb1を1つのエリア(j4)、a2とb3、a3とb2を1つのエリア(j5)として分類する。
図12は、本発明の第一実施形態における第一エリア分割処理を説明する第二の図である。
以下に本実施形態の第一エリア分割処理のアルゴリズムを説明する。第一エリア分割部14は、以下の手順で各処理を行う。
1.まず、各配送拠点の各ポート(第1の時空間ネットワークモデルの場合は配送拠点)を供給点と需要点に分け、供給点の集合A、需要点の集合Bを生成する。V1=A∪Bとする。
2.次にV1に新しい点s、tを加え、V=V1∪{s,t}とする。
3.AからBに配送ルートe11~e19を作り、各配送ルートに対してその配送ルートが示す経路で配送した場合の移動時間に基づくコスト関数c(e)を定義する。
4.sからA、Bからtに配送ルートを作りそれらのコストを0とする。sからA、Bからtの配送ルートの集合をE2とし、E1とE2の和集合をEとする。
5.ここまでの処理で2部グラフG=(V,E)を構成する。
6.Gの最小重み最大マッチング、すなわちコストが最小となるsからtへの経路を算出する。より具体的には、sからtへの経路のうち、集合Aに含まれる各供給点から出る配送ルートの数が1、集合Bに含まれる各需要点に入る配送ルートの数が1という条件の下で、sと集合Aの各供給点と集合Bの各需要点とtとを結ぶ配送ルートのコストの合計が最小となる場合の配送ルートを算出する(主問題)。4.よりsから集合Aの各供給点へのコスト、集合Bの各需要点からtへのコストは0であるから、コストが最小となる場合の供給点a1~供給点a3と需要点b1~需要点b3との対応付け方を求めることができる。ここでコストは移動時間に基づく関数であるから、最も距離が近い供給点と需要点との1対1マッチングを求めることができる。図12の例では、例えばa1とb1とを結ぶ配送ルートe11、a2とb3とを結ぶ配送ルートe16、a3とb2とを結ぶ配送ルートe18の組み合わせがコストの合計が最小となる配送ルートであって、その場合、a1とb1、a2とb3、a3とb2が1対1で対応付けられる。
7.次に対応付けられた2つのポートが同じエリアに含まれるように、全てのポートをエリアで分割する。このとき、対応付けられた2つのポート間の移動時間が所定の値以下であれば1つのエリアに分類する。図12の例では、例えば、対応付けたa1とb1、a2とb3、a3とb2のうち、a1とb1を1つのエリア(j4)、a2とb3、a3とb2を1つのエリア(j5)として分類する。
8.次に1.~5.の手順で作成した2部グラフを再度作成し、6.の双対問題を生成する(双対問題は数学的な操作で生成することができる)。枝e=(u,v)に対して、主問題の最適解X*(e)が1であれば、双対問題の最適解をYとした場合、c(e)-Y*(u)-Y*(v)=0となる(相補性条件:complementary slackness)ところ、c^(e)をc^(e)=c(e)-Y*(u)-Y*(v)で定義し、
0 ≦ c^(e) ≦ ε(εは所定の定数)
の条件により、c^(e)に幅を持たせる。この条件は、c^(e)=0だけでなく、c^(e)がε以下となる場合も配送ルートの候補として認めることを意味する。つまり、主問題でもコストが最小になる場合だけでなく、幅を持った解が得られる。この解の条件の緩和により、図12の例では、例えばa1とb1とを結ぶ配送ルートの候補e19が新たに得られる。
0 ≦ c^(e) ≦ ε(εは所定の定数)
の条件により、c^(e)に幅を持たせる。この条件は、c^(e)=0だけでなく、c^(e)がε以下となる場合も配送ルートの候補として認めることを意味する。つまり、主問題でもコストが最小になる場合だけでなく、幅を持った解が得られる。この解の条件の緩和により、図12の例では、例えばa1とb1とを結ぶ配送ルートの候補e19が新たに得られる。
以上で第一エリア分割処理が完了する。第一エリア分割処理が完了すると、配送計画生成部12が、分割後の各エリアについて配送計画を生成する。その際、配送計画生成部12は、第一エリア分割処理で得られた配送ルートの候補を使用して条件を満たす配送計画を生成する。具体的には、上述した「1.流量保存則」~「6.配送拠点の中で留まる枝に対する制約」に加えて、第一エリア分割処理で得られた配送ルートの候補(e11,e16,e18,e19)を用いることを制約条件に加えて、枝情報の集合を計算する。
次に本実施形態の配送計画の生成処理の流れについて説明する。
図13は、本発明の第一実施形態における配送計画の生成処理の一例を示すフローチャートである。
まず、配送計画を行う配送スタッフが、配送計画装置10に配送計画の初期条件を入力する。入出力部13はその入力を受け付け、受け付けた情報を初期条件設定部11に出力する。初期条件設定部11は、配送スタッフが入力した初期条件の情報を取得する(ステップS11)。初期条件設定部11は、取得した初期条件の情報を配送計画の初期条件に設定する。初期条件とは、例えば、各拠点における配送物の供給数量(余っている数量)、需要数量(不足している数量)、出発拠点にある配送車の台数、配送スタッフの人数、各拠点間の移動時間、配送期限などである。
次に、第一エリア分割部14は、初期条件の情報に含まれる各配送拠点(又はポート)での配送物の供給数量、需要数量を用いて、第一エリア分割処理を行う(ステップS12)。第一エリア分割処理については図11,図12を用いて説明したとおりである。
図13は、本発明の第一実施形態における配送計画の生成処理の一例を示すフローチャートである。
まず、配送計画を行う配送スタッフが、配送計画装置10に配送計画の初期条件を入力する。入出力部13はその入力を受け付け、受け付けた情報を初期条件設定部11に出力する。初期条件設定部11は、配送スタッフが入力した初期条件の情報を取得する(ステップS11)。初期条件設定部11は、取得した初期条件の情報を配送計画の初期条件に設定する。初期条件とは、例えば、各拠点における配送物の供給数量(余っている数量)、需要数量(不足している数量)、出発拠点にある配送車の台数、配送スタッフの人数、各拠点間の移動時間、配送期限などである。
次に、第一エリア分割部14は、初期条件の情報に含まれる各配送拠点(又はポート)での配送物の供給数量、需要数量を用いて、第一エリア分割処理を行う(ステップS12)。第一エリア分割処理については図11,図12を用いて説明したとおりである。
次に、配送計画生成部12は、第一エリア分割処理で得られたエリアごとに、図3や図8で例示した時空間ネットワークモデル上で、上記の各制約条件を満たすように枝情報を生成し、配送期限等の条件を満たす枝情報の集合を複数生成する(ステップS13)。具体的には、配送計画生成部12は、第一エリア分割処理で得られた配送ルートの候補について、配送物の数量、配送車の台数、配送スタッフの人数の情報を付加し、各制約条件(「1.流量保存則」~「6.配送拠点の中で留まる枝に対する制約」)を満たす枝情報を生成する。配送計画生成部12は、生成した枝情報を組み合わせて、配送期限までに各拠点の需要台数を満たすような配送を示す枝情報の集合を複数生成する。
次に、配送計画生成部12は、エリアごとに、生成した枝情報の集合ごとに総コストを計算する(ステップS14)。例えば、配送車、配送スタッフ、配送物ごとに単位時間あたりに発生する単位コストが予め記憶部15に記録されており、配送計画生成部12は、配送車、配送スタッフ、配送物の単位コストに各枝が示す時間を乗じて枝ごとのコスト(配送車、配送スタッフ、配送物に掛かるコストの合計)を計算する。配送計画生成部12は、枝情報の集合に含まれる枝ごとのコストを計算してそれらを合計する。合計したコストが1つの枝情報の集合に対するコストである。配送計画生成部12は、エリアごとに、全ての枝情報の集合それぞれについてコストを計算する。
次に配送計画生成部12は、エリアごとに、計算した各集合について計算したコストを比較し、総コストが最小となる枝情報の集合を選択する(ステップS15)。選択した枝情報の集合は、初期条件が示す出発拠点や各配送拠点の状態から、時間の経過に伴う配送物、配送手段、配送スタッフの移動を表している(図3、図8)。従って、枝情報の集合に基づいて配送を実行すれば、ユーザからの需要に応じた配送が可能になる。つまり、この枝情報の集合は、分割後の1つのエリアについての求める配送計画である。配送計画生成部12がエリアごとの配送計画を生成し終えると、初期条件として与えられた全配送拠点に対する配送計画が生成されたことになる。
本実施形態によれば、初期条件で与えられた配送拠点の全体を、近距離にある配送拠点の集合(エリア)に分割することによって、配送問題の規模を小さくすることができ、各エリアでの配送計画の生成処理の計算量を削減することができる。エリア分割を行う際に配送ルートの候補を算出し、それらの候補の中から配送ルートを選択して枝情報を生成するのでさらに計算量を削減することができる。これにより、配送物や配送拠点の数が多く、配送問題が大規模になった場合でも、実用的な時間(例えば10分)で配送計画を生成することができる。
配送計画生成部12は、ステップS13において配送ルートの候補を用いることなく枝情報を生成し、配送計画を生成してもよい。
エリアの配送計画のコストを加味してエリアを再構成してもよい。例えば、配送コストの差が著しく離れているエリアのペアに対して、早めに配送が完了するエリアを大きくし、遅く配送が完了するエリアを小さくすることで、全体のコストを下げることができる場合がある。
配送計画生成部12は、ステップS13において配送ルートの候補を用いることなく枝情報を生成し、配送計画を生成してもよい。
エリアの配送計画のコストを加味してエリアを再構成してもよい。例えば、配送コストの差が著しく離れているエリアのペアに対して、早めに配送が完了するエリアを大きくし、遅く配送が完了するエリアを小さくすることで、全体のコストを下げることができる場合がある。
<第二実施形態>
次に大規模な配送問題について実用的な時間で配送計画を生成する他の方法(第二実施形態)に係る配送計画システムについて図14~図18を参照して説明する。第一実施形態では、比較的近距離に存在する需要点と供給点に注目し、一対の需要点と供給点とを集めて小規模なエリアを生成した。第二実施形態では、出発拠点を中心にエリア分割処理を行い、分割後の各エリア内で配送計画を生成する。第二実施形態におけるエリア分割処理を第二エリア分割処理と呼ぶ。
次に大規模な配送問題について実用的な時間で配送計画を生成する他の方法(第二実施形態)に係る配送計画システムについて図14~図18を参照して説明する。第一実施形態では、比較的近距離に存在する需要点と供給点に注目し、一対の需要点と供給点とを集めて小規模なエリアを生成した。第二実施形態では、出発拠点を中心にエリア分割処理を行い、分割後の各エリア内で配送計画を生成する。第二実施形態におけるエリア分割処理を第二エリア分割処理と呼ぶ。
図14は、本発明の第二実施形態における配送計画システムの一例を示す機能ブロック図である。
本発明の第二実施形態に係る構成のうち、本発明の第一実施形態に係る配送計画装置10を構成する機能部と同じものには同じ符号を付し、それぞれの説明を省略する。第二実施形態に係る配送計画装置10Aは、第一実施形態の構成における第一エリア分割部14に代えて、第二エリア分割部16を備えている。
第二エリア分割部16は、出発拠点を出発して一部の配送拠点間に係る配送を行って元の出発拠点に戻るまでの予め設定された配送ルートとその配送ルートで配達したときのコストとを示す単位経路情報を複数取得する。第二エリア分割部16は、複数の単位経路情報の組み合わせの中から、当該組み合わせに含まれる、配送拠点の数が所定の数以内となり、且つ、コストが最小となる組み合わせを選択する。この単位経路情報の組み合わせに含まれる出発拠点および配送拠点の集合が分割後のエリアである。
第二エリア分割部16は、配送計画装置10Aが備えるCPUが、記憶部15からプログラムを読み出して実行することで実現される。
本発明の第二実施形態に係る構成のうち、本発明の第一実施形態に係る配送計画装置10を構成する機能部と同じものには同じ符号を付し、それぞれの説明を省略する。第二実施形態に係る配送計画装置10Aは、第一実施形態の構成における第一エリア分割部14に代えて、第二エリア分割部16を備えている。
第二エリア分割部16は、出発拠点を出発して一部の配送拠点間に係る配送を行って元の出発拠点に戻るまでの予め設定された配送ルートとその配送ルートで配達したときのコストとを示す単位経路情報を複数取得する。第二エリア分割部16は、複数の単位経路情報の組み合わせの中から、当該組み合わせに含まれる、配送拠点の数が所定の数以内となり、且つ、コストが最小となる組み合わせを選択する。この単位経路情報の組み合わせに含まれる出発拠点および配送拠点の集合が分割後のエリアである。
第二エリア分割部16は、配送計画装置10Aが備えるCPUが、記憶部15からプログラムを読み出して実行することで実現される。
図15は、本発明の第二実施形態における配送問題の第二エリア分割処理を説明する第一の図である。
図15において、丸点は配送拠点w1~配送拠点w17、四角点は出発拠点c1~出発拠点c3を示している。本実施形態では、まず、考えうるすべての需要・供給のパターンを列挙した上で、出発拠点ごとに各パターンの需要・供給を満たす単純な配送ルートを多数作成しておく。ここで、出発拠点c1~出発拠点c3には、十分な量の配送車(トラック)や配送スタッフが存在しており、配送拠点w1,w3,w6,w8,w10が供給点、配送拠点w2,w5,w7,w9,w11が需要点であるとする。配送に係る配送物の種類は同じであるとする。この場合、出発拠点ごとの需要・供給を満たす単純な配送ルートとは、例えば、出発拠点c1を出発し配送拠点w1に至り(R1)、配送拠点w1で配送物を取り、配送拠点w2へその配送物を運び(R2)、配達が終わったら出発拠点c1に戻る(R3)配送ルート(配送ルート1とする)である。同様に、出発拠点c1から配送拠点w3、配送拠点w5を経由して出発拠点c1に戻るルート(配送ルート2とする)、出発拠点c1から配送拠点w6、配送拠点w7を経由して出発拠点c1に戻る配送ルート(配送ルート3とする)、出発拠点c2から配送拠点w8、配送拠点w9を経由して出発拠点c2に戻る配送ルート(配送ルート4とする)、出発拠点c3から配送拠点w10、配送拠点w11を経由して出発拠点c3に戻る配送ルート(配送ルート5とする)などである。これらの単純なルートは予め多数作成され、記憶部15に記録されている。図示しないが、例えば以下のようなルートも作成され予め記憶部15に記録されている。出発拠点c1から配送拠点w1と配送拠点w5を経由して出発拠点c1に戻る配送ルート、出発拠点c1から配送拠点w1と配送拠点w7を経由して出発拠点c1に戻る配送ルート、出発拠点c1から配送拠点w3と配送拠点w2を経由して出発拠点c1に戻る配送ルート、出発拠点c1から配送拠点w10と配送拠点w11を経由して出発拠点c1に戻る配送ルート、出発拠点c2から配送拠点w1と配送拠点w2を経由して出発拠点c2に戻る配送ルート、出発拠点c3から配送拠点w1と配送拠点w2を経由して出発拠点c3に戻る配送ルート、などである。
図15において、丸点は配送拠点w1~配送拠点w17、四角点は出発拠点c1~出発拠点c3を示している。本実施形態では、まず、考えうるすべての需要・供給のパターンを列挙した上で、出発拠点ごとに各パターンの需要・供給を満たす単純な配送ルートを多数作成しておく。ここで、出発拠点c1~出発拠点c3には、十分な量の配送車(トラック)や配送スタッフが存在しており、配送拠点w1,w3,w6,w8,w10が供給点、配送拠点w2,w5,w7,w9,w11が需要点であるとする。配送に係る配送物の種類は同じであるとする。この場合、出発拠点ごとの需要・供給を満たす単純な配送ルートとは、例えば、出発拠点c1を出発し配送拠点w1に至り(R1)、配送拠点w1で配送物を取り、配送拠点w2へその配送物を運び(R2)、配達が終わったら出発拠点c1に戻る(R3)配送ルート(配送ルート1とする)である。同様に、出発拠点c1から配送拠点w3、配送拠点w5を経由して出発拠点c1に戻るルート(配送ルート2とする)、出発拠点c1から配送拠点w6、配送拠点w7を経由して出発拠点c1に戻る配送ルート(配送ルート3とする)、出発拠点c2から配送拠点w8、配送拠点w9を経由して出発拠点c2に戻る配送ルート(配送ルート4とする)、出発拠点c3から配送拠点w10、配送拠点w11を経由して出発拠点c3に戻る配送ルート(配送ルート5とする)などである。これらの単純なルートは予め多数作成され、記憶部15に記録されている。図示しないが、例えば以下のようなルートも作成され予め記憶部15に記録されている。出発拠点c1から配送拠点w1と配送拠点w5を経由して出発拠点c1に戻る配送ルート、出発拠点c1から配送拠点w1と配送拠点w7を経由して出発拠点c1に戻る配送ルート、出発拠点c1から配送拠点w3と配送拠点w2を経由して出発拠点c1に戻る配送ルート、出発拠点c1から配送拠点w10と配送拠点w11を経由して出発拠点c1に戻る配送ルート、出発拠点c2から配送拠点w1と配送拠点w2を経由して出発拠点c2に戻る配送ルート、出発拠点c3から配送拠点w1と配送拠点w2を経由して出発拠点c3に戻る配送ルート、などである。
単純な配送ルートとは、1つの供給点、1つの需要点を経由して元の出発拠点に戻る配送ルート(2つの配送拠点を巡回して元の出発拠点に戻るルート)のことだけを指すのではなく、出発拠点c1を出発して、配送拠点w1にて配送物を2つ取り、配送拠点w2と配送拠点w4に配送物を一つずつ届け出発拠点c1に戻るという配送ルートであってもよい(配送拠点が3つの例)。あるいは、出発拠点c1を出発して、配送拠点w1にて配送物を1つ取り配送拠点w2に届け、続いて配送拠点w3にて配送物を1つ取り配送拠点w4に届け、出発拠点c1に戻るという配送ルートであってもよい(配送拠点が4つの例)。
図16は、本発明の第二実施形態における配送問題の第二エリア分割処理を説明する第二の図である。
図16に図示するように記憶部15には、予め用意された単純な配送ルートが複数記録されている。単純な配送ルートに対応付けて、その配送ルートで配送した場合のコストが記録されている。コストは、例えば移動時間の関数として与えられる。予め記録された単純な配送ルートとコストの情報は、多ければ多い程、より精度の高い(厳密な最適解に近い)配送計画を生成することができる。図16に例示する単純な配送ルートとその配送ルートに対応するコストを含む情報を単位経路情報とよぶ。
図16に図示するように記憶部15には、予め用意された単純な配送ルートが複数記録されている。単純な配送ルートに対応付けて、その配送ルートで配送した場合のコストが記録されている。コストは、例えば移動時間の関数として与えられる。予め記録された単純な配送ルートとコストの情報は、多ければ多い程、より精度の高い(厳密な最適解に近い)配送計画を生成することができる。図16に例示する単純な配送ルートとその配送ルートに対応するコストを含む情報を単位経路情報とよぶ。
図17は、本発明の第二実施形態における配送問題の第二エリア分割処理を説明する第三の図である。
次に第二エリア分割部16による第二エリア分割処理について図15~図17を用いて説明する。
前提として、記憶部15には図16で例示した単位経路情報が記録されている。配送に関する要求事項(配送拠点ごとの需要数量、供給数量、出発拠点の配送車の台数、配送スタッフの人数など)の初期条件が与えられるとする。
1.まず第二エリア分割部16は、初期条件で与えられる配送要求(需要)のうち、一部を満たす配送ルートを含む単位経路情報を記憶部15から読み出す。
2.次に第二エリア分割部16は、読み出した単位経路情報に含まれる配送ルートを組み合わせて、全ての配送要求を満たすルートを作成し、暫定解とする。ここで、予め記録された単純な配送ルートを組み合わせて、全ての要求を満たし且つコストが最も安くなる組み合わせを求める方法として、集合分割アプローチと呼ばれる数学的手法が用いられるが、この手法の場合、単純な配送ルートの数が膨大になると、その組み合わせの最適化問題は実用的な時間では解くことができない場合がある。その為、第二エリア分割部16は、記憶部15が記憶する多数の単純な配送ルートのうち、少数の配送ルートを用いて初期解を生成し、列生成法と呼ばれる数学的手法を用いて、単純な配送ルートを追加しながら最適解を求める。初期解を生成するための少数の単純な配送ルートは、任意の方法で選択してよい。初期解の生成には、一般的に提供されているソルバーを用いることができる。このとき、1つの出発拠点が担当する配送拠点の数に制約(例えば、需要点と供給点を含め6拠点以内など)を設ける。ここで、配送拠点の数に制約(上限)を設けるのは、計算量を削減し、処理を高速化するためである。制約する配送拠点の数については、例えば、実際に計算を行い、実用的な時間内に解が求められる場合の配送拠点の数を上限として定めてもよい。初期解として、例えば、図15に示す解(配送ルート1~配送ルート5)が得られる。
次に第二エリア分割部16による第二エリア分割処理について図15~図17を用いて説明する。
前提として、記憶部15には図16で例示した単位経路情報が記録されている。配送に関する要求事項(配送拠点ごとの需要数量、供給数量、出発拠点の配送車の台数、配送スタッフの人数など)の初期条件が与えられるとする。
1.まず第二エリア分割部16は、初期条件で与えられる配送要求(需要)のうち、一部を満たす配送ルートを含む単位経路情報を記憶部15から読み出す。
2.次に第二エリア分割部16は、読み出した単位経路情報に含まれる配送ルートを組み合わせて、全ての配送要求を満たすルートを作成し、暫定解とする。ここで、予め記録された単純な配送ルートを組み合わせて、全ての要求を満たし且つコストが最も安くなる組み合わせを求める方法として、集合分割アプローチと呼ばれる数学的手法が用いられるが、この手法の場合、単純な配送ルートの数が膨大になると、その組み合わせの最適化問題は実用的な時間では解くことができない場合がある。その為、第二エリア分割部16は、記憶部15が記憶する多数の単純な配送ルートのうち、少数の配送ルートを用いて初期解を生成し、列生成法と呼ばれる数学的手法を用いて、単純な配送ルートを追加しながら最適解を求める。初期解を生成するための少数の単純な配送ルートは、任意の方法で選択してよい。初期解の生成には、一般的に提供されているソルバーを用いることができる。このとき、1つの出発拠点が担当する配送拠点の数に制約(例えば、需要点と供給点を含め6拠点以内など)を設ける。ここで、配送拠点の数に制約(上限)を設けるのは、計算量を削減し、処理を高速化するためである。制約する配送拠点の数については、例えば、実際に計算を行い、実用的な時間内に解が求められる場合の配送拠点の数を上限として定めてもよい。初期解として、例えば、図15に示す解(配送ルート1~配送ルート5)が得られる。
3.次に第二エリア分割部16は、列生成法(公知の数学的手法)によって未選択の単純な配送ルートの中から1つ又は複数の配送ルートを選択し、既に選択されたある単純な配送ルートと選択した単純な配送ルートを入れ替えた場合の減少コストを計算する。減少コストとは、入れ替えにより新たに解として選択された単純な配送ルートに対応付けられて記録されたコスト(図16のコスト欄)の合計から、入れ替え前に選択されていた元々の単純な配送ルートに対応付けられて記録されたコストの合計を引いた値である。
4.第二エリア分割部16は、3.で計算した減少コストが負の値(入れ替え後の方が安い)ならば、3.で選択した単純な配送ルートで既存の全配送ルートの一部を更新する。例えば、配送拠点w7への配送に関して、図15に示す初期解では、配送ルート3が選択されているが、第二エリア分割部16は、この配送ルート3に代えて、出発拠点c2から配送拠点w6、配送拠点w7を経由して出発拠点c2へ戻るルート(配送ルート6とする)に入れ替えた場合の減少コストを計算する。図16により配送ルート3のコストは2500、配送ルート6のコストは1500であるから、減少コストは、-1000である。従って、第二エリア分割部16は、配送ルート3を配送ルート6で更新する。更新後の単純な配送ルートの組み合わせを図17に示す。減少コストを計算する場合も、第二エリア分割部16は、1つの出発拠点が担当する拠点の数が制約内となるように配送ルートを選択する。
この例では、単純な配送ルートを出発拠点c1の担当範囲から出発拠点c3の担当範囲へ移す例を挙げたが、配送ルートの更新は、この例に限定されない。例えば、図15の状態で、出発拠点c1が担当するルート内の配送ルート1と配送ルート2の組み合わせを、出発拠点c1から配送拠点w3、配送拠点w2を経由して出発拠点c1へ戻るルートと出発拠点c1から配送拠点w1、配送拠点w5を経由して出発拠点c1へ戻るルートの組み合わせに更新する方法でもよい。あるいは、配送拠点w1に対象とする配送物が2つあるとして、配送ルート1と配送ルート2の組み合わせを、出発拠点c1から配送拠点w1、配送拠点w2、配送拠点w3、配送拠点w5を経由して出発拠点c1へ戻る配送ルートに更新する方法でもよい。
5.第二エリア分割部16は、3.~4.の処理を繰り返し、コストを減少できるルートが無くなった時点で第二エリア分割処理を終了する。第二エリア分割処理が終了すると、出発拠点ごとに制約条件(例えば6拠点)以内の配送拠点が関連付けられることになる。この関連付けられた複数の配送拠点と出発拠点の集合(例えば、エリアj6~エリアj8のそれぞれ)が、第二エリア分割処理によって得られるエリアである。
次に本実施形態の配送計画の生成処理の流れについて説明する。
図18は、本発明の第二実施形態における配送計画の生成処理の一例を示すフローチャートである。図13と同様の処理については簡単に説明を行う。
まず、初期条件設定部11は、配送スタッフなどが入力した初期条件の情報を取得する(ステップS11)。
次に、第二エリア分割部16は、初期条件の情報に含まれる各拠点での配送物の供給数量、需要数量、出発拠点での配送スタッフ数、配送車の種類及び数を用いて、第二エリア分割処理を行う(ステップS121)。第二エリア分割処理については図15~図17を用いて説明したとおりである。
図18は、本発明の第二実施形態における配送計画の生成処理の一例を示すフローチャートである。図13と同様の処理については簡単に説明を行う。
まず、初期条件設定部11は、配送スタッフなどが入力した初期条件の情報を取得する(ステップS11)。
次に、第二エリア分割部16は、初期条件の情報に含まれる各拠点での配送物の供給数量、需要数量、出発拠点での配送スタッフ数、配送車の種類及び数を用いて、第二エリア分割処理を行う(ステップS121)。第二エリア分割処理については図15~図17を用いて説明したとおりである。
次に、配送計画生成部12は、第二エリア分割処理で得られたエリア(第二エリア分割処理で得られた出発拠点とその出発拠点に関連付けられた複数の配送拠点の集合)ごとに、図3や図8で例示した時空間ネットワークモデル上で、上記の各制約条件を満たすように枝情報を生成し、配送期限等の条件を満たす枝情報の集合を複数生成する(ステップS131)。図17の例では、配送計画生成部12は、エリアj6~エリアj8のそれぞれについて、枝情報の集合を複数生成する。配送計画生成部12は、第二エリア分割処理で用いた単純な配送ルート及びその組み合わせに関係なく枝情報の生成を行ってもよいし、単純な配送ルート及びその組み合わせを利用して枝情報の生成を行ってもよい。
次に、配送計画生成部12は、生成した枝情報の集合ごとに総コストを計算する(ステップS14)。図17の例では、配送計画生成部12は、エリアj6~エリアj8のそれぞれについて、生成した枝情報の集合ごとの総コストを計算する。
次に配送計画生成部12は、計算した総コストを比較し、総コストが最小となる枝情報の集合を選択する(ステップS15)。図17の例では、配送計画生成部12は、エリアj6~エリアj8のそれぞれについて、総コストが最小となる枝情報の集合を選択する。
選択した枝情報の集合は、各エリアにおける配送計画を示している。つまり、配送計画生成部12がエリアごとの配送計画を生成し終えると、分割前の全配送拠点についての配送計画が生成されたことになる。
次に配送計画生成部12は、計算した総コストを比較し、総コストが最小となる枝情報の集合を選択する(ステップS15)。図17の例では、配送計画生成部12は、エリアj6~エリアj8のそれぞれについて、総コストが最小となる枝情報の集合を選択する。
選択した枝情報の集合は、各エリアにおける配送計画を示している。つまり、配送計画生成部12がエリアごとの配送計画を生成し終えると、分割前の全配送拠点についての配送計画が生成されたことになる。
本実施形態によれば、初期条件で与えられた需要や供給のある全ての配送拠点の一つ一つを出発拠点に関連付けることによって出発拠点ごとの配送エリアに分割することができる。小規模な配送エリアに分割し、それらの配送エリアごとに配送計画の生成処理を行うことで、初期条件で与えられた全ての需要のある配送拠点を対象にして配送計画を生成する場合に比べ、配送計画の生成に必要な計算量を削減することができる。これにより、配送物や配送拠点の数が多く、配送問題が大規模になった場合でも、実用的な時間(例えば10分)で配送計画を立案することができる。
<第三実施形態>
さらに大規模な配送問題について実用的な時間で配送計画を生成する他の方法(第三実施形態)に係る配送計画システムについて図19~図22を参照して説明する。第一実施形態、第二実施形態は、初期条件に含まれる配送拠点ごとの需要および供給の情報に基づいて配送問題を空間的に分割(エリア分割)することにより小規模な配送問題に分割し、小規模な配送問題を解くことにより処理の高速化を実現する方法であった。この第三実施形態では、初期条件に含まれる配送物の配送制限時間の情報に基づいて時間的な分割により配送問題を小問題化し、分割後の各時間ごとに配送計画を生成する。
さらに大規模な配送問題について実用的な時間で配送計画を生成する他の方法(第三実施形態)に係る配送計画システムについて図19~図22を参照して説明する。第一実施形態、第二実施形態は、初期条件に含まれる配送拠点ごとの需要および供給の情報に基づいて配送問題を空間的に分割(エリア分割)することにより小規模な配送問題に分割し、小規模な配送問題を解くことにより処理の高速化を実現する方法であった。この第三実施形態では、初期条件に含まれる配送物の配送制限時間の情報に基づいて時間的な分割により配送問題を小問題化し、分割後の各時間ごとに配送計画を生成する。
図19は、本発明の第三実施形態における配送計画システムの一例を示す機能ブロック図である。
本発明の第三実施形態に係る構成のうち、本発明の第一実施形態に係る配送計画装置10Bを構成する機能部と同じものには同じ符号を付し、それぞれの説明を省略する。第三実施形態に係る配送計画装置10Bは、第一実施形態の構成における第一エリア分割部14に代えて、時間分割部17を備えている。配送計画装置10Bは、配送計画生成部12に代えて、配送計画生成部12aを備えている。
時間分割部17は、初期条件で与えられた配送制限時間を複数の時間に分割することにより配送問題を分割した時間ごとの規模の小さな配送問題に分割する。時間分割部17が分割して出来た各時間を区間と呼ぶ。
配送計画生成部12aは、時間分割部17が分割してできた区間に応じて、異なる目的関数や制約を設定した配送問題を解いて配送計画を生成する。例えば、配送計画生成部12aは、分割後の各区間の最初の時刻における配送物の配送状況(1つ前の区間が終わったときの配送の進捗状況)から配送を開始して、当該区間内に配送物がなるべく多く需要のある配送拠点に配送されるような配送計画を生成する。時間分割部17は、分割してできた区間のうち最後の区間については、その最後の区間内に初期条件で示された需要のある配送拠点の中で未配送となっている配送拠点の全てに配送物が配送される配送計画を生成する。
時間分割部17、配送計画生成部12aは、配送計画装置10Bが備えるCPUが、記憶部15からプログラムを読み出して実行することで実現される。
本発明の第三実施形態に係る構成のうち、本発明の第一実施形態に係る配送計画装置10Bを構成する機能部と同じものには同じ符号を付し、それぞれの説明を省略する。第三実施形態に係る配送計画装置10Bは、第一実施形態の構成における第一エリア分割部14に代えて、時間分割部17を備えている。配送計画装置10Bは、配送計画生成部12に代えて、配送計画生成部12aを備えている。
時間分割部17は、初期条件で与えられた配送制限時間を複数の時間に分割することにより配送問題を分割した時間ごとの規模の小さな配送問題に分割する。時間分割部17が分割して出来た各時間を区間と呼ぶ。
配送計画生成部12aは、時間分割部17が分割してできた区間に応じて、異なる目的関数や制約を設定した配送問題を解いて配送計画を生成する。例えば、配送計画生成部12aは、分割後の各区間の最初の時刻における配送物の配送状況(1つ前の区間が終わったときの配送の進捗状況)から配送を開始して、当該区間内に配送物がなるべく多く需要のある配送拠点に配送されるような配送計画を生成する。時間分割部17は、分割してできた区間のうち最後の区間については、その最後の区間内に初期条件で示された需要のある配送拠点の中で未配送となっている配送拠点の全てに配送物が配送される配送計画を生成する。
時間分割部17、配送計画生成部12aは、配送計画装置10Bが備えるCPUが、記憶部15からプログラムを読み出して実行することで実現される。
図20は、本発明の第三実施形態における配送問題の時間分割処理を説明する第一の図である。
図20の左図は、ある配送問題の初期状態を示している。配送拠点w1では配送物d1が2個余っており、配送拠点w2では配送物d1が3個余っている。配送拠点w3では配送物d1が4個不足しており、配送拠点w4では配送物d1が1個不足している。この初期状態から配送物d1を、120分以内に配送拠点w3、配送拠点w4における需要を満たすように配送する問題を考える。第一実施形態、第二実施形態では、配送拠点w1~配送拠点w4をエリアごとに分割した。本実施形態では、初期条件として与えられた配送制限時間120分を分割する。
具体的には、時間分割部17は、配送制限時間120分を複数の時間(区間)に分割する。例えば、時間分割部17は、配送制限時間120分を前半60分、後半60分の2つの区間に分割する。時間分割部17が分割してできる1区間の時間の長さや区間の数は任意であってよい。例えば、時間分割部17は、120分を90分と30分に分割してもよいし、40分ごとの3つの区間に分類してもよい。時間分割部17は、初期条件で与えられた配送制限時間よりも所定の時間だけ短い時間を分割後の1番目の区間とし、残りの時間を最後の区間としてもよい。
図20の左図は、ある配送問題の初期状態を示している。配送拠点w1では配送物d1が2個余っており、配送拠点w2では配送物d1が3個余っている。配送拠点w3では配送物d1が4個不足しており、配送拠点w4では配送物d1が1個不足している。この初期状態から配送物d1を、120分以内に配送拠点w3、配送拠点w4における需要を満たすように配送する問題を考える。第一実施形態、第二実施形態では、配送拠点w1~配送拠点w4をエリアごとに分割した。本実施形態では、初期条件として与えられた配送制限時間120分を分割する。
具体的には、時間分割部17は、配送制限時間120分を複数の時間(区間)に分割する。例えば、時間分割部17は、配送制限時間120分を前半60分、後半60分の2つの区間に分割する。時間分割部17が分割してできる1区間の時間の長さや区間の数は任意であってよい。例えば、時間分割部17は、120分を90分と30分に分割してもよいし、40分ごとの3つの区間に分類してもよい。時間分割部17は、初期条件で与えられた配送制限時間よりも所定の時間だけ短い時間を分割後の1番目の区間とし、残りの時間を最後の区間としてもよい。
図20の右図は、時間分割部17が、配送制限時間120分を60分ずつの2つの区間に分割したことを示している。時間分割部17が配送制限時間の分割を行うと、配送計画生成部12aが、分割してできた1つ目の区間について配送計画の生成を行う。このとき、配送計画生成部12aは、全ての要求を満たすことを目指すのではなく、1つ目の区間の終了時点にできるだけ多くの要求を満たせるような配送計画を生成する。全ての要求を満たすことを目指すとは、この例の場合、配送拠点w3と配送拠点w4の需要数量を満足するように配送物d1を60分で配送することである。できるだけ多くの要求を満たせるような配送計画とは、例えば、配送を開始してから60分後に、配送拠点w3での配送物d1の不足が3個、配送拠点w4での配送物d1の不足が0個となる配送計画と、配送拠点w3での配送物d1の不足が2個、配送拠点w4での配送物d1の不足が0個となる配送計画が生成できた場合、後者の配送計画のことをいう。
次に1つ目の区間について設定する目的関数、制約について説明する。次に説明する目的関数等は、より一般的には、時間分割部17が、配送制限時間をN個に分割した場合、最後の区間(N番目の区間)を除く、全ての区間(時間の流れに沿って順に1番目の区間からN-1番目の区間)について使用する目的関数等である。
(目的関数)
以下の(1)~(7)の和を最小化する。
(1)拠点間の移動コスト
拠点間の移動コストを抑制することができる。
(2)需要供給を満たす時刻
需要供給を満たす時刻をなるべく早くするよう促すことで解の選択肢が減る(後の時刻でも同様な配送が可能な場合でも、最先の配送のみを解とすることで選択肢を減らすことができ、計算量の削減につながる)。
(3)需要を満たす場合に供給を行うポート番号
小さい番号のポートから供給を行うよう促すことで解の選択肢が減る(大きい番号のポートに配送しても問題ない場合でも、もっとも小さい番号のポートと定めておくことで解の選択肢を減らし計算量を削減することができる)。
(4)配送拠点に存在する人、配送手段のうち、後の区間で使用しないものの数(g[w])
計算中の区間の最後の時刻において,次の区間で配送物の配送に用いられない余分な人・配送手段を出発拠点に移動させることを促す。例えば、第一区間の最後の時刻において、自転車を載せて移動できる配送手段が無くなっている場合、第二区間では自転車を配送に使用しないため出発拠点に移動させる。
(5)需要点における需要、供給点における供給が満たされた場合であって、それらの配送拠点に存在する人、配送手段の数
需要供給が満たされた配送拠点において、人や配送手段が残らないようにすることを促す。本実施形態では、時間分割を行ったそれぞれの区間について(一つ前の区間における配送状況の引き継ぎは行うが)、独立して配送計画を算出するので、後の区間で使用しない余分な配送スタッフや配送手段が配送拠点に残ってしまうことも考えられる。そこで(4)、(5)を加えて余分な配送スタッフなどが配送拠点に残らないようにする。
(6)供給点に残っている配送物の数、需要点で足りない配送物の数
(7)配送物が足りない需要点の数
(6)、(7)によって、その区間の最後の時刻において、なるべく需要供給の条件をできるだけ多く満たすことを促すことができる。
目的関数は、各項目(1)~(7)の各々の内容に対応する関数の和を最小化することとして表されるが、目的関数の各項(各項目の関数)に任意の係数を乗算して重み付けを行ってもよい。
以下の(1)~(7)の和を最小化する。
(1)拠点間の移動コスト
拠点間の移動コストを抑制することができる。
(2)需要供給を満たす時刻
需要供給を満たす時刻をなるべく早くするよう促すことで解の選択肢が減る(後の時刻でも同様な配送が可能な場合でも、最先の配送のみを解とすることで選択肢を減らすことができ、計算量の削減につながる)。
(3)需要を満たす場合に供給を行うポート番号
小さい番号のポートから供給を行うよう促すことで解の選択肢が減る(大きい番号のポートに配送しても問題ない場合でも、もっとも小さい番号のポートと定めておくことで解の選択肢を減らし計算量を削減することができる)。
(4)配送拠点に存在する人、配送手段のうち、後の区間で使用しないものの数(g[w])
計算中の区間の最後の時刻において,次の区間で配送物の配送に用いられない余分な人・配送手段を出発拠点に移動させることを促す。例えば、第一区間の最後の時刻において、自転車を載せて移動できる配送手段が無くなっている場合、第二区間では自転車を配送に使用しないため出発拠点に移動させる。
(5)需要点における需要、供給点における供給が満たされた場合であって、それらの配送拠点に存在する人、配送手段の数
需要供給が満たされた配送拠点において、人や配送手段が残らないようにすることを促す。本実施形態では、時間分割を行ったそれぞれの区間について(一つ前の区間における配送状況の引き継ぎは行うが)、独立して配送計画を算出するので、後の区間で使用しない余分な配送スタッフや配送手段が配送拠点に残ってしまうことも考えられる。そこで(4)、(5)を加えて余分な配送スタッフなどが配送拠点に残らないようにする。
(6)供給点に残っている配送物の数、需要点で足りない配送物の数
(7)配送物が足りない需要点の数
(6)、(7)によって、その区間の最後の時刻において、なるべく需要供給の条件をできるだけ多く満たすことを促すことができる。
目的関数は、各項目(1)~(7)の各々の内容に対応する関数の和を最小化することとして表されるが、目的関数の各項(各項目の関数)に任意の係数を乗算して重み付けを行ってもよい。
次に制約について説明する。
1.流量保存則
(ア)分割後の各区間のうち最後の区間以外の区間の場合
(1)配送物の流量について
区間の開始時点においては、供給が存在するポートから出る流量は1、供給が存在しないポートから出る流量は0となる。その他の点で、区間の終了時点でない場合は、出ていく流量と入る流量は等しい。
(2)配送車の流量について
区間の開始時点においては、道から出る流量は、その拠点に存在する配送車の数となる。その他の点で、区間の終了時点でない場合は、出ていく流量と入る流量は等しい。
(3)配送スタッフの流量について
区間の開始時点においては、道から出る流量は、その拠点に存在する配送スタッフの数となる。その他の点で、区間の終了時点でない場合は、出ていく流量と入る流量は等しい。
1.流量保存則
(ア)分割後の各区間のうち最後の区間以外の区間の場合
(1)配送物の流量について
区間の開始時点においては、供給が存在するポートから出る流量は1、供給が存在しないポートから出る流量は0となる。その他の点で、区間の終了時点でない場合は、出ていく流量と入る流量は等しい。
(2)配送車の流量について
区間の開始時点においては、道から出る流量は、その拠点に存在する配送車の数となる。その他の点で、区間の終了時点でない場合は、出ていく流量と入る流量は等しい。
(3)配送スタッフの流量について
区間の開始時点においては、道から出る流量は、その拠点に存在する配送スタッフの数となる。その他の点で、区間の終了時点でない場合は、出ていく流量と入る流量は等しい。
(イ)分割後の各区間のうち最後の区間の場合
(1)配送物の流量について
区間の開始時点においては、供給が存在するポートから出る流量は1、供給が存在しないポートから出る流量は0となる。区間の終了時点においては、需要が存在するポートに入る流量は1、需要が存在しないポートに入る流量は0となる。その他の点では、出ていく流量と入る流量は等しい。
(2)配送車の流量について
区間の配送開始時点においては、道から出る流量は、その拠点に存在する配送車の数となる。区間の終了時点においては、道から入る流量は、その拠点で需要がある配送車の数となる。その他の点では、出ていく流量と入る流量は等しい。
(3)配送スタッフの流量について
区間の配送開始時点においては、道から出る流量は、その拠点に存在する配送スタッフの人数となる。区間の終了時点においては、道から入る流量は、その拠点で需要がある配送スタッフの人数となる。その他の点では、出ていく流量と入る流量は等しい。
(1)配送物の流量について
区間の開始時点においては、供給が存在するポートから出る流量は1、供給が存在しないポートから出る流量は0となる。区間の終了時点においては、需要が存在するポートに入る流量は1、需要が存在しないポートに入る流量は0となる。その他の点では、出ていく流量と入る流量は等しい。
(2)配送車の流量について
区間の配送開始時点においては、道から出る流量は、その拠点に存在する配送車の数となる。区間の終了時点においては、道から入る流量は、その拠点で需要がある配送車の数となる。その他の点では、出ていく流量と入る流量は等しい。
(3)配送スタッフの流量について
区間の配送開始時点においては、道から出る流量は、その拠点に存在する配送スタッフの人数となる。区間の終了時点においては、道から入る流量は、その拠点で需要がある配送スタッフの人数となる。その他の点では、出ていく流量と入る流量は等しい。
2.容量制約
配送拠点内の配送物、人の移動量は1以下である。
配送拠点内の配送物、人の移動量は1以下である。
3.配送拠点内の制約1
∀e∈Ewp
(Ewpは配送物、配送手段、人の道からポートへの移動を示す枝の集合)
(1)eの行き先がdの供給点のとき
配送物は道からポートには入ってこない。
(2)eの行き先がdの需要点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
∀e∈Ewp
(Ewpは配送物、配送手段、人の道からポートへの移動を示す枝の集合)
(1)eの行き先がdの供給点のとき
配送物は道からポートには入ってこない。
(2)eの行き先がdの需要点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
4.配送拠点内の制約2
∀e∈Epw
(Epwは配送物、配送手段、人のポートから道への移動を示す枝の集合)
(1)eの出発点がdの供給点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(2)eの出発点がdの需要点のとき
配送物はポートから道には出ない。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
∀e∈Epw
(Epwは配送物、配送手段、人のポートから道への移動を示す枝の集合)
(1)eの出発点がdの供給点のとき
配送物と配送スタッフの流量が同じ値を取る(0または1)。
(2)eの出発点がdの需要点のとき
配送物はポートから道には出ない。
(3)どちらの場合も
自転車の台数は配送スタッフの人数以下である。
5.区間の最後の時刻におけるペナルティに関する変数に対する制約
任意の道wに対して、次の区間で使用しない人や配送手段の数をg[w]としたとき、g[w] ≦ f[w]という制約を入れる。
f[w]は任意の数を表す。f[w]の値を調整することで、区間の最後に残存することを許容できる人、配送手段の数を変更することができる。
任意の道wに対して、次の区間で使用しない人や配送手段の数をg[w]としたとき、g[w] ≦ f[w]という制約を入れる。
f[w]は任意の数を表す。f[w]の値を調整することで、区間の最後に残存することを許容できる人、配送手段の数を変更することができる。
6.道から道への枝に対する制約
(1)道から道への枝が、車の枝のとき(自転車を載せる可能性がある)
配送車には必ず配送スタッフが乗ること、配送スタッフの人数は搭乗可能人数以下であること、運転できない自転車の台数は、車に積載可能な台数以下であることを制約とする。
(2)道から道への枝が、自転車の枝かつ徒歩の枝で車の枝ではないとき(自転車または徒歩で移動)
自転車台数と徒歩で移動している人数の和は、その枝を移動している配送スタッフの人数に等しい。
(3)道から道への枝が、自転車の枝であるが車の枝でも徒歩の枝でもないとき(自転車で移動)
自転車台数と、その枝を移動している配送スタッフの人数は等しい。
(4)道から道への枝が、徒歩の枝であるが車の枝でも自転車の枝でもないとき(徒歩で移動)
徒歩で移動している人数と、その枝を移動している配送スタッフの人数は等しい。
(1)道から道への枝が、車の枝のとき(自転車を載せる可能性がある)
配送車には必ず配送スタッフが乗ること、配送スタッフの人数は搭乗可能人数以下であること、運転できない自転車の台数は、車に積載可能な台数以下であることを制約とする。
(2)道から道への枝が、自転車の枝かつ徒歩の枝で車の枝ではないとき(自転車または徒歩で移動)
自転車台数と徒歩で移動している人数の和は、その枝を移動している配送スタッフの人数に等しい。
(3)道から道への枝が、自転車の枝であるが車の枝でも徒歩の枝でもないとき(自転車で移動)
自転車台数と、その枝を移動している配送スタッフの人数は等しい。
(4)道から道への枝が、徒歩の枝であるが車の枝でも自転車の枝でもないとき(徒歩で移動)
徒歩で移動している人数と、その枝を移動している配送スタッフの人数は等しい。
7.配送拠点の中で留まる枝に対する制約
車には必ず人が乗ること、自転車は路駐できないこと、配送物の総体積はトラックの積載量以下であること、を制約とする。
車には必ず人が乗ること、自転車は路駐できないこと、配送物の総体積はトラックの積載量以下であること、を制約とする。
配送計画生成部12aは、これらの目的関数や制約条件で定式化された配送問題(整数計画問題)を、第1または第2の時空間ネットワークを用いて解く。実際の計算においては、カットを加えてさらに高速化を図ってもよい。図20の右図に、配送計画生成部12aが1番目の区間について配送計画を生成した結果の一例を示す。この計画によれば、配送を開始してから60分後には、配送拠点w1および配送拠点w2では配送物d1が1個余り、配送拠点w3では配送物d1が2個不足しており、配送拠点w4では配送物d1の不足が解消していることが分かる。
このように時間を分割して計算する方法の利点として、次のような点を挙げることができる。まず、配送制限時間を120分から60分にすることで、計算に必要なパラメータの数を減らし、計算量を削減することができる。図20では、説明の便宜のため、配送拠点、配送物の数が共に少ない例を挙げているが、20カ所の配送拠点に、20個以上の配送物を120分以内に配送する問題を計算する場合、例えば、変数が41000、制約が61000にもなることが分かっている。これに対し、時間を前半の60分で区切り、上記のできるだけ多くの要求を満たせるような配送計画を生成する場合、例えば、変数の数を14000、制約の数は18000程度に抑えることができる。このようにパラメータの数を減らすことで計算量を削減し、処理を高速化することができる。次に後半の60分の配送計画の生成処理について説明する。
図21は、本発明の第三実施形態における配送問題の時間分割処理を説明する第二の図である。
図21に分割後の後半60分を使って行う配送計画の生成処理を示す。後半60分の開始時点の各配送拠点における需要数量と供給数量について整理する。後半の開始時点の配送拠点w1および配送拠点w2では配送物d1が1個余り、配送拠点w3では配送物d1が2個不足している。配送計画生成部12aが、後半60分を使って生成しなければならない配送計画は、配送拠点w1および配送拠点w2の配送物d1を、残りの60分以内に配送拠点w3における需要を満たすように配送する問題である。配送拠点w4については、配送拠点w4の不足は前半60分で解消しているので後半60分の配送問題には含まれない。
図21に分割後の後半60分を使って行う配送計画の生成処理を示す。後半60分の開始時点の各配送拠点における需要数量と供給数量について整理する。後半の開始時点の配送拠点w1および配送拠点w2では配送物d1が1個余り、配送拠点w3では配送物d1が2個不足している。配送計画生成部12aが、後半60分を使って生成しなければならない配送計画は、配送拠点w1および配送拠点w2の配送物d1を、残りの60分以内に配送拠点w3における需要を満たすように配送する問題である。配送拠点w4については、配送拠点w4の不足は前半60分で解消しているので後半60分の配送問題には含まれない。
次に、配送制限時間をN個に分割した場合の最後の区間を対象とする配送問題について設定する目的関数、制約について説明する。この場合の目的関数や制約などは、第1の時空間ネットワークモデル(図3)、第2の時空間ネットワークモデル(図8)を用いて説明したものと同様である。つまり、配送計画生成部12aは、最後の区間の最後の時刻までに全ての需要を満たすように配送物を配送し終える配送計画のうち、最もコストや配送に掛かる移動時間を最小化する配送計画を生成する。
後半の60分(最後の区間)の処理についての利点を挙げると、まず、前半60分と同様、配送制限時間を60分にすることで、パラメータの数を減らし、計算量を削減することで処理の高速化を図ることができる点を挙げることができる。さらに、最後の区間に至るまでの各区間で算出されたなるべく多く要求を満たすような配送計画によって、残っている需要が減少しているため、解かなければならない配送問題の規模が小さくなっていることを挙げることができる。例えば図20、図21に示す例では、単に各需要点における需要数量が減るだけではなく、配送拠点w4での需要が満たされているので、配送拠点の数を減らすことに成功している。これによりさらに配送問題の規模を小さくすることができる。20カ所の配送拠点に20個以上の配送物を120分以内に配送する問題を60分ごとに分割した場合、後半60分の区間においては、例えば、変数の数を8000、制約の数は12000程度に減少させることができる。このように、本実施形態によれば、時間の分割によるパラメータの減少と、時間的に先の区間において生成した配送計画によって、後の区間での配送問題の規模を縮小化することができるので、配送計画の生成処理を高速化することができる。第三実施形態ではエリア分割を行わない為、第一実施形態、第二実施形態と比べ、配送拠点分布の大域性を確保したまま配送計画を生成することができ、より最適化された配送計画を生成することができる。
次に本実施形態の配送計画の生成処理の流れについて説明する。
図22は、本発明の第三実施形態における配送計画の生成処理の一例を示すフローチャートである。図13、図18と同様の処理については簡単に説明を行う。
まず、配送計画を行う配送スタッフが、配送計画装置10Bに配送計画の初期条件を入力する。入出力部13はその入力を受け付け、受け付けた情報を初期条件設定部11に出力する。初期条件設定部11は、配送スタッフが入力した初期条件の情報を取得する(ステップS11)。
次に、時間分割部17は、初期条件の情報に含まれる配送制限時間を用いて、時間分割処理を行う(ステップS122)。時間分割処理については図20を用いて説明したとおりである。例えば、時間分割部17は、初期条件の配送制限時間を2~3つに分割する。あるいは、経験則などで需要のある配送拠点に対する配送完了が一定の割合で見込める時間(例えば75分)が分かっている場合、ユーザの設定により、時間分割部17は、その時間単位(例えば75分)で元の配送制限時間を分割し、残りの時間を最後の区間としてもよい。あるいは、時間分割部17は、初期条件で与えられた配送制限時間よりも所定の時間だけ短い時間を分割後の1番目の区間とし、残りの時間を最後の区間としてもよい。次に配送計画生成部12aは、分割された各区間に対して時間順に配送計画を生成する。まず、配送計画生成部12aは、カウンター変数nに1を設定する(ステップS123)。次に配送計画生成部12aは、n番目の区間の配送問題を設定する(ステップS124)。例えば、1番目の区間であれば、配送計画生成部12aは、初期条件の情報に含まれる各配送拠点の需要数量、供給数量、出発拠点に存在する配送手段の数量、配送スタッフの人数、1番目の区間の時間を配送制限時間に用いて、できるだけ多くの要求を満たし、コストが最も安くなる配送計画の生成のための目的関数、制約条件による整数計画問題を定式化する。
図22は、本発明の第三実施形態における配送計画の生成処理の一例を示すフローチャートである。図13、図18と同様の処理については簡単に説明を行う。
まず、配送計画を行う配送スタッフが、配送計画装置10Bに配送計画の初期条件を入力する。入出力部13はその入力を受け付け、受け付けた情報を初期条件設定部11に出力する。初期条件設定部11は、配送スタッフが入力した初期条件の情報を取得する(ステップS11)。
次に、時間分割部17は、初期条件の情報に含まれる配送制限時間を用いて、時間分割処理を行う(ステップS122)。時間分割処理については図20を用いて説明したとおりである。例えば、時間分割部17は、初期条件の配送制限時間を2~3つに分割する。あるいは、経験則などで需要のある配送拠点に対する配送完了が一定の割合で見込める時間(例えば75分)が分かっている場合、ユーザの設定により、時間分割部17は、その時間単位(例えば75分)で元の配送制限時間を分割し、残りの時間を最後の区間としてもよい。あるいは、時間分割部17は、初期条件で与えられた配送制限時間よりも所定の時間だけ短い時間を分割後の1番目の区間とし、残りの時間を最後の区間としてもよい。次に配送計画生成部12aは、分割された各区間に対して時間順に配送計画を生成する。まず、配送計画生成部12aは、カウンター変数nに1を設定する(ステップS123)。次に配送計画生成部12aは、n番目の区間の配送問題を設定する(ステップS124)。例えば、1番目の区間であれば、配送計画生成部12aは、初期条件の情報に含まれる各配送拠点の需要数量、供給数量、出発拠点に存在する配送手段の数量、配送スタッフの人数、1番目の区間の時間を配送制限時間に用いて、できるだけ多くの要求を満たし、コストが最も安くなる配送計画の生成のための目的関数、制約条件による整数計画問題を定式化する。
次に、配送計画生成部12aは、定式化した整数計画問題に対して、図3や図8で例示した第1または第2の時空間ネットワークモデルを用いて、各制約を満たしつつ、各配送拠点の需要をなるべく満足するような枝情報の集合を複数生成する(ステップS132)。次に、配送計画生成部12aは、生成した枝情報の集合ごとに総コストを計算する(ステップS14)。次に配送計画生成部12aは、計算した総コストを比較し、総コストが最小となる枝情報の集合を選択する(ステップS15)。これによって、n番目(今回は1番目)の区間に対する配送計画が生成される。
次に配送計画生成部12aは、nがNと等しいかどうかを判定する(ステップS16)。nがNと等しい場合(ステップS16;Yes)、分割後の全ての区間に対する配送計画が生成されていることになるので、配送計画の生成処理を終了する。nがNと等しくない場合(ステップS16;No)、配送計画生成部12aは、nに1を加算し(ステップS17)、ステップS124からの処理を繰り返す。
具体的には、例えば、1を加算した後のnの値が2の場合、配送計画生成部12aは、ステップS124において、1番目の区間について生成した配送計画を実行した結果の各配送拠点の需要数量、供給数量、出発拠点に存在する配送手段の数量、配送スタッフの人数、2番目の区間の時間を配送制限時間に用いて、整数計画問題を定式化する。このとき、配送計画生成部12aは、nがNと等しければ、全ての要求を満たす配送計画の生成のための目的関数、制約による整数計画問題を定式化する(第一実施形態、第二実施形態と同様の目的関数等)。nがNと等しくない場合、配送計画生成部12aはできるだけ多くの要求を満たせる配送計画の生成のための目的関数、制約による整数計画問題を定式化する。配送計画生成部12aは、整数計画問題を解いて、n番目の区間の配送計画を生成する。配送計画生成部12aは、全ての区間について配送計画を生成するまで(nがNと等しくなるまで)ステップS124~ステップS17の処理を繰り返す。1番目の区間からN番目(最後)の区間のそれぞれについて順に生成した配送計画の全体が、初期条件で与えられた要求を満たす配送計画である。
図22のフローチャートでは、最初に初期条件で与えられた配送制限時間をいくつかの区間に分割したが、例えば、次のように配送計画処理を構成してもよい。
1.まず、初期条件で与えられた配送制限時間より短い区間(第一配送制限時間)を設定し、その区間内になるべく多く、且つ、安く配送できる配送計画を生成する。
2.次にその第一配送制限時間内で配送し終えることができない配送物については、さらに第一配送制限時間に続く所定長さの区間(第二配送制限時間)を設定し、設定した区間内になるべく多くの配送物を配送する配送計画を生成する。
3.1.~2.のステップを、配送開始からの区間の長さの合計が配送制限時間を超えない間繰り返す。つまり、時間を延長しながら解を見つける(時間展開法)。最初の区間や延長する区間の長さは配送状況に応じて任意に設定してよい。
4.配送開始からの時間の合計が配送制限時間を超えそうになった場合は、次の区間を最後として、最後の区間内(直前に生成した配送計画の完了時点を開始時刻とし、第一配送制限時間の開始時刻を基準にして初期条件に含まれる配送制限時間が経過する時刻を終了時刻とする時間内)に全ての需要を満たしコストが最小となるような配送計画を生成する。
1.まず、初期条件で与えられた配送制限時間より短い区間(第一配送制限時間)を設定し、その区間内になるべく多く、且つ、安く配送できる配送計画を生成する。
2.次にその第一配送制限時間内で配送し終えることができない配送物については、さらに第一配送制限時間に続く所定長さの区間(第二配送制限時間)を設定し、設定した区間内になるべく多くの配送物を配送する配送計画を生成する。
3.1.~2.のステップを、配送開始からの区間の長さの合計が配送制限時間を超えない間繰り返す。つまり、時間を延長しながら解を見つける(時間展開法)。最初の区間や延長する区間の長さは配送状況に応じて任意に設定してよい。
4.配送開始からの時間の合計が配送制限時間を超えそうになった場合は、次の区間を最後として、最後の区間内(直前に生成した配送計画の完了時点を開始時刻とし、第一配送制限時間の開始時刻を基準にして初期条件に含まれる配送制限時間が経過する時刻を終了時刻とする時間内)に全ての需要を満たしコストが最小となるような配送計画を生成する。
本実施形態の配送計画生成処理を実際に行ったところ、配送拠点が20カ所、配送物が20個程度の配送問題に対して、実用的な時間(10分以内)で準最適解(厳密な最適解と比べて目的関数の値の差が10%以下)を算出することができた。
本実施形態の配送計画生成方法は以下のような場面で用いることもできる。例えば、120分間で全ての車両を需要のある駐車場に配送しなければならない場合、まず前半60分について配送計画を生成する。配送計画を生成し終えると、実際にその配送計画に基づいて、車両の配送を開始する。車両の配送を行っている間、残りの60分間の配送計画を生成する。このように、配送計画の生成処理と配送とを並行して行うことで、例えばカーシェアリングのサービスを行う現場で、時間を有効に使うことができる。
上述した配送計画装置10、10A、10Bにおける各処理の過程は、プログラムの形式でコンピュータ読み取り可能な記録媒体に記憶されており、このプログラムを配送計画システムのコンピュータが読み出して実行することによって、上記処理が行われる。ここでコンピュータ読み取り可能な記録媒体とは、磁気ディスク、光磁気ディスク、CD-ROM、DVD-ROM、半導体メモリ等をいう。このコンピュータプログラムを通信回線によってコンピュータに配信し、この配信を受けたコンピュータが当該プログラムを実行するようにしてもよい。
上記プログラムは、前述した機能の一部を実現するためのものであってもよい。さらに、前述した機能をコンピュータシステムにすでに記録されているプログラムとの組み合わせで実現できるもの、いわゆる差分ファイル(差分プログラム)であってもよい。配送計画装置10、10A、10Bは、1台のコンピュータで構成されていても良いし、通信可能に接続された複数のコンピュータで構成されていてもよい。
その他、本発明の趣旨を逸脱しない範囲で、上記した実施の形態における構成要素を周知の構成要素に置き換えることは適宜可能である。この発明の技術範囲は上記の実施形態に限られるものではなく、本発明の趣旨を逸脱しない範囲において種々の変更を加えることが可能である。
配送スタッフは配送主体の一例であり、配送車、トラック、自転車は配送手段の一例であり、カーシェアリングにおける共用の車両は配送物の一例である。第一エリア分割部14、第二エリア分割部16、時間分割部17の各々は分割部の一例である。
上記した配送計画システム、配送計画方法及びプログラムによれば、実用的な時間で、大規模な配送問題に対するコストや移動時間を最小にする配送計画を立案することができる。
10、10A、10B・・・配送計画装置
11・・・初期条件設定部
12、12a・・・配送計画生成部
13・・・入出力部
14・・・第一エリア分割部
15・・・記憶部
16・・・第二エリア分割部
17・・・時間分割部
11・・・初期条件設定部
12、12a・・・配送計画生成部
13・・・入出力部
14・・・第一エリア分割部
15・・・記憶部
16・・・第二エリア分割部
17・・・時間分割部
Claims (15)
- 配送物を需要のある配送拠点に配送する配送問題において、初期条件が示す配送問題をより規模の小さな配送問題に分割する分割部と、
前記分割部が分割した後の配送問題について配送計画を生成する配送計画生成部と、
を備える配送計画システム。 - 前記分割部は、前記配送物の需要がある配送拠点群に含まれる一つの需要点と、前記配送物の供給元となる配送拠点群に含まれる一つの供給点とを、当該一つの需要点から当該一つの供給点への移動時間が最小となるように対応付け、対応付けた前記需要点および前記供給点の組み合わせの集合を生成し、前記初期条件が示す配送問題を、前記生成した集合内に含まれる需要点群から供給点群への配送問題に分割する、
請求項1に記載の配送計画システム。 - 前記分割部は、生成した集合内に含まれる複数の供給点と複数の需要点との対応関係のうち、一つの供給点から一つの需要点への移動時間が所定の値以下となる供給点から需要点への配送ルートを計算し、
前記配送計画生成部は、前記生成した集合内に含まれる供給点群から需要点群への配送ルートのうち移動時間が前記所定の閾値以下となる配送ルートを用いて、前記規模の小さな配送問題に対する配送計画を生成する、
請求項2に記載の配送計画システム。 - 前記分割部は、出発拠点を出発して一部の配送拠点間に係る配送を行って前記出発拠点に戻るまでの予め設定された配送ルートとその配送ルートで配送したときのコストとを示す単位経路情報を複数取得し、前記複数の単位経路情報の組み合わせのうち、当該組み合わせに含まれる前記配送拠点の数が所定の数以内で、且つ、前記コストの合計が最小となる組み合わせを算出し、その組み合わせに含まれる出発拠点と配送拠点の集合を生成し、前記初期条件が示す配送問題を、前記生成した出発拠点と配送拠点の集合内に含まれる需要点群から供給点群への配送問題に分割する、
請求項1に記載の配送計画システム。 - 前記分割部は、列生成法により、前記単位経路情報の組み合わせを算出する、
請求項4に記載の配送計画システム。 - 前記分割部は、前記配送物の配送制限時間を複数の時間に分割することにより前記初期条件が示す配送問題を前記分割した時間ごとの配送問題に分割し、
前記配送計画生成部は、前記分割後の各時間の最初の時刻における前記配送物の配送状況から当該分割後の各時間内に前記配送物がなるべく多く需要のある拠点に配送されるような配送計画を生成する、
請求項1に記載の配送計画システム。 - 前記分割部が分割してできた最後の時間に係る配送問題について、
前記配送計画生成部は、前記最後の時間が終了するまでに、前記初期条件で示された需要のある配送拠点の全てに前記配送物が配送されるよう配送計画を生成する、
請求項6に記載の配送計画システム。 - 前記分割部は、前記初期条件が示す配送問題を、前記初期条件に含まれる配送制限時間よりも所定の時間だけ短い第一配送制限時間を新たな配送制限時間とする配送問題に分割し、
前記配送計画生成部は、前記第一配送制限時間内に前記配送物がなるべく多く需要のある拠点に配送されるような配送計画を生成する、
請求項1に記載の配送計画システム。 - 前記分割部は、前記第一配送制限時間に続く所定長さの時間を第二配送制限時間として設定し、
前記配送計画生成部は、当該第二配送制限時間内に前記配送物がなるべく多く需要のある拠点に配送されるような配送計画を生成する、
請求項8に記載の配送計画システム。 - 前記配送計画生成部は、前記生成した配送計画を実行した場合の完了時点を開始時刻とし、前記第一配送制限時間の開始時刻を基準にして前記初期条件に含まれる配送制限時間が経過する時刻を終了時刻とする最後の時間内に、前記配送計画の実行の結果、配送が完了していない配送物について配送し終える配送計画を生成する、
請求項8または請求項9に記載の配送計画システム。 - 前記配送物がなるべく多く需要がある拠点に配送されるような配送計画の生成にあたり、前記配送計画生成部は、前記配送計画を実行した結果、前記配送計画の実行に必要な配送スタッフと配送手段が前記配送拠点に残らないことを条件に配送計画を生成する、
請求項6から請求項10の何れか1項に記載の配送計画システム。 - 前記配送計画生成部は、前記配送物を配送する配送主体と前記配送物または前記配送主体を移動する配送手段の初期位置を示す出発拠点および前記配送拠点と配送開始の時を基準とする各時刻とを組にした点情報と、前記点情報のうち前記配送物の配送に係る2つの点情報の間の、前記配送に係る前記配送物および前記配送主体および前記配送手段の流量を示す枝情報と、で構成される時空間ネットワークモデルに基づく整数計画問題を解いて、前記分割部による分割後の配送問題における前記配送に係る枝情報の集合を少なくとも1つ生成する、
請求項1から請求項11の何れか1項に記載の配送計画システム。 - 前記配送計画生成部は、前記時空間ネットワークモデルにおいて、一つの前記配送拠点について、その配送拠点の入口と時刻とを組にした入口に係る点情報と、その配送拠点の出口と時刻とを組にした出口に係る点情報と、その配送拠点に係る配送物1個ずつに対して時刻を組にした配送物の置き場に係る点情報とを生成し、前記入口に係る点情報と前記配送物に係る点情報との間、前記出口に係る点情報と前記配送物に係る点情報との間、における前記配送主体および前記配送物の流量の値を0または1に設定する、
請求項12に記載の配送計画システム。 - 配送計画システムが、
配送物を需要のある配送拠点に配送する配送問題において、初期条件が示す配送問題をより規模の小さな配送問題に分割し、
前記分割した後の配送問題について配送計画を生成する、
配送計画方法。 - 配送計画システムのコンピュータを、
配送物を需要のある配送拠点に配送する配送問題において、初期条件が示す配送問題をより規模の小さな配送問題に分割する手段、
前記分割した後の配送問題について配送計画を生成する手段、
として機能させるためのプログラム。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
SG11201901115SA SG11201901115SA (en) | 2016-10-31 | 2017-10-20 | Delivery planning system, delivery planning method, and program |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2016-213838 | 2016-10-31 | ||
JP2016213838A JP6692022B2 (ja) | 2016-10-31 | 2016-10-31 | 配送計画システム、配送計画方法及びプログラム |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2018079443A1 true WO2018079443A1 (ja) | 2018-05-03 |
Family
ID=62023404
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2017/038040 WO2018079443A1 (ja) | 2016-10-31 | 2017-10-20 | 配送計画システム、配送計画方法及びプログラム |
Country Status (4)
Country | Link |
---|---|
JP (1) | JP6692022B2 (ja) |
SG (1) | SG11201901115SA (ja) |
TW (1) | TWI706339B (ja) |
WO (1) | WO2018079443A1 (ja) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP3879466A1 (en) * | 2020-03-10 | 2021-09-15 | Fujitsu Limited | Information processing apparatus, route generation method, and route generation program |
KR20220092616A (ko) | 2020-01-15 | 2022-07-01 | 제이에프이 스틸 가부시키가이샤 | 배송 계획 작성 방법, 조업 방법, 및 배송 계획 작성 장치 |
CN115112137A (zh) * | 2021-03-23 | 2022-09-27 | 广东博智林机器人有限公司 | 路径规划方法、装置、电子设备及可读存储介质 |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20230065108A1 (en) * | 2020-03-05 | 2023-03-02 | Nippon Telegraph And Telephone Corporation | Optimization function generation apparatus, optimization function generation method, and program |
JP7354910B2 (ja) * | 2020-04-08 | 2023-10-03 | 富士通株式会社 | 情報処理装置、情報処理方法および情報処理プログラム |
US20240054441A1 (en) * | 2021-01-12 | 2024-02-15 | Nec Corporation | Optimization apparatus, optimization method, and non-transitory computer-readable medium |
CN113177699B (zh) * | 2021-04-14 | 2022-07-22 | 中联重科股份有限公司 | 配送方法和配送系统 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH09311702A (ja) * | 1996-05-21 | 1997-12-02 | Ricoh Co Ltd | 配送計画における最適ブロック分割方式 |
JP2004238129A (ja) * | 2003-02-05 | 2004-08-26 | Jfe Steel Kk | 配送計画立案方法およびその装置 |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102117441A (zh) * | 2010-11-29 | 2011-07-06 | 中山大学 | 基于离散粒子群优化算法的智能物流配送 |
US20130159206A1 (en) * | 2011-12-14 | 2013-06-20 | International Business Machines Corporation | Dynamic vehicle routing in multi-stage distribution networks |
CN103413209B (zh) * | 2013-07-17 | 2016-08-10 | 西南交通大学 | 多客户多仓库物流配送路径选择方法 |
US20160048802A1 (en) * | 2014-08-13 | 2016-02-18 | Tianyu Luwang | Transportation planning for a regional logistics network |
CN105809402A (zh) * | 2016-03-11 | 2016-07-27 | 惠龙易通国际物流股份有限公司 | 一种基于bfs算法的货运信息处理方法及系统 |
-
2016
- 2016-10-31 JP JP2016213838A patent/JP6692022B2/ja active Active
-
2017
- 2017-10-20 WO PCT/JP2017/038040 patent/WO2018079443A1/ja active Application Filing
- 2017-10-20 SG SG11201901115SA patent/SG11201901115SA/en unknown
- 2017-10-31 TW TW106137595A patent/TWI706339B/zh not_active IP Right Cessation
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH09311702A (ja) * | 1996-05-21 | 1997-12-02 | Ricoh Co Ltd | 配送計画における最適ブロック分割方式 |
JP2004238129A (ja) * | 2003-02-05 | 2004-08-26 | Jfe Steel Kk | 配送計画立案方法およびその装置 |
Non-Patent Citations (1)
Title |
---|
SAWAMOTO: "A Proposal of a Method of Reactive Scheduling for the Delivery Scheduling Problem", IEEJ PROCEEDINGS, vol. 122, no. 5, 1 May 2002 (2002-05-01), pages 832 - 842 * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20220092616A (ko) | 2020-01-15 | 2022-07-01 | 제이에프이 스틸 가부시키가이샤 | 배송 계획 작성 방법, 조업 방법, 및 배송 계획 작성 장치 |
EP3879466A1 (en) * | 2020-03-10 | 2021-09-15 | Fujitsu Limited | Information processing apparatus, route generation method, and route generation program |
CN115112137A (zh) * | 2021-03-23 | 2022-09-27 | 广东博智林机器人有限公司 | 路径规划方法、装置、电子设备及可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
JP2018073213A (ja) | 2018-05-10 |
JP6692022B2 (ja) | 2020-05-13 |
TWI706339B (zh) | 2020-10-01 |
TW201830298A (zh) | 2018-08-16 |
SG11201901115SA (en) | 2019-05-30 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2018079443A1 (ja) | 配送計画システム、配送計画方法及びプログラム | |
Manerba et al. | Attended Home Delivery: Reducing last-mile environmental impact by changing customer habits | |
Ahmadizar et al. | Two-level vehicle routing with cross-docking in a three-echelon supply chain: A genetic algorithm approach | |
CN108960519B (zh) | 基于大数据分析的时间最短运输路径选择方法 | |
Daneshzand | The vehicle-routing problem | |
Comi et al. | Emerging information and communication technologies: the challenges for the dynamic freight management in city logistics | |
Ni et al. | Same-day delivery with crowdshipping and store fulfillment in daily operations | |
Ebben | Logistic control in automated transportation networks | |
Yaghini et al. | A hybrid metaheuristic algorithm for dynamic rail car fleet sizing problem | |
Zahrani et al. | An intelligent social-based method for rail-car fleet sizing problem | |
Gu et al. | Dynamic truck–drone routing problem for scheduled deliveries and on-demand pickups with time-related constraints | |
Parragh et al. | A survey on pickup and delivery models part ii: Transportation between pickup and delivery locations | |
WO2017159734A1 (ja) | 配送計画システム、配送計画方法及びプログラム | |
De Jonge et al. | A heuristic algorithm for multi-agent vehicle routing with automated negotiation | |
Iacobucci et al. | A multi-stage optimisation approach to design relocation strategies in one-way car-sharing systems with stackable cars | |
Correia et al. | Smart supply chain management: The 5W1H open and collaborative framework | |
CN108985510B (zh) | 基于人工智能的大规模智能物流路径判定系统 | |
Teimoury et al. | The sustainable hybrid truck-drone delivery model with stochastic customer existence | |
Campbell et al. | Special issue on recent advances in urban transport and logistics through optimization and analytics | |
Vishkaei et al. | Rescheduling multiproduct delivery planning with digital technologies for smart mobility and sustainability goals | |
Jeong et al. | Dynamic pickup and delivery problem for autonomous delivery robots in an airport terminal | |
Sabino et al. | A multi-objective ant colony optimization method applied to switch engine scheduling in railroad yards | |
Safia et al. | Optimization of vehicle routing for smart city: Real case study in Casablanca | |
Wang | Joint Optimization of Relocation and Routing Strategies for E-Scooter Sharing System | |
Heimfarth | Operations Research Methods for the Sustainable Use of Autonomous Delivery Robots in Retail |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 17865090 Country of ref document: EP Kind code of ref document: A1 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 17865090 Country of ref document: EP Kind code of ref document: A1 |