This application claims priority to and the benefit of Japanese Patent Application No. 2020-004599 filed on Jan. 15, 2020, the entire disclosure of which is incorporated herein by reference.
The present disclosure relates to a delivery plan generation method, an operation method, and a delivery plan generation device using an annealing machine.
There are conventional methods of optimizing article delivery plans by transportation equipment such as trucks and ships. An example of such conventional methods is a method of firstly listing combinations of delivery patterns with predetermined delivery routes, loading and unloading, and schedules and secondly selecting, from these combinations, a plurality of delivery patterns that satisfy delivery-related constraints and whose evaluation index such as cost is minimum or maximum. However, in the case where there are a large number of delivery routes and cargoes, the total number of combinations of delivery patterns becomes enormous, and it is difficult to select an appropriate combination of delivery patterns from these combinations within realistic time.
As techniques of selecting appropriate delivery patterns from delivery pattern candidates, optimization methods such as branch and bound method and metaheuristic are proposed. However, when the number of delivery pattern candidates is enormous, the calculation time required for optimization increases exponentially, and these methods are not practical. NPL 1 proposes a method whereby calculation is performed from a reasonable number of delivery pattern candidates and, based on the calculation results, delivery patterns that are expected to provide improvement are added and recalculation is performed. This, however, requires repeated optimization calculation, and therefore causes an increase in calculation time. PTL 1 proposes a method whereby a problem is divided for each delivery area beforehand and calculation is performed in actual time. However, a plan for a delivery route that extends over delivery areas cannot be made, and there is a possibility that a plan which is not totally optimized is output. There is also a method whereby a developer of an algorithm understands a problem structure and implements a rule of narrowing delivery patterns down to an appropriate number of delivery patterns. This, however, relies on the developer's skill, and also prolongs the development period.
It is therefore an object of this disclosure to improve techniques relating to delivery plan generation.
A delivery plan generation method according to one of the disclosed embodiments comprises: generating a plurality of delivery patterns; narrowing the plurality of delivery patterns down to a designated number of delivery patterns, based on a plurality of solutions calculated as a result of inputting the plurality of delivery patterns to an annealing machine; and generating a delivery plan based on delivery patterns selected from the designated number of delivery patterns.
An operation method according to one of the disclosed embodiments comprises performing operation using a delivery plan generated by the above-described delivery plan generation method.
A delivery plan generation device according to one of the disclosed embodiments is a delivery plan generation device configured to generate a delivery plan, and comprises a controller configured to: generate a plurality of delivery patterns; narrow the plurality of delivery patterns down to a designated number of delivery patterns, based on a plurality of solutions calculated as a result of inputting the plurality of delivery patterns to an annealing machine; and generate a delivery plan based on delivery patterns selected from the designated number of delivery patterns.
It is thus possible to improve techniques relating to delivery plan generation.
In the accompanying drawings:
A system 10 that implements a delivery plan generation method according to one of the disclosed embodiments will be described below, with reference to the drawings.
In the drawings, the same or corresponding parts are given the same reference signs. In the following description of this embodiment, the description of the same or corresponding parts is omitted or simplified as appropriate.
The structure of the system 10 according to this embodiment will be described below, with reference to
The system 10 according to this embodiment includes a delivery plan generation device 20 and an annealing machine 30. The delivery plan generation device 20 is a general-purpose computer, and can communicate with the annealing machine 30 via a network 40. The network 40 includes the Internet, an ad hoc network, a local area network (LAN), or a metropolitan area network (MAN). The network 40 includes a cellular network, a wireless personal area network (WPAN), or a public switched telephone network (PSTN). The network 40 includes a terrestrial wireless network, an optical network, or other networks. The network 40 includes any combination of these networks. The components of the wireless network include, for example, an access point (for example, a Wi-Fi access point) and a femtocell.
The delivery plan generation device 20 includes a controller 21, a storage 22, a communication section 23, an input section 24, and an output section 25.
The controller 21 includes at least one processor, at least one dedicated circuit, or a combination thereof. Examples of the processor include a general-purpose processor such as a central processing unit (CPU) or a graphics processing unit (GPU), or a dedicated processor specialized in a specific process. Examples of the dedicated circuit include a field-programmable gate array (FPGA) and an application specific integrated circuit (ASIC). The controller 21 executes a process relating to the operation of the delivery plan generation device 20 while controlling each component in the delivery plan generation device 20.
The storage 22 includes at least one semiconductor memory, at least one magnetic memory, at least one optical memory, or a combination of two or more thereof. Examples of the semiconductor memory include a random access memory (RAM) and a read only memory (ROM). The RAM is, for example, a static random access memory (SRAM) or a dynamic random access memory (DRAM). The ROM is, for example, an electrically erasable programmable read only memory (EEPROM). For example, the storage 22 functions as a main storage device, an auxiliary storage device, or a cache memory. The storage 22 stores data used for the operation of the delivery plan generation device 20 and data obtained as a result of the operation of the delivery plan generation device 20.
The communication section 23 includes at least one communication interface. Examples of the communication interface include a LAN interface, a WAN interface, an interface that complies with a mobile communication standard such as Long Term Evolution (LTE), 4G (4th generation), or 5G (5th generation), and an interface that complies with short-range wireless communication such as Bluetooth® (Bluetooth is a registered trademark in Japan, other countries, or both). The communication section 23 receives data used for the operation of the delivery plan generation device 20, and transmits data obtained as a result of the operation of the delivery plan generation device 20.
The input section 24 includes at least one input interface. Examples of the input interface include a physical key, a capacitive key, a pointing device, a touch screen integrated with a display, and a microphone. The input section 24 receives an operation of inputting data used for the operation of the delivery plan generation device 20. The input section 24 may be connected to the delivery plan generation device 20 as an external input device, instead of being included in the delivery plan generation device 20. As a connection method, any method such as Universal Serial Bus (USB), High-Definition Multimedia Interface (HDMI® (HDMI is a registered trademark in Japan, other countries, or both)), or Bluetooth® may be used.
The output section 25 includes at least one output interface. Examples of the output interface include a display and a speaker. The display is, for example, a liquid crystal display (LCD) or an organic electroluminescent (EL) display. The output section 25 outputs data obtained as a result of the operation of the delivery plan generation device 20. The output section 25 may be connected to the delivery plan generation device 20 as an external output device, instead of being included in the delivery plan generation device 20. As a connection method, any method such as USB, HDMI®, or Bluetooth® may be used.
The functions of the delivery plan generation device 20 are implemented by a program according to this embodiment being executed by a processor corresponding to the controller 21. That is, the functions of the delivery plan generation device 20 are implemented by software. The program causes a computer to execute the operation of the delivery plan generation device 20, thus causing the computer to function as the delivery plan generation device 20. In other words, the computer executes the operation of the delivery plan generation device 20 according to the program to thus function as the delivery plan generation device 20.
In this embodiment, the program can be recorded in a computer-readable recording medium. The computer-readable recording medium includes a non-transitory computer-readable medium, such as a magnetic recording device, an optical disc, a magneto-optical recording medium, or a semiconductor memory. The program is distributed, for example, by selling, transferring, or renting a portable recording medium. The portable recording medium is, for example, a digital versatile disc (DVD) or a compact disc read only memory (CD-ROM) having the program recorded therein. The program may be distributed by storing the program in a storage of a server and transmitting the program from the server to another computer. The program may be provided as a program product.
In this embodiment, for example, the computer once stores, in the main storage device, the program recorded in the portable recording medium or the program transmitted from the server, and then reads the program stored in the main storage device by the processor and executes a process according to the read program by the processor. The computer may read the program directly from the portable recording medium and execute the process according to the program. Each time the computer receives the program from the server, the computer may execute the process according to the received program. Without the program being transmitted from the server to the computer, the process may be executed by application service provider (ASP) services that implement the functions by only execution instruction and result acquisition. The program includes information that is to be processed by an electronic computer and equivalent to a program. For example, data that is not a direct command to the computer but has the property of defining a process of the computer is “equivalent to a program”.
All or part of the functions of the delivery plan generation device 20 may be implemented by a dedicated circuit corresponding to the controller 21. That is, all or part of the functions of the delivery plan generation device 20 may be implemented by hardware.
In the system 10 according to this embodiment, the delivery plan generation device 20 generates an article delivery plan by transportation equipment using the annealing machine 30. Table 1 is an example of a delivery plan generated by the delivery plan generation device 20.
In the example in Table 1, the delivery plan includes information for identifying transportation equipment used (transportation equipment ID) and information for identifying a loading place (loading place ID). The delivery plan also includes information for identifying the type and quantity of each article (article 1 ID, article 2 ID, and respective tonnage), information for identifying the delivery start time, and information for identifying the delivery finish time. In other words, the system 10 according to this embodiment generates a delivery plan for delivering a type of article in a predetermined quantity from a loading place to an unloading place using transportation equipment.
In the delivery plan generation method according to this embodiment, first, a plurality of candidate delivery patterns that can be employed in a delivery plan are listed, to generate a delivery pattern candidate list (hereafter also referred to as “delivery pattern list”). Table 2 is an example of the delivery pattern list.
In the example in Table 2, the delivery pattern list includes information for identifying a delivery pattern (pattern ID), information for identifying transportation equipment used (transportation equipment ID), and information for identifying a loading place (loading place ID). The delivery pattern list also includes information for identifying the type and quantity of each article (article 1 ID, article 2 ID, and respective tonnage), information of the delivery start time, and information of the delivery finish time. In the delivery plan generation method according to this embodiment, appropriate delivery patterns are selected from the delivery pattern list by optimization calculation or the like. The set of the selected delivery patterns is a delivery plan. In the optimization calculation, a combination of delivery patterns that satisfies supply and demand constraints and transportation equipment constraints and minimizes (maximizes) an evaluation index such as cost is calculated. In the example in Table 1 and Table 2, the number of loading places and the number of unloading places are each one, but the delivery plan generation method according to this embodiment is equally applicable in the case where there are a plurality of loading places and there are a plurality of unloading places.
Suppose the parameters of each delivery pattern have the respective degrees of freedom in Table 3. Then, the total number of combinations is approximately 1,360,000. In the case where there are such a large number of combinations, it is not practical to find an optimum solution only by optimization calculation because the calculation time is enormous.
In view of this, in the delivery plan generation method according to this embodiment, the annealing machine 30 performs a process of narrowing delivery pattern candidates beforehand. The annealing machine 30 is a calculator specialized in optimization calculation, and stochastically calculates a variable that minimizes or maximizes an objective function having, as an argument, a variable implemented by qubits. Methods of the annealing machine 30 include a digital method and a method using a quantum effect, and any of these methods may be used in this embodiment. The annealing machine 30 is capable of optimization calculation faster than a typically used general-purpose computer. Here, the object to be solved by the annealing machine 30 needs to be formulated into an Ising model defined in Formula (1).
min Σi,j(i≥j)Qijxixj (1)
The annealing machine 30 performs calculation so as to minimize the value of Formula 1, and outputs the resultant x which is a solution. Q is a coefficient matrix, and is calculated based on information of input data, constraint conditions, and an evaluation index. xp (p=1, 2, . . . , i, . . . P) is a binary variable. Although minimization is used as an example in Formula (1), maximization can be equally used by plus/minus inversion of the value of coefficient matrix Q. Here, the annealing machine 30 calculates the constraint conditions as a penalty, as part of the evaluation function. Accordingly, the solution output from the annealing machine 30 does not necessarily satisfy the constraint conditions. Hence, in the delivery plan generation method according to this embodiment, first the annealing machine 30 narrows delivery pattern candidates, and then the delivery plan generation device 20 which is a general-purpose computer selects, from the narrowed delivery patterns, delivery patterns that satisfy the constraint conditions by an optimization method to generate a delivery plan.
The delivery plan generation method by the system 10 according to this embodiment will be described below, with reference to a flowchart in
First, the input section 24 in the delivery plan generation device 20 receives input of information necessary for a delivery plan (step S100). The information necessary for a delivery plan includes plan information, constraint information, and an evaluation index. The plan information includes, for example, information of available transportation equipment and deliverable unloading places and loading places, transportation equipment use cost, and loadable weight capacity. Table 4 to Table 7 indicate an example of plan information. Table 4 indicates information of available transportation equipment.
Table 5 indicates loading place information and loadable article information.
Table 6 indicates unloading place information, needed article information and weight, and desired delivery time period information.
Table 7 indicates deliverable route (loading place and unloading place) information and required time information.
The constraint information is information about the constraint conditions that need to be satisfied by the delivery plan, and includes, for example, the following constraint conditions 1 to 4:
The evaluation index is an index for evaluating a generated delivery plan. For example, the evaluation index is minimization of delivery cost. In this case, a delivery plan with a lower delivery cost is evaluated more highly.
After the information necessary for a delivery plan is input, the controller 21 in the delivery plan generation device 20 generates a plurality of delivery patterns based on the input information (step S110). The controller 21 determines constraints that can be considered in units of delivery patterns beforehand, and generates only delivery patterns satisfying such constraints. The constraints that can be considered in units of delivery patterns are, for example, constraint conditions 2 and 3. The controller 21 also calculates the delivery cost of each delivery pattern. For example, the controller 21 calculates the delivery cost based on the use cost of transportation equipment per unit time and the required time for each route.
The controller 21 then inputs the generated plurality of delivery patterns to the annealing machine 30 to calculate a plurality of solutions, and, based on the calculated solutions, narrows the plurality of delivery patterns down to a designated number of delivery patterns (step S120).
Specifically, the controller 21 generates Formula (1) based on the input information and the delivery pattern information, and transmits input data to the annealing machine 30. Variable xi in Formula (1) is a variable that takes a value of 1 to indicate selecting the ith delivery pattern and takes a value of 0 to indicate not selecting the ith delivery pattern. The annealing machine 30 calculates the value of variable xi so as to minimize the value of Formula (1). Coefficient matrix Q in Formula (1) is the sum of coefficient matrixes representing the evaluation index and the constraint information by Formula (1). For example, the constraint that transportation equipment cannot be used simultaneously (constraint condition 1) is represented by a coefficient matrix in Formula (2). In the case where the evaluation index is the delivery cost, the delivery cost is represented by a coefficient matrix in Formula (3).
Regarding constraint condition 4, the constraint of delivering a needed article to an unloading place is represented by Formula (4). Developing Formula (4) and rearranging it by x yields Formula (5).
In these formulas, Scpi represents the number of articles p delivered to unloading place c by delivery pattern i, and Dcp represents the number of articles p needed in unloading place c. Adding Formulas (2), (3), and (5) together yields the following Formula (6).
Q
ij
=w
1
QA
ij
+w
2
QC
ij
+w
3
QD
ij (6)
In Formula (6), w1, w2, and w3 are coefficients. These coefficients are set to sufficiently large values to satisfy the constraints as much as possible. The purpose of this step is to narrow the delivery patterns. Therefore, there is no need to satisfy all constraints. Hence, to obtain various delivery pattern candidates, the value of at least one of w1, w2, and w3 may be adjusted to a low value so as not to satisfy the constraints to a certain degree.
After generating Q in Formula (6), the controller 21 inputs Q to the annealing machine 30. The annealing machine 30 performs calculation so as to minimize the value of Formula (1), and outputs the resultant x which is a solution. The delivery plan generation device 20 receives the output plurality of solutions. Based on the plurality of solutions, the controller 21 narrows the plurality of delivery patterns down to the designated number of delivery patterns.
After narrowing the plurality of solutions down to the designated number of delivery patterns in step S120, the controller 21 in the delivery plan generation device 20 generates a delivery plan (step S130). Specifically, using the delivery pattern candidates narrowed by the annealing machine 30 as input, the controller 21 calculates a combination of delivery patterns satisfying the constraints by an optimization method. Examples of the optimization calculation method include a branch-and-bound-based solver, a constraint programming-based solver, and metaheuristic-based calculation.
Consider the case where the number of delivery patterns generated in step S110 exceeds the upper limit of the number of delivery patterns that can be input to the annealing machine 30. In such a case, in step S120, for example the controller 21 performs a process of inputting delivery patterns randomly selected from the plurality of delivery patterns to the annealing machine 30, a plurality of times. The number of delivery patterns selected is less than or equal to the number of delivery patterns that can be input to the annealing machine 30. The annealing machine 30 may then calculate solutions corresponding to each input, and narrowing may be performed based on the solutions. In detail, the controller 21 randomly selects different delivery pattern candidates from the delivery patterns generated in step S110. The controller 21 inputs the selected delivery patterns to the annealing machine 30 to calculate a plurality of solutions. The controller 21 performs this process a plurality of times while changing randomly selected delivery patterns each time. The delivery patterns are narrowed down to the designated number of delivery patterns based on the solutions output each time the process is performed. The number of delivery patterns resulting from narrowing by the annealing machine 30 may be set to greater than or equal to the designated number, and the controller 21 may further narrow the delivery patterns to the designated number of delivery patterns. Since the calculation by the annealing machine 30 is very fast, performing the calculation a plurality of times takes only a short calculation time. Thus, since the annealing machine 30 is capable of very fast calculation and is capable of outputting a plurality of different solutions in each calculation operation, the narrowing of the delivery patterns can be carried out by this process.
The above describes an example in which all delivery patterns selected in the plurality of solutions output from the annealing machine 30 are used in the calculation by the delivery plan generation device 20 in the next step S120, but the presently disclosed techniques are not limited to such.
An example of generating a delivery plan for delivering raw material such as iron ore necessary for steelmaking from overseas using ships will be described below. In this example, a branch-and-bound-based solver was used as the optimization method by the delivery plan generation device 20. The annealing machine 30 performed calculation to select delivery patterns from randomly selected 1000 delivery pattern candidates. In a program used for verification, approximately 100 delivery patterns were selected. Then, approximately 1000 different solutions were obtained. The frequency of each delivery pattern was examined, and 200 delivery patterns in descending order of frequency were stored. This process was performed twenty times, and a total of 4000 delivery patterns were taken to be delivery pattern candidates to be input to the delivery plan generation device 20. The time taken to perform the process twenty times was approximately 20 seconds. The upper limit of the calculation time of optimization calculation in the delivery plan generation device 20 was set to 600 seconds, and the calculation was discontinued halfway.
Thus, the delivery plan generation method and the delivery plan generation device 20 in the system 10 according to the present disclosure narrow a large number of delivery patterns down to a designated number of delivery patterns using the annealing machine 30. The annealing machine 30 outputs a plurality of solutions in one calculation operation. This makes it possible to obtain various solutions that takes similar values of Formula (1), and therefore is useful for appropriate delivery pattern narrowing. The calculation of the plurality of solutions by the annealing machine 30 is fast, with the calculation time being on the order of microseconds to milliseconds. The calculation time when obtaining such various solutions by the conventional method is on the order of seconds to minutes. The delivery plan generation device 20 generates a delivery plan based on delivery patterns selected from the designated number of delivery patterns, so that a delivery plan having a high evaluation value can be generated in a short time. To narrow the delivery patterns down to the designated number of delivery patterns, it suffices to formulate the object to be solved into the Ising model defined in Formula (1) and repeatedly solve it by the annealing machine 30. The process is therefore versatile with no need for narrowing rules and knowledge. By performing operation using the delivery plan generated by the delivery plan generation method according to the present disclosure, operation according to a delivery plan with a high evaluation value (for example, operation at low delivery cost) can be achieved. The delivery plan generation method, the operation method, and the delivery plan generation device 20 in the system 10 according to the present disclosure can thus improve techniques relating to delivery plan generation.
While the presently disclosed techniques have been described by way of the drawings and embodiments, various changes and modifications may be easily made by those of ordinary skill in the art based on the present disclosure. Such changes and modifications are therefore included in the scope of the present disclosure. For example, the functions included in the components, steps, etc. may be rearranged without logical inconsistency, and a plurality of components, steps, etc. may be combined into one component, step, etc. and a component, step, etc. may be divided into a plurality of components, steps, etc.
Number | Date | Country | Kind |
---|---|---|---|
2020-004599 | Jan 2020 | JP | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2020/046427 | 12/11/2020 | WO |