Ternary search explained

A ternary search algorithm[1] is a technique in computer science for finding the minimum or maximum of a unimodal function.

The function

Assume we are looking for a maximum of

f(x)

and that we know the maximum lies somewhere between

A

and

B

. For the algorithm to be applicable, there must be some value

x

such that

a,b

with

A\leqa<b\leqx

, we have

f(a)<f(b)

, and

a,b

with

x\leqa<b\leqB

, we have

f(a)>f(b)

.

Algorithm

Let

f(x)

be a unimodal function on some interval

[l;r]

. Take any two points

m1

and

m2

in this segment:

l<m1<m2<r

. Then there are three possibilities:

f(m1)<f(m2)

, then the required maximum can not be located on the left side –

[l;m1]

. It means that the maximum further makes sense to look only in the interval

[m1;r]

f(m1)>f(m2)

, that the situation is similar to the previous, up to symmetry. Now, the required maximum can not be in the right side –

[m2;r]

, so go to the segment

[l;m2]

f(m1)=f(m2)

, then the search should be conducted in

[m1;m2]

, but this case can be attributed to any of the previous two (in order to simplify the code). Sooner or later the length of the segment will be a little less than a predetermined constant, and the process can be stopped.choice points

m1

and

m2

:

m1=l+(r-l)/3

m2=r-(r-l)/3

Run time order

T(n)=T(2n/3)+1 =\Theta(logn)

Recursive algorithm

def ternary_search(f, left, right, absolute_precision) -> float: """Left and right are the current bounds; the maximum is between them. """ if abs(right - left) < absolute_precision: return (left + right) / 2

left_third = (2*left + right) / 3 right_third = (left + 2*right) / 3

if f(left_third) < f(right_third): return ternary_search(f, left_third, right, absolute_precision) else: return ternary_search(f, left, right_third, absolute_precision)

Iterative algorithm

def ternary_search(f, left, right, absolute_precision) -> float: """Find maximum of unimodal function f within [left, right]. To find the minimum, reverse the if/else statement or reverse the comparison. """ while abs(right - left) >= absolute_precision: left_third = left + (right - left) / 3 right_third = right - (right - left) / 3

if f(left_third) < f(right_third): left = left_third else: right = right_third

# Left and right are the current bounds; the maximum is between them return (left + right) / 2

See also

Notes and References

  1. Web site: Ternary Search . cp-algorithms.com . 21 August 2023.