This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2018-005256, filed on Jan. 17, 2018, the entire contents of which are incorporated herein by reference.
The embodiments discussed herein relate to an optimization apparatus and a control method thereof.
In today's society, information processing is performed in various fields by using arithmetic devices such as computers. Meaningful results are obtained by calculating and processing various data, and the obtained results are used for prediction, determination, and control operations, for example. Optimization processing is one of the important techniques in the field of information processing. For example, the optimization processing is applicable to a problem in which a solver needs to minimize the resources or cost needed when certain processing is performed. The optimization processing is also applicable to a problem in which the solver needs to maximize the effect obtained by the certain processing. Apparently, solving these problems is very important.
As a typical optimization problem, there is a linear programming in which an evaluation function represented by a linear sum of a plurality of continuous variables is used. In this linear programming, values are obtained for the variables such that the evaluation function is maximized or minimized under constraints represented by the linear sum. The linear programming is used in various fields such as product production scheduling. For this linear programming, excellent algorithms such as a simplex method and an interior point method are known, and even a problem having hundreds of thousands of variables or more is efficiently solvable.
There are also many optimization problems in which discrete values are used for variables instead of continuous values. One example is a traveling salesman problem in which a solver determines the shortest possible route that a salesman takes when the salesman visits a plurality of cities sequentially and returns to the origin city. Another example is a knapsack problem in which a solver is given a set of different items and selects a set of items with which the solver fills a knapsak such that the total value of the selected items is as large as possible. This kind of problem is referred to as a discrete optimization problem, a combinatorial optimization problem, etc., and it is known that calculation of an optimal solution for this kind of problem is very difficult.
The biggest reason for this difficulty is that only discrete values are used for individual variables. Namely, an optimal solution is not obtainable by continuously changing variables in a direction in which an evaluation function is improved. In addition, there are extraordinary numbers of values that result in local extrema of the evaluation function (local minimums (maximums) or local solutions), other than the values of the variables that result in an accurate optimal value (an optimal solution or a global solution). Thus, since a method such as a brute-force method needs to be used to obtain an optimal solution certainly, the calculation time is significantly extended. Among the discrete optimization problems, there are many problems referred to as NP (Non-deterministic Polynomial)-hard problems in complexity theory. In these NP-hard problems, the calculation time for obtaining an optimal solution is expected to extend exponentially with respect to the size of the problem (namely, the number of variables). The above traveling salesman problem and knapsack problem are also NP-hard problems.
As described above, it is very difficult to certainly obtain optimal solutions to discrete optimization problems. Thus, for practically important discrete optimization problems, algorithms that use characteristics unique to the respective problems are created. As described above, in many discrete optimization problems, to obtain an exact solution, the calculation time is expected to extend exponentially with respect to the size of the problem. Thus, many of the practical solution methods are approximate solution methods in which a value of an evaluation function does not indicate an optimal value but a value close to the optimal value as a solution.
In contrast to these approximation algorithms specially designed for the target problems, there are also known other approximation algorithms in which a wide range of problems are solved without using characteristics unique to the problems. These approximation algorithms are referred to as metaheuristics, and their examples include simulated annealing (SA), a genetic algorithm, and a neural network. While these algorithms could have lower efficiency than the algorithms that suitably use characteristics unique to the problems, these algorithms are expected to obtain solutions more quickly than the algorithms designed to obtain exact solutions.
Hereinafter, simulated annealing will be described.
Simulated annealing is a kind of a Monte Carlo method and is a method in which a solution is stochastically calculated by using a random number. The following description will be made by using, as an example, a problem in which a value of an evaluation function to be optimized is minimized, and the value of the evaluation function will be referred to as energy. If the problem was to maximize the value, the sign of the evaluation function would be changed.
Simulated annealing starts with an initial state in which a discrete value has been assigned to an individual variable. Next, from the current state (a combination of values of variables), a state close to the current state (for example, a state in which only one of the variables has been changed) is selected, and this state transition is examined. By calculating change of the energy associated with the state transition, whether to adopt the state transition and change the current state or maintain the original state without adopting the state transition is stochastically determined based on the calculated value. By setting the adoption probability of a state transition that results in a drop in the energy to be greater than the adoption probability of a state transition that results in a rise in the energy, state changes occur in a direction in which the energy drops on average. Thus, it is expected that the state will be transitioned to a more suitable state over time. Consequently, an optimal solution or an approximate solution that results in energy close to the optimal solution could be obtained finally. If whether to adopt the state transition is determined in a deterministic way, for example, if state transitions that result in a drop in the energy are adopted and those that result in a rise in the energy are not adopted, the change of the energy weakly decreases over time. However, once a local solution is reached, no further changes will occur. As described above, in a discrete optimization problem, since there are extraordinary numbers of local solutions, in many cases the state is stuck at a local solution that is not very close to an optimal value. Thus, it is important to determine whether to adopt the state transition stochastically.
In simulated annealing, it has been proved that a state reaches an optimal solution with an infinite time (an infinite number of iterations) if the adoption (acceptance) probability of the transition of the state is determined as follows.
(1) When an energy change associated with a state transition is denoted by (ΔE), an acceptance probability p of the state transition is determined by any one of the following functions f(x).
In mathematical formula 1-1, T represents a parameter referred to as a temperature and is changed as follows.
(2) As expressed by the following mathematical formula, the temperature T is dropped logarithmically with respect to the number t of iterations.
In the above mathematical formula, T0 represents an initial temperature, and it is desirable that a sufficiently large value be set as T0 on the basis of the problem.
When the acceptance probability expressed by the mathematical formulas in the above (1) is used and when a steady state is reached after a sufficient number of iterations, the occupation probability of an individual state is in accordance with a Boltzmann distribution at thermal equilibrium in thermodynamics. Since the occupation probability of a lower energy state rises by gradually decreasing a sufficiently high initial temperature, when the temperature has sufficiently dropped, a low energy state is supposed to be obtained. Since this behavior resembles state change seen when material is annealed, this method is called simulated annealing. In simulated annealing, the stochastic occurrence of a state transition that results in a rise in the energy corresponds to thermal excitation in physics.
As described above, in simulated annealing, an optimal solution is reached by setting an infinite number of iterations. However, in reality, since a solution needs to be obtained with a finite number of iterations, an optimal solution is not obtained certainly. In addition, since the temperature drops very gradually in accordance with the above formula, the temperature does not drop sufficiently within a finite time. Thus, in many cases of actual simulated annealing, the temperature is dropped more quickly, instead of using the logarithmic temperature change.
An optimization apparatus 10 includes a state storage unit 11 that holds the current state S (values of a plurality of state variables). The optimization apparatus 10 also includes an energy calculation unit 12 that calculates, when at least one state transition from the current state S occurs as a result of change of at least one of the values of the plurality of state variables, the energy changes {ΔEi} of the respective state transitions. In addition, the optimization apparatus 10 includes a temperature control unit 13 that controls a temperature T and a transition control unit 14 that controls state changes.
The transition control unit 14 refers to the temperature T, the energy changes {ΔEi}, and a random number to stochastically determines whether to accept any of a plurality of state transitions according to a relative relationship between the energy changes {ΔEi} and the thermal excitation energy.
The transition control unit 14 will be described in more detail. The transition control unit 14 includes a candidate generation unit 14a that generates state transition candidates and a transition acceptance determination unit 14b that stochastically determines whether to accept each state transition candidate from the corresponding energy changes {ΔEi} and the temperature T. In addition, the transition control unit 14 includes a transition determination unit 14c that determines a candidate to be adopted from the accepted candidates and a random number generation unit 14d that generates a probability variable.
Next, an operation in a single iteration will be described. First, the candidate generation unit 14a generates at least one state transition candidate (candidate number {Ni}) from the current state S stored in the state storage unit 11 to the next state. The energy calculation unit 12 calculates the energy changes {ΔEi} for the respective state transition candidates by using the current state S and the respective state transition candidates. By using the temperature T generated by the temperature control unit 13 and a probability variable (a random number) generated by the random number generation unit 14d, the transition acceptance determination unit 14b determines whether to accept each of the state transitions with the acceptance probability expressed by the above formulas 1-1 to 1-3 based on the energy changes {ΔEi} of the respective state transitions. In addition, the transition acceptance determination unit 14b outputs transition determination results {fi} indicating whether to accept the respective state transitions (the results will hereinafter be referred to as state transition acceptance determination results, as needed). When the transition acceptance determination unit 14b has accepted a plurality of state transitions, the transition determination unit 14c randomly selects one of the state transitions by using a random number. Next, the transition determination unit 14c outputs the transition number N of the selected state transition and the corresponding transition determination result f. When there is an accepted state transition, the values of the state variables stored in the state storage unit 11 are updated based on the adopted state transition.
Starting with the initial state, the optimization apparatus 10 repeats the above iteration while causing the temperature control unit 13 to drop the temperature. When a certain number of iterations is reached, the optimization apparatus 10 ends the operation. Alternatively, when a termination determination condition is satisfied, for example, when the energy falls below a certain value, the optimization apparatus 10 ends the operation. The solution outputted by the optimization apparatus 10 is the state corresponding to the end of the operation. However, in reality, since the temperature does not reach 0 with a finite number of iterations, an individual state occupancy rate has a distribution represented by a Boltzmann distribution or the like even at the end of the operation. Namely, there is no guarantee that an optimal solution or a good solution is obtained. Thus, in a realistic solution method, the lowest energy state obtained with a finite number of iterations is stored and outputted finally.
The transition control unit 14 includes a random number generation circuit 14b1, a selector 14b2, a noise table 14b3, a multiplier 14b4, and a comparator 14b5.
Of all the energy changes {ΔEi} calculated for the respective state transition candidates, the selector 14b2 selects and outputs one energy change corresponding to the transition number N, which is a random number generated by the random number generation circuit 14b1.
Functions of the noise table 14b3 will be described below. For example, a memory such as a random access memory (RAM) or a flash memory may be used as the noise table 14b3.
The multiplier 14b4 outputs a product of a value outputted by the noise table 14b3 and the temperature T (the product corresponds to the above thermal excitation energy).
The comparator 14b5 compares the product outputted by the multiplier 14b4 with the energy change selected by the selector 14b2 and outputs the comparison result as a transition determination result f.
Basically, the function described above is implemented without change on the transition control unit 14 illustrated in
A circuit that outputs 1 when the acceptance probability p is established and outputs 0 when (1−p) is established may be realized by a comparator that have two input terminals a and b and that outputs 1 when a>b and outputs 0 when a<b. More specifically, the acceptance probability p is inputted to the input terminal a of the comparator, and a uniform random value, which is a value in a section [0, 1) , is inputted to the input terminal b. Thus, by inputting a value indicating the acceptance probability p calculated by using formula (1) based on the energy change and the temperature T to this input terminal a of the comparator, the above function is realized.
Namely, assuming that f is the function used in the formulas in the above (1) and that u is a uniform random number, which is a value in the section [0, 1), the circuit that outputs 1 when f(ΔE/T)>u realizes the above function.
The same function is realized by any of the following variations. The two numbers maintain the same magnitude relationship even when the same monotonically increasing function is applied to the two numbers. Thus, even when the same monotonically increasing function is applied to the two input terminals of the comparator, the same output is obtained. When an inverse function f−1 of the function f is adopted as this monotonically increasing function, it is seen that a circuit that outputs 1 when −ΔE/T>f−1(u) or a circuit that outputs 1 when ΔE/T≤f−1(u) is suitable. In addition, since the temperature T is positive, a circuit that outputs 1 when −ΔE>Tf−1(u) or a circuit that outputs 1 when ΔE≤Tf−1(u) is also suitable. The noise table 14b3 in
To realize the circuit that outputs 1 when −ΔE>Tf−1(u), the selector 14b2 in
While the transition control unit 14 also includes, for example, a latch circuit that holds a determination result, etc. and a state machine that generates the corresponding timing, these components are not illustrated in
While simulated annealing is a versatile method and is very appealing, since the temperature needs to be dropped gradually, a relatively long calculation time is needed. In addition, it is difficult to suitably adjust how the temperature is dropped based on the problem. These problems will hereinafter be described with reference to
There are many local solutions with poor approximation along state transition paths from an initial value to an optimal solution or an approximate solution. To escape from these local solutions sufficiently quickly, a high temperature that enables sufficient thermal excitation is needed. However, since the energy spread is large in a Boltzmann distribution at a high temperature, the difference between the occupation probability of an optimal solution or a good approximate solution with low energy (hereinafter referred to as a good solution) and the occupation probability of a local solution with relatively high energy and poor approximation (hereinafter referred to as a poor solution) is small. Thus, even if the state transition has escaped from a local solution quickly, the state transition will be stuck at any one of the many subsequent poor solutions. Thus, the probability that the state transition reaches a good solution is very small. To raise the occupation probability of a good solution, a low temperature that achieves sufficiently smaller thermal excitation energy compared with the energy difference from a poor solution is needed. However, in this case, since the thermal excitation energy is small, the probability that the state transition is able to go over energy hills along a path is very low, and as a result, the state rarely changes. Thus, the state transition needs to slowly experience an intermediate temperature that enables the state transition to go over some energy hills and achieves some difference in occupation probability. In this way, the occupation probability of a good solution is increased gradually. If the temperature is dropped excessively slowly, since the temperature is not dropped sufficiently within a finite time, the occupation probability of a good solution is not increased finally. In contrast, if the temperature is dropped excessively quickly, the temperature is dropped before the state transition escapes from a local solution. Thus, the state transition remains stuck at a poor solution. Thus, as the temperature drops more and more, the rate of the change needs to be decreased sufficiently, and sufficient time is needed until a Boltzmann distribution at that temperature is neared.
As described above, in conventional simulated annealing, since escaping from a local solution is sought only by thermal excitation based on the temperature, it is desirable that the temperature be gradually dropped and how the temperature is dropped be suitably adjusted based on the problem.
See, for example, Japanese Laid-open Patent Publication No. 2017-138760
As described above, in simulated annealing, it takes much time for the state transition to escape from a local solution, and a long calculation time is needed to solve the optimization problem.
According to one aspect, there is provided an optimization apparatus including: a state storage unit configured to hold values of a plurality of state variables included in an evaluation function that represents energy; a calculation unit configured to calculate energy changes of the energy for a plurality of state transitions that occur in response to change of any of the values of the plurality of state variables; a temperature control unit configured to control a temperature; and a transition control unit configured to detect, when stochastically determining based on the temperature, the energy changes, and a random number whether to accept any of the plurality of state transitions according to a relative relationship between the energy changes and thermal excitation energy, a minimum value among the energy changes calculated by the calculation unit for the plurality of state transitions and subtract, when the minimum value is positive, an offset obtained by multiplying the minimum value by a value that is greater than 0 and less than or equal to 1 from each of the energy changes corresponding to the plurality of state transitions.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention.
Embodiments will be described below with reference to the accompanying drawings, wherein like reference characters refer to like elements throughout.
As illustrated in
When at least one of the values of a plurality of state variables has changed and at least one state transition from the current state has occurred, the minimum value detection circuit 21 receives an energy change {ΔEi} of an individual state transition. Next, the minimum value detection circuit 21 detects a minimum value ΔEmin of the energy changes {ΔEi} of the state transitions.
The multiplication circuit 22 is an arithmetic circuit that outputs values (MΔEmin) each of which is obtained by multiplying the minimum value ΔEmin by a value M (0<M≤1).
The addition circuit 23 is an arithmetic circuit that subtracts an individual value MΔEmin as an offset from the energy changes {ΔEi} of the state transitions (adds −MΔEmin to {ΔEi}). A subtraction circuit may be used instead of the addition circuit 23.
The selection signal generation circuit 24 generates a selection signal sign. When the minimum value ΔEmin is 0 or less, the selection signal generation circuit 24 generates a selection signal sign (for example, 0) that causes the selector 25 to select the energy changes {ΔEi} of the state transitions. When the minimum value ΔEmin is greater than 0, the selection signal generation circuit 24 generates a selection signal sign (for example, 1) that causes the selector 25 to select the values calculated by the addition circuit 23.
Based on the selection signal sign, the selector 25 selects and outputs the energy changes {ΔEi} of the state transitions or the values calculated by the addition circuit 23, namely, {ΔEi}−MΔEmin. The values outputted by the selector 25 are supplied to the selector 14b2. When the selector 25 selects and supplies the energy changes {ΔEi} to the selector 14b2, the selector 14b2 selects an energy change ΔE corresponding to a transition number N from the energy changes {ΔEi}, inverts the sign of the selected energy change ΔE, and outputs −ΔE. When the selector 25 selects and supplies the energy changes ({ΔEi}−MΔEmin) obtained by subtracting the offset MΔEmin from the energy changes {ΔEi} to the selector 14b2, the selector 14b2 selects an energy change ΔE−MΔEmin corresponding to the transition number N. Next, the selector 14b2 inverts the sign of the energy change ΔE−MΔEmin and outputs −ΔE+MΔEmin.
When the comparator 14b5 is configured to output 1 when the energy change ≥Tf−1(u), the selector 14b2 does not need to invert the sign as described above.
For example, the minimum value detection circuit 21 is formed by a plurality of stages of two-input minimum value detection circuits arranged in the form of a tournament. Each of the two-input minimum value detection circuits 21a1, 21a2, . . . , 21am in the first stage is supplied with energy changes corresponding to state transitions of two state variables among the energy changes {ΔEi} of the state transitions. For example, among the n state variables, energy changes (ΔE1 and ΔE2) corresponding to the state transitions of the first and second state variables are supplied to the two-input minimum value detection circuit 21a1. The two-input minimum value detection circuit 21a1 outputs the smaller one of the two energy changes (ΔE1 and ΔE2).
Each of the two-input minimum value detection circuits is realized by, for example, a comparison circuit and a selector.
Each of the two-input minimum value detection circuits in the second and subsequent stages outputs the smaller one of the energy changes outputted by the two two-input minimum value detection circuits in the previous stage. For example, the two-input minimum value detection circuit 21b in the second stage selects and outputs the smaller one of the energy changes outputted by the two-input minimum value detection circuits 21a1 and 21a2 in the previous stage.
In the case of this minimum value detection circuit 21, the energy change outputted by the two-input minimum value detection circuit 21c in the last stage is the minimum value ΔEmin.
By using the transition control unit 20 as described above, the acceptance probability of the state transition at a local solution is increased, and escaping from the local solution is accelerated. The reason will hereinafter be described.
As expressed by the above formulas 1-1 to 1-3, as the temperature decreases or as the energy change increases (positively), the state transition acceptance probability decreases.
As illustrated in
As expressed by formulas 1-1 to 1-3, as the smaller the energy change is, the greater the state transition acceptance probability will be. When the energy change is 0 or less, the acceptance probability reaches the maximum value (=1). Thus, among the energy changes {ΔE1} of the state transitions, when the minimum value ΔEmin is positive, by subtracting a value (MΔEmin) obtained by multiplying the minimum value ΔEmin by M from the individual state transition energy changes {ΔEi}, the acceptance probabilities are increased, as illustrated in
A waveform 31a indicates an example of the energy changes {ΔEi} of state transitions at a local solution. In the case of the waveform 31a, by subtracting as an offset a value (MΔEmin) obtained by multiplying the minimum value ΔEmin by M from the energy changes {ΔEi} of individual state transitions, the acceptance probabilities are increased as described above. A waveform 31b indicates energy changes when the minimum value ΔEmin is subtracted from the energy changes {ΔEi} indicated by the waveform 31a (namely, when M=1). When M=1, the minimum value of the energy changes ΔE indicated by the waveform 31b reaches 0, and the acceptance probability of the state transition corresponding to the minimum value reaches 1. In addition, a waveform 31c indicates energy changes when 0.5ΔEmin is subtracted from the energy changes {ΔEi} indicated by the waveform 31a (namely, M=0.5).
The convergence theorem of simulated annealing indicates that a good result is obtained if whether to accept an individual state transition is determined in accordance with the state transition probability of a
Metropolis method or a Gibbs method. Since the probabilities of state transitions are very small at local solutions, selection of a transition candidate is performed many times, and the branch ratio of the subsequent state transitions is proportional to the transition probability of a Metropolis method or Gibbs method. Thus, if the transition control unit increases the absolute values of the acceptance probabilities of the individual state transitions while maintaining the relative ratio of these acceptance probabilities, the branch ratio of the individual state transitions is maintained. Thus, the transition control unit is able to shorten the time for which the state is stuck at a local solution, without negatively affecting the convergence. As a result, the calculation time is shortened.
As described above, by subtracting MΔEmin as an offset from the energy changes {ΔEi} of the individual state transitions, the transition control unit is able to increase the absolute values of the acceptance probabilities while maintaining the relative ratio of the acceptance probabilities of the individual state transitions as illustrated in
In simulated annealing in which the energy to be optimized is expressed by an ising model and in optimization based on a Boltzmann machine almost equivalent to the simulated annealing, a method for generating transition candidates and calculating the energy changes associated with state transitions will briefly be described.
An ising model is a model that represents a system formed by N spins that interact with each other. An individual spin si (corresponding to an individual state variable described above) is represented by a binary value of ±1. The energy in the system is expressed by the following formula 4.
In formula 4, Ji,j represents an interaction coefficient between spins si and sj, and hi represents an external magnetic field coefficient, which is a bias value in the system.
A state transition candidate from the current state to the next state is a single spin flip, and there are N candidates. Thus, as the transition candidates, the number of a single spin that is flipping or a group of the numbers of a plurality of spins that are flipping may be generated.
Change of the energy associated with a flip of the i-th spin is expressed by the following formula 5.
In the following formula 6, Fi referred to as a local field value represents the rate of change of the energy associated with a flip of an individual spin.
Since whether to accept the state transition is determined based on change of the energy, basically, change of the energy is calculated from the local field value, instead of calculating the energy itself. When the state corresponding to the lowest energy obtained as the output is used, the energy is obtained by calculating change of the energy from the local field value and accumulating the results.
In addition, the following mathematical formula is obtained.
Thus, there is no need to recalculate the local field value from a matrix operation every time. Only the amount of change due to a flip of a spin associated with a state transition is added. Thus, the state storage unit 11 and the energy calculation unit 12 illustrated in
In addition, an optimization method based on a Boltzmann machine used in a neural network is the same as the simulated annealing using an ising model with the exception that an individual state variable corresponding to an individual spin is indicated by a binary value (0, 1). The energy, the energy change, and the local field value in a Boltzmann machine are expressed by the following formulas 8 to 10.
In many cases, a neuron in a Boltzmann machine corresponds to a spin in an ising model.
As described above, simulated annealing using an ising model is equivalent to simulated annealing using a Boltzmann machine. Thus, these simulated annealings are mutually convertible.
In simulated annealing using a Boltzmann machine (and simulated annealing using an ising model), only one state variable changes in association with a state transition, the energy change corresponding to this change is previously calculable by using a local field value. Thus, in
However, in a non-Boltzmann machine, there are cases where transitions in which a plurality of state variables change need to be considered. In these cases, an implementation in which needed energy changes after generation of transition candidates are calculated could be more advantageous.
The transition control unit 40 illustrated in
As in the selector 25, the selector 25a selects, based on a selection signal sign, the energy changes {ΔEi} of the respective state transitions or the values calculated by an addition circuit 23, namely, the energy changes {ΔEi}−MΔEmin obtained by subtracting an offset from energy changes {ΔEi}. Next, the selector 25a inverts the signs of the selected energy changes and outputs the energy changes.
The comparator 14b5 outputs comparison results, each of which is a comparison result between an individual −{ΔEi} or −{ΔEi}+MΔEmin and a product (corresponding to thermal excitation energy) outputted by the multiplier 14b4, as transition determination results {fi}. For example, assuming that the energy change associated with a state transition of the k-th state variable sk is denoted by ΔEk, when −ΔEk or −ΔEk+MΔEmin is greater than the product outputted by the multiplier 14b4, the transition determination result f of the state variable sk indicates 1. When −ΔEk or −ΔEk+MΔEmin is less than the product outputted by the multiplier 14b4, the transition determination result f of the state variable sk indicates 0.
When the comparator 14b5 is configured to output 1 when the energy change ≤Tf−1(u), the selector 25a does not need to invert the sign as described above.
The transition number determination circuit 41 preferentially selects, based on the transition determination results {fi} of the individual state transitions outputted by the comparator 14b5, a state transition determined to be accepted by the comparator 14b5 and outputs the transition number N and the transition determination result f of the selected state transition.
Hereinafter, a circuit example of the transition number determination circuit 41 when the number of state variables is 1,024 will be described. The following description assumes that the comparator 14b5 outputs 1 as a transition determination result {fi} when the comparator 14b5 determines to accept a state transition and outputs 0 otherwise.
The transition number determination circuit 41 includes a noise generation circuit 50 and selection circuit units 51a1, 51a2, . . . , 51a32, and 52.
The noise generation circuit 50 generates and outputs 5-bit random numbers rd1 and rd2 as noise values. Different seeds (initial values) are used for the random numbers rd1 and rd2. For example, a linear feedback shift register (LFSR) or the like may be used as the noise generation circuit 50.
Each of the selection circuit units 51a1 to 51a32 receives 32 state transition determination results {fi} of the 1,024 transition determination results {fi}. Each of the selection circuit units 51a1 to 51a32 selects and outputs one of the 32 transition determination results based on the 5-bit random number rd1. In addition, each of the selection circuit units 51a1 to 51a32 generates and outputs a 5-bit index that indicates the one transition determination result selected from the respective 32 state transition determination results.
The selection circuit unit 52 receives the transition determination results and the 5-bit indexes outputted from the selection circuit units 51a1 to 51a32. Next, based on the transition determination results, the indexes, and the 5-bit random number rd2, the selection circuit unit 52 selects and outputs one transition determination result f of the 32 transition determination results and generates and outputs a 10-bit transition number N.
In
The selection circuit unit 51a1 includes selection circuits 60a to 60e. The selection circuit unit 51a1 also includes selection circuits 61a1 to 61a16, 61b1 to 61b8, 61c1 to 61c4, 61d1 and 61d2, and 61e. These selection circuits 61a1 to 61a16, 61b1 to 61b8, 61c1 to 61c4, 61d1 and 61d2, and 61e are connected in a tree shape in five stages.
The selection circuit 60a supplies 0 or 1 to the selection circuits 61a1 to 61a16 in the first stage based on the value of the first bit of the 5-bit random number rd1. The selection circuit 60b supplies 0 or 1 to the selection circuits 61b1 to 61b8 in the second stage based on the value of the second bit of the 5-bit random number rd1. The selection circuit 60c supplies 0 or 1 to the selection circuits 61c1 to 61c4 in the third stage based on the value of the third bit of the 5-bit random number rd1. The selection circuit 60d supplies 0 or 1 to the selection circuits 61d1 and 61d2 in the fourth stage based on the value of the fourth bit of the 5-bit random number rd1. The selection circuit 60e supplies 0 or 1 to the selection circuit 61e in the fifth stage based on the value of the fifth bit of the 5-bit random number rd1.
Each of the selection circuits 61a1 to 61a16 in the first stage receives two of the 1,024 state transition determination results {fi}. Next, based on the values of the corresponding transition determination results and 0 or 1 outputted by the selection circuit 60a, each of the selection circuits 61a1 to 61a16 selects and outputs one of the two transition determination results and generates and outputs a 1-bit index that indicates the determination result that it has selected.
Each of the selection circuits 61b1 to 61b8 in the second stage receives two of the 16 transition determination results and two of the 16 indexes outputted by the selection circuits 61a1 to 61a16. Next, based on the values of the corresponding transition determination results and 0 or 1 outputted by the selection circuit 60b, each of the selection circuits 61b1 to 61b8 selects and outputs one of the two transition determination results and generates and outputs a 2-bit index that indicates the determination result that it has selected.
Each of the selection circuits 61c1 to 61c4 in the third stage receives two of the eight transition determination results and two of the eight indexes outputted by the selection circuits 61b1 to 61b8. Next, based on the values of the corresponding transition determination results and 0 or 1 outputted by the selection circuit 60c, each of the selection circuits 61c1 to 61c4 selects and outputs one of the two transition determination results and generates and outputs a 3-bit index that indicates the determination result that it has selected.
Each of the selection circuits 61d1 and 61d2 in the fourth stage receives two of the four transition determination results and two of the four indexes outputted by the selection circuits 61c1 to 61c4. Next, based on the values of the corresponding transition determination results and 0 or 1 outputted by the selection circuit 60d, each of the selection circuits 61d1 and 61d2 selects and outputs one of the two transition determination results and generates and outputs a 4-bit index that indicates the determination result that it has selected.
The selection circuit 61e in the fifth stage receives the two transition determination results and the two indexes outputted by the selection circuits 61d1 and 61d2. Next, based on the values of the transition determination results and 0 or 1 outputted by the selection circuit 60e, the selection circuit 61e selects and outputs one of the two transition determination results and generates and outputs a 5-bit index that indicates the determination signal that it has selected.
The selection circuit unit 52 illustrated in
In
The selection circuit 61b1 includes an exclusive OR (XOR) circuit 70, an OR circuit 71, and selection circuit 72 and 73.
the XOR circuit 70 receives the transition determination results outputted by the selection circuits 61a1 and 61a2 in the first stage. In
The OR circuit 71 receives fg1 and fg2. When at least one of fg1 and fg2 represents 1, the OR circuit 71 outputs 1 as the transition determination result (denoted by fg3). When both fg1 and fg2 represent 0, the OR circuit 71 outputs 0 as fg3.
The selection circuit 72 receives fg1 and 0 or outputted by the selection circuit 60b. When the XOR circuit 70 outputs 1, the selection circuit 72 selects and outputs the value of fg1. When the XOR circuit 70 outputs 0, the selection circuit 72 selects and outputs the value outputted by the selection circuit 60b.
The selection circuit 73 receives the indexes outputted by the selection circuits 61a1 and 61a2 in the first stage. In
A value obtained by adding the 1-bit value outputted by the selection circuit 72 to the value of id1 or id2 outputted by the selection circuit 73 (added to an upper bit) is the index (denoted by id3 in
Each of the selection circuits 61a1 to 61a16 in the first stage illustrated in
When the selection circuit 60b outputs 1 and when the two transition determination results (fg1 and fg2) supplied to the selection circuit 61b1 illustrated in
When the selection circuit 60b outputs 0 and when fg1 and fg2 represent the same value, the selection circuit 61b1 outputs, as id3, a value obtained by adding a new bit 0 to the upper bit of id2. In addition, when the selection circuit 60b outputs 0 and when fg1 and fg2 represent 1 and 0, respectively, the selection circuit 61b1 also outputs, as id3, the value obtained by adding the new bit 1 to the upper bit of id1. In addition, when the selection circuit 60b outputs 0 and when fg1 and fg2 represent 0 and 1, respectively, the selection circuit 61b1 outputs, as id3, the value obtained by adding the new bit 0 to the upper bit of id2.
In addition, when at least one of fg1 and fg2 represents 1, fg3 represents 1. When both fg1 and fg2 represent 0, fg3 represents 0.
By using the transition number determination circuit 41 as described above, a state transition to be accepted is selected preferentially. Thus, since the state transition frequency is increased, the calculation time is expected to shorten further.
A transition control unit 80 includes an offset addition circuit 81 and an offset control circuit 82 added to the circuit portion that realizes the functions of the transition acceptance determination unit 14b illustrated in
The offset addition circuit 81 adds an offset y to −ΔE. In the circuit example in
The offset control circuit 82 performs a control operation such that the offset y at a local solution (a solution where the energy indicates a locally minimum value) is greater than that of a non-local solution. In the example in
When −ΔE+y, which is the sum of the −ΔE outputted by selector 14b2 and the offset y stored in the accumulator 82a, is greater than the product Tf−1(u) of the temperature T and the random number, the transition control unit 80 as described above accepts the corresponding state transition.
In addition, the accumulator 82a changes the offset y as follows. If a state transition has been accepted and has occurred, the accumulator 82a resets the offset y to 0. If no state transition has been accepted and has occurred, the accumulator 82a increments the offset y by the offset increment Δy.
As illustrated in
As illustrated in
In contrast, in the case of the transition control units 20 and 40 illustrated in
Results 90a to 90e indicate simulation results of change of the energy with respect to the number of iterations when the transition control unit 80 in
In contrast, results 91a to 91d indicate simulation results of change of the energy with respect to the number of iterations when the transition control unit 40 in
When the minimum energy value (the energy at an optimal solution) is about 6,000, in the case of the transition control unit 80, the smallest number of iterations it2 to reach an energy Ex, which is larger than the minimum value by about 10%, is about 65,000, which is more than triple the smallest number of iterations it1 in the case of the transition control unit 40.
Namely, the example in
The example in
The degree of the above effect differs depending on the optimization problem to be calculated. For example, the value of M is selected based on the individual optimization problem and the software simulation results as described above such that the calculation time is further shortened.
While an aspect of the optimization apparatuses and control methods thereof based on embodiments has been described, the above description is only an example. The embodiments are not limited to the above description.
In an aspect, the embodiments shorten the calculation time of an individual optimization problem.
All examples and conditional language provided herein are intended for the pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although one or more embodiments of the present invention have been described in detail, it should be understood that various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2018-005256 | Jan 2018 | JP | national |