Wolfe's Algorithm

Download as pdf or txt
Download as pdf or txt
You are on page 1of 16

Mathematical Programming Study l (1974) 190.205.

North-Holland Publishing Company

ALGORITHM FOR A LEAST-DISTANCE


P R O G R A M M I N G PROBLEM

Philip W O L F E
IBM Thomas J. Watson Re,~earch Center, Yorktown fteights, N.Y,, U.S.A.

Received 4 March 1974


Revised manuscript received 25 March 1974

An algorithm is developed for the problem of finding the point of smallest Euclidean
norm in the convex hull of a given finite point set in a Euclidean space, with particular
attention paid to the description of the procedure in geometric terms.

Dedication

The paper that follows was written in celebration of the work of


Albert W. Tucker in mathematical programming. It also bears witness
to his pervasive influence on my own work; the three postdoctoral years
I spent working under his direction at Princeton set the aims and style
of much of the rest of my career, and I have called on his helpfulness
and wisdom many times since then.
The paper deals with a certain quadratic programming problem and
its solution via pivoting in a condensed tableau. AI Tucker pioneered in
these areas, and though his first work in them was done more than
twenty years ago and mine just a little later, they have continued to
involve us both.
To give a highly condensed account of the development of"quadratic
programming", Al's papers [14, 15, 11] are the earliest I have found
which point out the usefulness and attractive properties of the quadratic
programming problem, and I believe it was these papers that led Edward
Barankin (my thesis advisor at Berkeley) and Robert Dorfman to make
the important connection between the simplex tableau and the K u h n - -
Tucker conditions for that problem [1, 2]. At Princeton, in Ars ONR
P. Wolfe, Algorithm for a least-distance programming problem 191

Logistics Project, Marguerite Frank and I used their result as an


essential part of applying what has become known as the Frank-Wolfe
algorithm to the quadratic programming problem [-10]; later, still with
the Project, I developed it further into "A simplex method for quadratic
programming" [20], which was the first use of complementary bases in
a nonlinear programming algorithm.
Meanwhile, AI continued on one hand to exploit tableaux and pivot
theory in many ways eg. [16, 17], and on the other hand to analyze the
structure of the general quadratic programming problem through the
particularly graphic properties of his "least-distance programming
problem", in which the minimand is the square of the Euclidean metric
[,18, 19, 13]. The present paper is about a special case of that problem,
and aims at relating, for an algorithm, the geometry of the problem--
which AI has used in many beautiful ways--to the algebra of its solution
by the tableaux AI taught me to use.
I hope he likes it.

1. Introduction

We develop a numerical algorithm for finding that point ofa polytope


in Euclidean n-space having smallest Euclidean norm. The polytope is
defined as the convex hull of a given point set P = {P, . . . . P,,}; alge-
braically, we are required to minimize t X 12 = XTX for all X of the form

X = ~ PkWk, ~ Wk = 1 for allw k >- O. (1.1)


k=l k=l

This problem is, of course, a problem of quadratic programming, for


which there are several excellent general algorithms [-3, 5, 9, 21] which
would probably all behave with comparable efficiency; but the special
nature of this problem--particularly the uniqueness of its solution X - -
encourages a more refined attack on it. The problem arises in a sur-
prising number of places, if one looks for it: we have used its solution
in a procedure for the minimization of nondifferentiable functions and
in the construction of hyperplanes separating two given point sets as in
[,4].
Since problem (1.1) is very much a geometry problem, we have taken
the route of first devising a plausible "geometric" procedure for solving
it, described in Section 2 and illustrated on a small example, and then
192 P. Wolfe, Algorithm Jor a h,ast-distance programming problem

using the familiar algebra of complementary pivot theory to describe


the calculations. The resulting algorithm (as explained in Section 7) may
be somewhat more efficient than some of the standard algorithms when
applied to this problem, but our primary interest here is in the fact that
all of the quantities that are consulted in performing it are geometrically
explainable. Sections 3 and 4 are devoted to the connections between
the entries of the tableau used in the calculation and the geometric
elements of importance. The algebra of the algorithm is set forth in
Section 5, while Section 6 tracks it in solving the example. Section 7 deals
with some numerical safeguards needed to make the method work on
a real computer, results from running some test problems, and the
conditions under which one would want to use this algorithm in practice.
The last section also refers to a different way [22-] of organizing the
calculations of the algorithm which we find better than this tableau form,
except when n > m. That was the original form of the algorithm; we are
indebted to Harlan Crowder for the suggestion of casting it into tableau
form, which was particularly appropriate for a problem of his in which
n=500andm = 10.
The following expressions are used frequently below: For a set Q of k
points in E" (taken to be a set of k column vectors, or the columns of the
n-by-k matrix Q),

A(Q) = { X" X = Q w, eTw = I}

is the affine hull of Q, and

C(Q) = IX: X = Q w , eXw = 1,w >- O}

is the convex hull ofQ. [e is the column vector (1, 1. . . . , 1)r. The number
of components in vectors like e and w is to be inferred from the context:
here, k]. The set Q is affinely independent if q ~ A(Q \ { q }) is false for all
q e Q. Finally, for any X ~ E"

H ( X ) = { y~En: X T Y = x T X I

will denote the (n - 1)-dimensional affine set passing through the point
X and normal to the line through X and the origin.
P. Wolfe, Algorithm for a least-distance programming problem 193

2. The algorithm: geometry

We call an affinely independent subset Q of P a corral if the point


of smallest norm in C(Q) is in its relative interior. Note that any singleton
is a corral. There is a corral whose convex hull contains the solution
of the smallest-norm problem over P, and our algorithm will find it.
The algorithm consists of a finite number of major cycles, each of
which consists of a finite number of minor cycles. At the start of each
major cycle we have a corral Q and the point X ~ C(Q) of smallest norm.
At the start of a minor cycle we have merely some affinely independent
set Q and some point X ~ C(Q). Each minor cycle yields another such Q
and X until the last, which finds a corral; that major cycle is finished,
and another ready to begin. The initial corral is the singleton given by
step 0 below. Subsequently, each major cycle begins at step I ; the minor
cycles, if any, in a major cycle constitute repetitions of steps 3 and 2.

Algorithm
Step O. Find a point of P of minimal norm. Let X be that point and
Q= {x}.
Step 1. If X = 0 or H(X) separates P from the origin, stop. Other-
wise, choose PJ e P on the near side of H(X) and replace Q by Q w {PJ }.
Step 2. Let Y be the point of smallest norm in A(Q). If Y is in the
relative interior of C(Q), replace X by Y and return to step 1. Otherwise
Step 3. Let Z be the nearest point to Y on the line segment C(Q) n X Y
(thus a boundary point of C(Q)). Delete from Q one of the points not
on the face of C(Q) in which Z lies, and replace X by Z. Go to step 2.

The example below illustrates the algorithm in a simple problem, gi-


ving the current Q and X at the end of each step.
We must show that the algorithm terminates in a solution of the
problem. First, observe that Q is always affinely independent: it changes
only by the deletion of single points or by the adjunction of Ps in step I.
Now the line OX is normal to A(Q), since IX[ is minimal there; thus
A(Q) ~_H(X). Since PsCn(s), we know PjCA(Q), so Qw{Ps} is
affinely independent if Q is. Next, there can be no more minor cycles
in a major cycle beginning with a given Q than the dimension of C(Q),
for when Q is a singleton, step 2 returns us to step 1 (indeed, the total
number of minor cycles that have been performed from the beginning
cannot exceed the number of major cycles). Every time step 1 is followed
194 P. Wolfe, Algorithm for a teast-distance programming problern

by the replacement in step 2 (the major cycle has no minor cycle) the
value of I X ] is reduced, since the segment X Y intersects the interior of
C(Q w {Pj}), and IX[ strictly decreases along that segment. For the
same reason, the first minor cycle, if any, of a major cycle also reduces
I X], and subsequent minor cycles cannot increase it. Thus I x I is
reduced in each major cycle. Since X is uniquely determined by the
corral on hand at step l, no corral can enter the algorithm more than
once. Since there is but a finite number of corrals, the algorithm must
terminate, and it can only do so when the problem is solved.
The reader familiar with the Simplex Method for linear programming
will notice its close relationship to our algorithm, particularly in Dant-
zig's description [7, Section 7-3] emphasizing the role of simplices in
visualizing his method.

Pi = (0,2)

P2=(3,o)
Fig. 1.

Example (see Fig. 1). R = (0.923, 1.385) is the nearest point to O on P1P2.
S = (0.353, 0.529) is the intersection of OR and P2P3. T = (0.115, 0.577)
is the answer.
Here are the steps taken, and the results:
Step X Q Y
0 P1 P1
1 P1 P1, P2
2 R do R
1 R P1, P2, P3
2 R do O
3 S P2, P3
2 T do T
1 Stop
P. Wolfe, Algorithm for a least-distanceprogramming problem 195

3. Calculating with affine sets

Affine independence of a set Q of k points is equivalent to the property


that the (n + l)-by-k matrix

has rank k, as well as to the property that the symmetric matrix of


order k + 1

be nonsingular. (To prove the latter, suppose there were /~, u so that
eru=O, e # + Q V Q u = O . Then O = u T ( e # + Q V Q u ) = l Q u l z, so
Q u = 0, whence Q is affinely dependent.) The sets A(Q) and C(Q) then
have dimension k - 1, and C(Q) is a nondegenerate simplex whose
vertices are the points of Q, while all the faces of dimension p of that
simplex are the convex hulls of all the subsets of p + 1 points of Q. Also,
the smallest face of C(Q) containing a given point X in its relative
interior is uniquely defined: its vertices are those points for which the
barycentric coordinate wj of X ~ Q w in Q is positive.
When Q is affinely independent, we can find the projection X of any
point Y on A(Q), that is, solve the problem

minimize I Y - X I 2 = I r - Q u l z,
subject to eTu = l.

The gradient in u of the Lagrangian ~(Y - Q u)T(Y - Q u) + # (eru - 1)


being - Q r Y + QTQ u + e #, we obtain the Lagrangian conditions

eXu = 1
e ~ + Q'rQ u = QTy, (3.2)

which have a unique solution owing to the nonsingularity of their


matrix (3.1). The set Q is a corral when those equations, for Y = 0, have
a solution u > 0.
196 P. Wolfe, Algorithm for a least-distance programming problem

4. Geometry of the tableau

The problem of this paper is:

minimize wr P r P w,
(4.1)
subject to w >- O, eVw = 1.

Introducting the Lagrange multiplier 2, we state the equivalent special


linear complementarity problem of finding w, v > 0 so that

uTw ~ O,
P ~ P w + e). = v, (4.2)
eTw = 1.

These conditions are just the necessary conditions of Kuhn and Tucker
[11] applied to (4.1), and are, of course, also sufficient for this problem.
They have a simple geometric interpretation: Noting that

2 = w % 2 = wry - w T p T p W = -- X T X ,
v = pTx -- e X T X = (P - X eT)rX
(4.3)

(where X = P w), we see that the complementarity condition wTv = 0


requires that each point P~ whose weight w~ is positive satisfy p T x --
X X X = vi = 0, so that Pj lies on the hyperplane H(X); and the condition
v >- 0 requires all points of P to lie on H ( X ) or on its far side.
Now let Q be any affinely independent subset of P, and R be the
remaining points of P, so that P = [Q, R]; and let the vectors e, w, v be
correspondingly partitioned so that (4.2) may be written--in tableau
form---.as

2 w1 wz

o eT 4 I= 1
el QTQ QTR = vl (4.4)
e2 RTQ RTR = v2
P. Wolfe, Algorithm for a least-distance programming problem 197

Let M denote the nonsingular submatrix

QO_J"
The system (4.4) has the simple complementary solution found by
setting wz = 0, vl = 0, and solving for wl and v2; it is exhibited ex-
plicitly by performing a block pivot on M, yielding the tableau (4.5)
below where S = R T R - [e2, R T Q ] M - l [e2, RTQ] v.

- 1, - vl W2

M- 1 m - 1[e2, RTQ]T
(4.5)
-- [e 2, R T Q ] M - 1 S /)2

The system (4.5) is almost, but not quite, that of the "fundamental
problem" of complementary pivot theory [6, 12], but it is easy to see
how to bring it to that by discarding the first row of (4.5), separating
out the first column, and changing signs appropriately to obtain a
system of the form

W2 l) 2

It will be more convenient for us to stay with the equivalent form (4.5).
Let us number the rows and columns of the tableau (4.5) 0, 1, 2. . . . , m,
and denote entry i, j of the tableau by T(i, j). The (variable) set of indices
IQ = { i 1. . . . . ik} ~-- { 1, 2 . . . . . rn} will designate an affinely independent
subset Q = {Pi, . . . . . Pik} of P. With IQ is associated the tableau of the
form (4.5) (except for irrelevant simultaneous permutation of rows and
columns) obtained from the starting tableau (4.4) by pivoting on the
block whose row and column indices are {0, i l , . . . , ik}. The first row and
column are special; once having been pivoted in, they are not used
again for pivot choices.
Each entry of the tableau (4.5) has a geometric meaning for our
problem. We are particularly interested in the left-hand column which
198 P Wolfe, Algorithrn for a least-distance prograrnming probh, rn

gives the values of the basic variables that determine the choice of
pivots, and in the diagonal on which we do all our pivoting. What we
need is covered in the five propositions below.
IR will denote the complement of the index set IQ in the set
{1,2 . . . . . m}.

Proposition I. T(0, 0) = - I X [2, where X = Q w I is the point of smallest


norm on A(Q).

Proof. The relations (3.2), with Y = 0, follow from (4.4) with w e = 0


and vl = 0; and see (4.3).

Proposition 2. For i E IQ, - T(O, i) is the barycentric coordinate of X in Q.


Proof. Immediate--see (4.5).

Proposition 3. For i ~ IR, - T(O, i) is I s [ times the distance of Pi from


H(X), taken positive if. Pi is on the far side of H(X).

Proof. See (4.3, 4.5).

Proposition 4. For i ~ In, T(i, i) is the square of the distance ofPifrom A(Q).

Proof. Let r = Pi~ R. The column M - 111, rrQ] T from the upper right-
hand block of (4.5) is the solution (~, u r) of the equations (2.2) for Y = r,
so that Q u is the nearest point to r on A(Q). N o w (2.2) gives g = uVe la =
uT(QTr _ QTQ u) = rTQ u - t Q ul 2, s o that

T(i, i) = rTr - (1, rTQ) M - 1(1, rTQ) T


rTr -- (1, rTQ) (U, uT)T
rT r - I ~ - rrQu=rTr- 2rTQu+lQul z
Ir-
Proposition 5. For i e IQ, T(i, i) is the reciprocal of the square of the
distance of Pi from A ( Q \ { Pi}.

Proof. Consider the tableau T of the form (4.5) formed for the affinely
independent set Q {P;}. By Proposition 4, T(i, i) is the square of the
distance of Pi from A(Q\{Pi}),and that is not zero. The tableau f is
obtained from T by pivoting on i, i, so that T(i, i) = liT(i, i).
P. Wolfe, Algorithm for a least-distance programming program 199

5. The algorithm in tableau form

We describe the algebra of the algorithm in tableau form, paralleling


the geometric description in Section 2. The notes that follow the algo-
rithm explain the significance of the algebraic steps.
Recall that pivoting on the entry I, J in a tableau T yields the tableau
by these rules:

T(i,j) = T(i,j) - t(I,j) T(i, J ) / T ( I , J) for i # I , j # J ;


?(1,j) = T(I,j)/T(I,J) f o r j ~ J;
T(i,J) = - T(i,J)/T(I,J) for i ~ I;
T(I, J) = l I T ( I , J).

When the tableau is bordered by variables as in (4.4, 4.5), the variables


associated with row I and column J are interchanged, and their signs
are changed. We do only principal pivots here---always I = J - - s o we
always have a complementary basis.

Algorithm
Step O. (a) Form the (m + 1)-by-(m + 1) tableau

To _ [ 0 eT I

e pTp
I

(b) Let i = io minimize To(i, i) for i > 0. Set IQ = {io} and let w be
the vector of length m for which wi = 6Uo.
(c) Pivot in To on (io, io) and then on (0, 0); call the resulting tableau T.
Step 1. (Begins with an index set IQ, an m-vector w, and a tableau T;
IR is the complement of IQ in { 1. . . . . m}.)
(a) If T(0, i) ~ 0 for all i ~ 1~, stop.
(b) Otherwise choose i ~ IR so that T(0, 0 is maximal.
Replace 1Q by IQ u {i}.
Step 2. (Requires the above data, and i from (lb) or (3a).)
(a) Replace T by the result of pivoting in T on {i, i}.
(b) Let y be the m-vector: yj = T(O,j) for j ~ IQ, ys = 0 for j~IR.
(c) If yj > 0 for all j ~ IQ, set w = y and return to step 1. Otherwise,
do step 3.
200 P. Wolfe, Algorithm for a least-distance programming problem

Step 3. (a) Let

0 rain{ w/__
--
Yj
" wj - yj > 0 }
,

and let i be an index for which this minimum is assumed.


(b) Replace w by (1 - 0) w + 0 y.
(c) Replace IQ by I~\{i}.
(d) Go to step 2.

Explanation. Step 0 above is clearly the same as step 0 of Section 2.


Step (la), by Proposition 3 of Section 4, stops the algorithm when no
point of P is on the near side of H(X); otherwise, step (lb) chooses such
a point, and adjoins it to the corral Q.
The index i for step (2a) has been determined either by (lb) or (3a).
In the former case, since T(0, i) ~ 0, we know that Pi r H(X) (Propo-
sition 3), so Pir A(Q), so T(i, i) v~ 0 (Proposition 4); and in the latter case
T(i, i) r 0 also (Proposition 5). Thus the pivot operation may be carried
out. Step (2b) determines the barycentric coordinates y of the point
Y = P y of smallest norm in the affine hull of the new corral Q. If Y is
interior to C(Q), then (2c) sets X to Y and returns to step 1, completing
the major iteration; otherwise it goes to step 3 for minor iterations.
Step (3a) finds the largest value 0 of 0 for which the barycentric
coordinates (1 - O)w + Oy of the point (1 - O)X + 0 Y stay non-
negative, and the index i of a coordinate which vanishes for that value.
Steps (3b, 3c) replace X by Z = (1 - 0) + 0 Y, which lies in the face of
C(Q) opposite Pi, and designate the new Q as Q {Pi }.
The argument that I x J 2 = - T(0,0) decreases monotonically
throughout the procedure, and that the procedure is finite, has been
given in Section 2.

6. S o l u t i o n o f t h e e x a m p l e

We shall solve the example of Section 2, giving the result of taking


each of the steps of the algorithm. The data are

P= 0 "
P. Wolfe, Algorithm Jor a least-distance programming problem 201

Steps Result

0 1 1 1
1 4 0 2
0a
1 0 9 -6
1 2 -6 5

Ob IQ = {1}, w = (1,0,0)

-4 1 -4 -2
1 0 1 I
0c
4 -1 13 -4
2 -1 -4 5

la T(0, IR) = { 4, 2 } ; go on
lb i=2, IQ= {1,2}

- 36 9 4 -42
9 ! - 1 17
2a ~l•
4 - 1 1 - 4
42 - 17 4 49

2b y = (9/13, 4/13, 0)
2c w = (9/13, 4/13, 0)
la T(O, IR) = {42/13}; go on
ib i = 3, IQ= {1,2,3}

0 - 21 28 42
- 21 26 - 9 - 17
2a •
28 - 9 5 4
42 - 17 4 13

2b y = ( - 3/7, 4/7, 6/7)


3a 0 = 21/34, i = 1.
3b w = (0, 8/17, 9/17)
3c IQ = {2, 3}
202 P. Wolfe, Algorithm for a least-distance programming problem

Steps, contd. Result

- 9 21 11 15
-21 49 -9 -17
2a ~6 x
11 9 1 -1
15 17 - 1 1

2b y = (0, 11/26, 15/26)


2c w = (0, 11/26, 15/26)
la T(0, I~) = { - 21/26 }; Stop

Check of solution: eTw = 1.


X = P w = (3/26, 15/26);
min {pTx} = min {30/26, 9/26, 9/26} = 9/26 = IX 12.

7. C o m p u t a t i o n a l notes

A computer routine for a programming problem must guard against


having the decisions it makes in the course of its work led astray by
roundoff error. The crucial decision in the algorithm of Section 5 is at
step (la): the test there might have stopped the algorithm if perfect
arithmetic had been done, but in practice, allow (lb) to choose a point
Pi which is actually dependent on Q; and disaster would ensue. We
mention here the refinements we have incorporated which seem to make
the procedure work well using 16-digit floating-point arithmetic.
Step (1 a). Let
= max { T(0, i)/[ Pi 1: i ~ IR}.
Stopifq~ --
< 10 -1~ ~V, Q wj I P i l 9
Step (lb): Choose i as the index for which max above is assumed.
Step (2b): Normalize the y found; replace it by Y/~iYi.
Step (3b): Replace all components of w less than 10-lo by zero, and
normalize w.
The rule for (la) is based on a simple-minded analysis of roundoff
error in the calculation. It has, at least, the virtue, used with (lb), of
rendering the choices made independent of the scaling of P. One might
also check the size of the pivot entry in step (2a) as a further guard
against the dependence of P~ on Q (or on Q {Pi} in a minor iteration),
but we have not found that necessary.
P. Wolfe, AIgorithmfor a least-distance programming problem 203

We have tested the algorithm on two types of generated problem.


The two tables below give the average number of pivot steps taken to
solve ten problems for various m and n. A type 1 problem is easy: a
point X ~ is chosen at random from a cube of side 4 centered at the
origin, and the m points of P taken at random from the cube of side 2
centered at X ~ (all distributions uniform). The relative ease of the
problem is signalled by the fact that for n = 10 the number of points
in the terminal corral was usually 3 or 4. A type 2 problem consists of m
points, uniformly distributed in the parallelopiped

0.995_<xl < 1.005, -l_<x~_< 1 for j = 2 . . . . . n.

Such a problem is quite hard, as Table 1 shows. The number of points


in the terminal corral was always very close to the smaller of m and n.

Table 1
Average number of pivot steps

Type 1 Type 2
n m 20 40 20 40

10 1.4 3.1 14.7 28.0


20 3.3 4.3 14.2 34.5
30 4.3 4.1 14.3 30.0

We must mention that the algorithm of this paper, with the calcula-
tions performed in a tableau, is probably efficient in arithmetic only for
problems in which the number m of points is not much greater than the
dimension n of the space in which they reside. Almost all of the cal-
culating is done in the pivot step, which requires O(rn 2) multiplications.
When m :~- n, a different organization of the calculation [22], related
to the present method as the revised simplex method for linear program-
ming is to the standard form, is much better; it requires O(m n) multi-
plications for a step, can take advantage of sparsity of the matrix P,
and gives better control over roundoff error.
The preceding paragraph explains why we have not much inves-
tigated the use of the tableau algorithm in practice. Doing so would
involve at least comparing its behavior on a variety of problems with
that of other tableau procedures for quadratic programming, such as
those of Cottle and Dantzig [5] and Lemke [12], which we have not
204 P. Wolfe, Algorithm for a least-distance programming problem

done. We have, though, tried their procedures on the problem of Sec-


tion 2 and another.
Counting steps from the tableau 0c of Section 6, our procedure ("T")
and the Cottle-Dantzig ("CD") took the same first step, then different
second and third steps to solve the problem. The Lemk~ procedure ("L")
requires a special first step (pivoting on 2, 5 after augmenting the tableau
by the column e), and then solves the problem in three steps (by reducing
to zero the variable associated with the added column).
Next we carefully adjoined the point ( - 2 , 3) to the three points of the
problem and reran the methods. (The tableau 0c becomes bordered by
2, 1, - 8, 3 on the right and - 2, - 1, - 8, 3, 5 below.) The choices made
by T and L were unchanged, so they required, respectively, three and
four steps. CD, however, took five steps, because it had to maintain the
nonnegativity of the new variable v4, while L was unaffected and T
ignored its change of sign. This suggests to us that T would usually
require fewer steps than CD: We have observed in linear programming
problems that one should make no effort to prevent reduced costs from
changing sign, but concentrate on reducing the objective; and procedure
T adheres to that view.

References

[1] E.W. Barankin and R. Dorfman, "Toward quadratic programming", Rept. to the
Logistics Branch, Office of Naval Research (January, 1955), unpublished.
[2] E.W. Barankin and R. Dorfman, "On quadratic programming", University of
California Publications in Statistics 2 (1958) 285 318.
[3] E.M.L. Beale, "Numerical methods", Parts ii-iv, in: Nonlinear programmin9,
Ed. J. Abadie (North-Holland, Amsterdam, 1967)pp. 143-172.
[4] M.D. Canon and C.D. Cullum, "The determination of optimum separating hyper-
plans I. A finite step procedure", RC 2023, IBM Watson Research Center, Yorktown
Heights, N.Y. (February, 1968).
[5] R.W. Cottle, "The principal pivoting method of quadratic programming", in:
Mathematics of the decision sciences, Part I, Vol. 11 of Lectures in Applied Ma-
thematics, Eds. G.B. Dantzig and A.F. Veinott (A.M.S., Providence, R.I., 1968)
pp. 144-162.
[6] R.W. Cottle and G.B. Dantzig, "Complementary pivot theory", in: Mathematics
of the decision sciences, Part I, Vol. 11 of Lectures in Applied Mathematics, Eds.
G.B. Dantzig and A.F. Veinott (A.M.S., Providence, R.I., 1968) pp. 115-136.
[7] G.B. Dantzig, Linear programmin9 and extensions (Princeton University Press,
Princeton, N.J., 1963).
[8] G.B. Dantzig and A.F. Veinott, Eds., Mathematics of the decision sciences, Part I,
Vol. 11 of Lectures in Applied Mathematics (A.M.S., Providence, R.I., 1968).
P. Wolfe, Algorithm for a least-distance programming problem 205

[9] R. Fletcher, "A general quadratic programming algorithm", T.P. 401, Theoretical
Physics Div., U.K.A.E.A. Research Group, A.E.R.E., Harwell (March, 1970).
[10] M. Frank and P. Wolfe, "An algorithm for quadratic programming", Naval Research
Logistics Quarterly 3 (1956) 95-110.
[I 1] H.W. Kuhn and A.W. Tucker, "Nonlinear programming", in: Proceedings of the
second Bereketey symposium on mathematical statistics and probability, Ed. J. Neyman
(University of California Press, Berkeley, Calif., 1951) pp. 481-492.
[12] C.E. Lemke, "On complementary pivot theory" in: Mathematics of the decision
sciences, Part I, Vol. I I of Lectures in Applied Mathematics, Eds. G.B. Dantzig
and A.F. Veinott (A.M.S. Providence, R.I., 1968) pp. 95-114.
[13] T.D. Parsons and A.W. Tucker, "Hybrid programs: linear and least-distance",
Mathematical Programming 1 (1971) 153-167.
[14] A.W. Tucker, "Analogues of KircholTs laws", Preprint LOGS 65, Stanford Uni-
versity Stanford, Calif. (July 19.50).
[15] A.W. Tucker, "On Kirchoff's laws, potential, Lagrange multipliers, etc.", NAML
Rept. 52-17, National Bureau of Standards, Institute for Numcrical Analysis,
University of California, Los Angeles, Calif. (August, 1951).
[16] A.W. Tucker, "Combinatorial theory underlying linear programs", in: Recent
advances in mathematical programming, Eds. R.L. Graves and P. Wolfe (McGraw-
Hill, New York, 1963) pp. 1-16.
[17] A.W. Tucker, "Principal pivot transforms of square matrices", SIAM Review 5
(1963) 305.
[18] A.W. Tucker, "A least-distance approach to quadratic programming", in: Mathe-
matics of the decision sciences, Part I, Vol. 11 of Lectures in Applied Mathematics,
Eds. G.B. Dantzig and A.F. Veinott (A.M.S., Providence, R.I., 1968)pp. 163-176.
[19] A.W. Tucker, "Least-distance programming", in: Proceedings of the Princeton
symposium on mathematical programming, Ed. H.W. Kuhn (Princeton University
Press, Princeton, N. J., 1971) pp. 583-588.
[20] P. Wolfe, "A simplex method for quadratic programming", ONR Logistics Project
Report., Princeton University, Princeton, N. J. (February 1957).
[21J P. Wolfe, "The simplex method for quadratic programming", Econometrica 27
(1959) 382 393.
[22] P. Wolfe, "Finding the nearest point in a polytope", RC 4887, IBM Research
Center, Yorktown Heights, N.Y. (June, 1974).

You might also like