The golden section search algorithm can be used for finding a minimum (or
maximum) of a single-variable function
. If it is known that the
function has a minimum between some two points, then we can search for it
iteratively, in a manner similar to the bisection search for the root of
an equation
. Specifically, if in the neighborhood of the minimum
we can find three points
corresponding to
,
then there exists a minimum between
and
. To search for this
minimum, we can choose another point
between
and
as shown
in the figure below, with the following two possible outcomes:
- If
, the minimum is inside the interval
associated with three new points
, i.e.,
is replaced by
.
- If
, the minimum is inside the interval
associated with three new points
, i.e.,
is replaced by
.
In either case, the new search interval
or
is
smaller than the old one
, i.e., such an iteration is guaranteed
to converge. Of course
can also be between
and
, the
iteration can be similarly carried out accordingly.
Similar to the bisection search for the root of
, here to search
for the minimum of
, we also want to avoid the worst possible case
in which the minimum always happens to be in the larger one of the two
sections
and
. We therefore choose
in such a way that the
two resulting search intervals will always be the same:
i.e.data:image/s3,"s3://crabby-images/c185a/c185ae3617688c2233cf6187536c5a0fcb79d59d" alt="$\displaystyle \;\;\;\;\;\;\;c=b-a$" |
(10) |
In other words, through out the iteration, the search interval should
always be partitioned into two sections with the same ratio:
ordata:image/s3,"s3://crabby-images/f5d3d/f5d3d0a1a83e7d6f2be9d2afc5fe3350c893daa5" alt="$\displaystyle \;\;\;\;\;
\frac{a+b}{b}=\frac{b}{b-c}=\frac{b}{a}$" |
(11) |
In either case, we get
data:image/s3,"s3://crabby-images/ec6b9/ec6b9f1ccfeaf8c7916aa19f9ddad260efde61df" alt="$\displaystyle a^2+ab-b^2=0$" |
(12) |
Solving this quadratic equation for
in terms of
we get
data:image/s3,"s3://crabby-images/9f68e/9f68e877c3fa8bcfcd6aba141eb0e71e3be19c76" alt="$\displaystyle a_{1,2}=\frac{-1\pm\sqrt{5}}{2}\;b
=\left\{\begin{array}{r}0.618\,b\\ -1.618\,b\end{array}\right.$" |
(13) |
We keep the positive result and get
data:image/s3,"s3://crabby-images/e89b0/e89b0fbb7f001a67634c0f0584be712e0b012ba7" alt="$\displaystyle \frac{a}{b}=0.618,\;\;\;\;\;\;\;\;\;
\frac{b}{a+b}=\frac{b}{0.618b+b}=\frac{1}{1.618}=0.618$" |
(14) |
This is the golden ratio between the two sections
and
of
the search interval.
The iteration of the golden section search can terminate when the size
of the search brackets
is small enough, compared with some
tolerance, such as
, pre-determined based on some prior knowledge
of the scale of the problem. However, this scale may be unknown, or it may
vary drastically, and an absolute tolerance may be too large for a small
scale problem but too small for a large scale problem. This problem can
be resolved by using a relative tolerance with a scale comparable with
that of the size of the problem:
data:image/s3,"s3://crabby-images/a436f/a436fcae5e97134d30e60ac43b5252e182cd4474" alt="$\displaystyle \vert x_2-x_0\vert < \epsilon(\vert x_1\vert+\vert x_3\vert)$" |
(15) |
where
is a small value such as
, and
represents the size of the search interval and
represents
the scale of the problem. When the inequality is satisfied, the iteration
is terminated.
It is possible that the three initial points chosen are such that either
or
, then we have to search
toward the descending direction of
until it starts to ascend.
For example, if
, they can be iteratively updated
by the following
data:image/s3,"s3://crabby-images/700c7/700c72807db6699ee1ba09bb7300e97bb35f8416" alt="$\displaystyle x^{new}_0=x^{old}_1,\;\;\;\;x^{new}_1=x^{old}_2,
\;\;\;\;x^{new}_2=x^{old}_2+c(x^{old}_2-x^{old}_1)$" |
(16) |
where
(e.g.,
), until we reach a point
at which
. Obviously the distance
grows exponentially
.