ECE 236B Course Notes
ECE 236B Course Notes
Convex Optimization
                                Note
                             Patricia Xiao (Zhiping)
Winter 2019
Contents
1 Introduction                                                                         6
  1.1   Mathematical Optimization . . . . . . . . . . . . . . . . . . . . . . .         6
  1.2   Least Square and Linear Programming . . . . . . . . . . . . . . . . .           6
  1.3   Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .     6
  1.4   Nonlinear Optimization (Non-Linear Programming) . . . . . . . . . .            7
  1.5   A Brief History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .     7
2 Math Basis                                                                           7
  2.1   Numerical linear algebra background . . . . . . . . . . . . . . . . . .         7
        2.1.1   Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . .    7
        2.1.2   Matrix structure and algorithm complexity . . . . . . . . . . .        7
        2.1.3   Solving linear equations with factored matrices . . . . . . . . .       8
        2.1.4   LU factorization . . . . . . . . . . . . . . . . . . . . . . . . . .   10
        2.1.5   sparse LU factorization . . . . . . . . . . . . . . . . . . . . . .    10
        2.1.6   Cholesky factorization . . . . . . . . . . . . . . . . . . . . . .     10
        2.1.7   sparse Cholesky factorization . . . . . . . . . . . . . . . . . .      10
        2.1.8   LDLT factorization . . . . . . . . . . . . . . . . . . . . . . . .     10
        2.1.9   Equations with structured sub-blocks . . . . . . . . . . . . . .       11
        2.1.10 Structured matrix with low-rank term . . . . . . . . . . . . .          11
  2.2   Linear Algebra . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .     12
        2.2.1   Dimension & Rank and Determinants . . . . . . . . . . . . . .          12
                                           1
        2.2.2   Norm    . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   12
        2.2.3   Dual Norm . . . . . . . . . . . . . . . . . . . . . . . . . . . .       12
        2.2.4   Null Space (a.k.a. Kernel), Range (a.k.a. Image)        . . . . . . .   12
        2.2.5   Pseudo-Inverse . . . . . . . . . . . . . . . . . . . . . . . . . .      13
        2.2.6   Vectorization . . . . . . . . . . . . . . . . . . . . . . . . . . .     13
        2.2.7   Singular Matrix . . . . . . . . . . . . . . . . . . . . . . . . . .     14
        2.2.8   More on Determinant . . . . . . . . . . . . . . . . . . . . . . .       14
        2.2.9   Matrix Trace . . . . . . . . . . . . . . . . . . . . . . . . . . .      14
        2.2.10 Eigen Decomposition . . . . . . . . . . . . . . . . . . . . . . .        15
        2.2.11 Positive Semi-Definite Matrix . . . . . . . . . . . . . . . . . .        15
        2.2.12 Positive Definite Matrix . . . . . . . . . . . . . . . . . . . . .       16
        2.2.13 Schur complement . . . . . . . . . . . . . . . . . . . . . . . .         16
  2.3   Calculus and Analysis . . . . . . . . . . . . . . . . . . . . . . . . . .       16
        2.3.1   Differentiate . . . . . . . . . . . . . . . . . . . . . . . . . . . .   16
        2.3.2   Conjugation . . . . . . . . . . . . . . . . . . . . . . . . . . . .     17
        2.3.3   Complex Conjugate . . . . . . . . . . . . . . . . . . . . . . . .       17
3 Course Concepts                                                                       17
  3.1   Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .    17
        3.1.1   Mathematical Optimization and Convex Optimization             . . . .   17
        3.1.2   Least Square and Linear Programming . . . . . . . . . . . . .           18
  3.2   Convex Set . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .      19
        3.2.1   Empty Set . . . . . . . . . . . . . . . . . . . . . . . . . . . . .     19
        3.2.2   Affine Sets and Convex Sets . . . . . . . . . . . . . . . . . . .       19
        3.2.3   Convex Combination and Convex Hull . . . . . . . . . . . . .            20
        3.2.4   Conic combination and Convex Cone . . . . . . . . . . . . . .           20
        3.2.5   Hyperplane and Halfspace (example 1 of convex set)          . . . . .   20
        3.2.6   Euclidean Balls and Ellipsoids (example 2 of convex set) . . .          21
        3.2.7   Norm Balls and Norm Cones (example 3 of convex set) . . . .             21
        3.2.8   Polyhedra (a.k.a. Polytopes) (example 4 of convex set) . . . .          22
        3.2.9   Positive Semidefinite Cone (example 5 of convex set) . . . . .          22
        3.2.10 Operations that Preserve Convexity . . . . . . . . . . . . . . .         23
        3.2.11 Generalized Inequalities . . . . . . . . . . . . . . . . . . . . .       24
        3.2.12 Minimum and Minimal elements of Generalized Inequality . .               25
                                            2
      3.2.13 Separating Hyperplanes and Supporting Hyperplanes . . . . .              26
      3.2.14 Dual Cones and Generalized Inequalities . . . . . . . . . . . .          26
      3.2.15 Minimum and Minimal Elements via Dual Inequalities . . . .               27
3.3   Convex Function . . . . . . . . . . . . . . . . . . . . . . . . . . . . .       27
      3.3.1   Definition . . . . . . . . . . . . . . . . . . . . . . . . . . . . .    27
      3.3.2   Convex and Concave Examples . . . . . . . . . . . . . . . . .           28
      3.3.3   Trick 1: Restriction of a convex function to a line . . . . . . .       28
      3.3.4   Trick 2: Extended-value extension . . . . . . . . . . . . . . . .       29
      3.3.5   Trick 3.1: First-Order Condition . . . . . . . . . . . . . . . . .      29
      3.3.6   Trick 3.2: Second-Order Conditions . . . . . . . . . . . . . . .        30
      3.3.7   Epigraph and Sublevel Set . . . . . . . . . . . . . . . . . . . .       31
      3.3.8   Jensen’s Inequality . . . . . . . . . . . . . . . . . . . . . . . .     32
      3.3.9   Brief Summary: How to prove convexity? . . . . . . . . . . . .          32
      3.3.10 Operations that Preserve Convexity . . . . . . . . . . . . . . .         32
      3.3.11 The Conjugate Function . . . . . . . . . . . . . . . . . . . . .         36
      3.3.12 Quasiconvex Functions (1/3 Generalization) . . . . . . . . . .           36
      3.3.13 Log-concave and Log-convex Functions (2/3 Generalization) .              38
      3.3.14 Convexity with respect to Generalized Inequalities (3/3 Gener-
             alization) . . . . . . . . . . . . . . . . . . . . . . . . . . . . .     40
3.4   Convex Optimization Problems . . . . . . . . . . . . . . . . . . . . .          40
      3.4.1   Optimization Problem in Standard Form . . . . . . . . . . . .           40
      3.4.2   Convex Optimization Problems . . . . . . . . . . . . . . . . .          42
      3.4.3   Quasiconvex Optimization . . . . . . . . . . . . . . . . . . . .        45
      3.4.4   Linear Optimization (LP) . . . . . . . . . . . . . . . . . . . .        46
      3.4.5   Quadratic Optimization (QP, SOCP, QCQP)             . . . . . . . . .   48
      3.4.6   Geometric Programming (GP) . . . . . . . . . . . . . . . . . .          50
      3.4.7   Generalized Inequality Constraints . . . . . . . . . . . . . . .        52
      3.4.8   Semidefinite Program (SDP) . . . . . . . . . . . . . . . . . . .        52
      3.4.9   Vector Optimization . . . . . . . . . . . . . . . . . . . . . . .       54
3.5   Duality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .   56
      3.5.1   Lagrangian . . . . . . . . . . . . . . . . . . . . . . . . . . . .      56
      3.5.2   Lagrange dual function . . . . . . . . . . . . . . . . . . . . . .      56
      3.5.3   Lagrange dual and Conjugate Function . . . . . . . . . . . . .          57
      3.5.4   (Lagrange) dual problem . . . . . . . . . . . . . . . . . . . . .       58
                                          3
      3.5.5   Weak and strong duality . . . . . . . . . . . . . . . . . . . . .      58
      3.5.6   Slater’s Constraint Qualifications . . . . . . . . . . . . . . . .     58
      3.5.7   Geometric interpretation . . . . . . . . . . . . . . . . . . . . .     60
      3.5.8   Optimality Conditions: Complementary Slackness . . . . . . .           60
      3.5.9   Optimality Conditions: Karush-Kuhn-Tucker (KKT) Conditions 60
      3.5.10 Perturbation and sensitivity analysis . . . . . . . . . . . . . .       61
      3.5.11 Generalized inequalities . . . . . . . . . . . . . . . . . . . . .      62
3.6   Approximation and fitting . . . . . . . . . . . . . . . . . . . . . . . .      63
      3.6.1   Norm approximation . . . . . . . . . . . . . . . . . . . . . . .       63
      3.6.2   Least-norm problems . . . . . . . . . . . . . . . . . . . . . . .      65
      3.6.3   Regularized approximation . . . . . . . . . . . . . . . . . . . .      66
      3.6.4   Robust approximation . . . . . . . . . . . . . . . . . . . . . .       66
3.7   Statistical estimation . . . . . . . . . . . . . . . . . . . . . . . . . . .   67
      3.7.1   Maximum likelihood estimation (MLE) . . . . . . . . . . . . .          67
      3.7.2   Optimal detector design . . . . . . . . . . . . . . . . . . . . .      67
      3.7.3   Experiment design . . . . . . . . . . . . . . . . . . . . . . . .      67
3.8   Geometric problems . . . . . . . . . . . . . . . . . . . . . . . . . . . .     68
      3.8.1   Extremal volume ellipsoids . . . . . . . . . . . . . . . . . . . .     68
      3.8.2   Centering . . . . . . . . . . . . . . . . . . . . . . . . . . . . .    69
      3.8.3   Classification . . . . . . . . . . . . . . . . . . . . . . . . . . .   69
3.9   Unconstrained minimization . . . . . . . . . . . . . . . . . . . . . . .       70
      3.9.1   Terminology and assumptions . . . . . . . . . . . . . . . . . .        70
      3.9.2   Gradient descent method . . . . . . . . . . . . . . . . . . . . .      71
      3.9.3   Steepest descent method . . . . . . . . . . . . . . . . . . . . .      71
      3.9.4   Newton’s method gradient . . . . . . . . . . . . . . . . . . . .       72
      3.9.5   Newton decrement . . . . . . . . . . . . . . . . . . . . . . . .       73
      3.9.6   Newton’s method . . . . . . . . . . . . . . . . . . . . . . . . .      73
      3.9.7   Classical Convergence Analysis for Newton method . . . . . .           74
      3.9.8   Newton Method and Cholesky factorization . . . . . . . . . .           75
3.10 Equality constrained minimization . . . . . . . . . . . . . . . . . . . .       75
      3.10.1 Eliminating equality constraints . . . . . . . . . . . . . . . . .      76
      3.10.2 Newton’s method with equality constraints . . . . . . . . . . .         76
      3.10.3 Infeasible start Newton method . . . . . . . . . . . . . . . . .        77
      3.10.4 Implementation of the Newton Method . . . . . . . . . . . . .           78
                                         4
  3.11 Interior-point methods . . . . . . . . . . . . . . . . . . . . . . . . . .       79
        3.11.1 Inequality constrained minimization . . . . . . . . . . . . . . .        79
        3.11.2 Logarithmic barrier function and central path . . . . . . . . .          79
        3.11.3 Barrier method . . . . . . . . . . . . . . . . . . . . . . . . . .       81
        3.11.4 Feasibility and phase I methods . . . . . . . . . . . . . . . . .        82
        3.11.5 Complexity analysis via self-concordance . . . . . . . . . . . .         82
        3.11.6 Generalized inequalities . . . . . . . . . . . . . . . . . . . . .       82
        3.11.7 Primal-dual interior-point methods . . . . . . . . . . . . . . .         85
                                            5
1     Introduction
What makes learning Convex Optimization useful?
This course also includes code implementation, a package called cvx in matlab,
equivalent package called cvxpy in Python (https://www.cvxpy.org/). Some useful
examples on https://www.cvxpy.org/examples/index.html. Such as the basic
functions at https://www.cvxpy.org/tutorial/functions/index.html.
Stanford online course (https://lagunita.stanford.edu/courses/Engineering/
CVX101/Winter2014/course/) is also pretty helpful.
1.3    Examples
Lamp-illuminating problem, optimizing the mini-max percentage error; constraint
the range (of the light power) between 0 and max; with regularization towards (max
/ 2).
Constraints might look the same but totally different. Untrained intuitions are not
reliable.
It is important to get trained and find “the correct thing to estimate” properly.
In this course, not to replicate, but to demystify.
                                         6
1.4         Nonlinear Optimization (Non-Linear Programming)
Traditional method of non-convex problems.
Back then (50’s, 60’s etc.) scientists are categorizing problems as, LP (Linear
Programming), NLP (Non-Linear Programming), ILP (I for integer), etc.
For Non-Linear Programming, localized solution starts from an initial guess and go
gradient descent, global solution could be exponential time in the worst case. Almost
every global optimization is based on convex optimization as a subroutine.
2         Math Basis
2.1         Numerical linear algebra background
2.1.1        Introduction
                                                    7
Vector operations with x, y ∈ Rn :
• sum x + y: n flops
• m(2n − 1) flops
• mp(2n − 1) flops
• less if A or B is sparse
• mn2 flops if m ≥ n
• m2 n flops if n ≥ m
   • After solving one value of λ, cost of solving k other λ value versions is:n2 k when
     m ≥ n, m2 k when n ≥ m
The performance could be also greatly influenced by the order you compute them.
                                                8
   • lower triangular matrix (when i < j, aij = 0): n2 flops
                      x1 = b1 /a11
                      x2 = (b2 − a21 x1 )/a22
                      x3 = (b3 − a31 x1 − a32 x2 )/a33
                         ...
                      xn = (bn − an1 x1 − an2 x2 − · · · − an,n−1 xn−1 )/ann
     The flop count for computing A−1 b is the same order as the flop count for
     computing Ab.
   • upper triangular matrix (when i > j, aij = 0): n2 flops, similar with the
     lower triangular one
Ax = (xπ1 , . . . , xπn )
costs 0 flops.
  1. Factor A into simple matrices mentioned before (those kinds above, usually
     k = 2 or 3):
                                  A = A1 A2 . . . Ak
2. Solving A1 x1 = b, A2 x2 = x1 , . . . , Ak xk = xk−1
  3. Now we have:
                                    x = A−1 b = Ak Ak−1 . . . A1 b
Axi = bi , i = 1, 2, . . . , m
                                                9
2.1.4   LU factorization
                                    A = P1 LU P2
Another permutation matrix P2 makes it possible (heuristic) for L, U being sparse.
Cost is usually less that (2/3)n3 , but the exact value depends, and is really complex.
                                    P1T AP2T = LU
                                    A = P LLT P T
with permutation matrix P that makes L hopefully sparse (heuristic). Complexity
is usually less that (1/3)n3 , depends only on the sparsity features of A, but still
complex.
                                    P T AP = LLT
                                          10
2.1.9    Equations with structured sub-blocks
The first topic under Block elimination and the matrix inversion lemma.
                                        
                               A11 A12 x1      b
                                            = 1
                               A21 A22 x2      b2
with xi ∈ Rni , Ai,j ∈ Rni ×nj .
If A11 is nonsingular:
                         x1 = A−1
                                11 (b1 − A12 x2 )
                         (A22 − A21 A−1                       −1
                                       11 A12 )x2 = b2 − A21 A11 b1
is computed.
Cost of computing the Schur complement is:
                                      f + n2 s + n22 n1
if simply compute the Schur complement of A11 .
The total cost is:
                            f + n2 s + 2n22 n1 + (2/3)n32
where f is the factorization cost, s is the cost of solving the actual problem.
The first topic under Block elimination and the matrix inversion lemma.
                                      (A + BC)x = b
            n×n
with A ∈ R      and structured, B ∈ Rn×p , C ∈ Rp×n . B, C low-rank.
                                          
                                   A B     x     b
                                              =
                                   C −I y        0
y is introduced, called in-elimination.
Thus we have:
                               (I + CA−1 B)y = CA−1 b
                               Ax = b − By
this proves the block-inversion lemma: with A and A + BC nonsingular,
                            (A + BC)−1
                           =A−1 − A−1 B(I + CA−1 B)−1 CA−1
A beautiful example: A diagonal and B, C dense: with this block method its cost
is as low as:
                            2p2 n + (2/3)p3 ≈ 2p2 n
                                             11
2.2      Linear Algebra
2.2.1      Dimension & Rank and Determinants
Refer to http://www.math.drexel.edu/~jwd25/LA_FALL_06/lectures/lecture4B.
html.
2.2.2      Norm
               Pn
   • kxk1 =       i=1   xi for x ∈ Rn
A trick:
                                 kxk − AT x ≥ 0 =⇒ kAk∗ ≤ 1
                              inf kxk + AT x =⇒ 0 (kAk∗ ≤ 1)
                                             
                               x
Null space:
Given:
• Linear transformation on Rn : T
T (X) = 0
• QR factorization
                                              12
Range: sometimes also called “image” and expressed as Im(A) etc.
R(A) = {Ax|x ∈ Rn }
                                         dim N (A) = n − r
                            dim R(A)⊥ = dim N (AT ) = m − r
                                  x ∈ N (A)⊥ =⇒ Ax ∈ R(A)
                     R(A)⊥ ⇐⇒ N (AT )                     N (A)⊥ ⇐⇒ R(AT )
                   x1 ∈ R(AT ) = N (A)⊥ , x2 ∈ A =⇒ x1 x2 ∈ R(A)
                             x1 ∈ N (A), x2 ∈ A =⇒ x1 x2 ∈ {0}
Besides we have:
Could view this problem in such a way that: thinking about 3D space, x, y-plane’s
Null Space is those who parallel with the z-axis, etc.
Could refer to mathworld at http://mathworld.wolfram.com/NullSpace.html and
https://math.stackexchange.com/questions/2037602/what-is-range-of-a-matrix.
2.2.5 Pseudo-Inverse
A† = AT (AAT )−1
A† = (AT A)−1 AT
2.2.6 Vectorization
                                                     13
2.2.7   Singular Matrix
It is calculated via:                     n
                                          X
                               det(A) =         aij (−1)i+j A−(i,j)
                                          i=1
                        det(A) = det(AT )
                        det(aA) = an det(A)
                        det(AB) = det(A) det(B)
                        det(I) = det(AA−1 ) = det(A) det(A−1 ) = 1
                                     1
                        det(A) =
                                  det(A−1 )
                        det(BAB −1 ) = det(A)
                        det(B −1 AB − λI) = det(A − λI)
                        det(A) = det(A)
                        det(A + I) = 1 +  det(A) + O(2 )
where a refers to complex conjugate of a (no matter a number or matrix).
Could refer to mathworld at http://mathworld.wolfram.com/Determinant.html.
• tr(A) = tr(AT )
                                                14
   • tr(αA) = α tr(A)
   • tr(BAB −1 ) = tr(A)
   • tr(AB) = tr(BA)
Useful Property 0:
Inner product of two symmetric matrices is the trace of the product:
                         (
                          A ∈ Sn
                                     =⇒ AB = tr(AB)
                          B ∈ Sn
Useful Property 1:
                                          X
                 tr(X T Y ) = tr(XY ) =         Xij Yij = vec(X)T vec(Y )
                                          i,j
Useful Property 2:
                                   ∇X tr(AX) = A
Could refer to mathworld at http://mathworld.wolfram.com/MatrixTrace.html.
                     X ∈ Sn+ , ∀y ∈ Rn , y T Xy ≥ 0 ⇐⇒ X  0
Basically:
Besides, when:
                         n=1            X11 ≥ 0
                                                   2
                         n = 2 Xii ≥ 0, X11 X22 − X12 ≥0
And iterative, for n + 1 size, the conditions for size n still hold, by emitting any one
row & any one column. That is, their submatr
                                            15
2.2.12    Positive Definite Matrix
                                          16
    • If f (x) = g(x)h(x):
                                    f 0 (x) = g 0 (x)h(x) + g(x)h0 (x)
    • If f (x) = h(g(x)):
                                         f 0 (x) = g 0 (x)h0 (g(x))
                              f 00 (x) = g 0 (x)2 h00 (g(x)) + h0 (g(x))g 00 (x)
2.3.2 Conjugation
                                         φx (g) = xgx−1
                                     φx (g)φx (h) = φx (gh)
z = a − bi
3 Course Concepts
3.1      Introduction
3.1.1    Mathematical Optimization and Convex Optimization
Optimization Problem:
                             minimize f0 (x)
                            subject to fi (x) ≤ bi (i = 1, 2, . . . , m)
where:
• x∗ optimal solution
                                                 17
Convex Optimization Problem:
                               minimize f0 (x)
                              subject to fi (x) ≤ bi (i = 1, 2, . . . , m)
where:
   • Convexity:
                                      fi (αx + βy) ≤ αfi (x) + βfi (y)
        with α + β = 1, α ≥ 0, β ≥ 0.
        “The cord lies above the graph”.
• Almost a technology
   • Many problem could be transformed into a convex form (though might be hard
     to recognize), and solve via convex optimization.
Least square:
                                       minimize kAx − bk22
where A ∈ Rk×n , x ∈ Rn , b ∈ Rk .
                                                  18
   • Time complexity n2 k in the worst case
                           minimize cT x
                          subject to aTi x ≤ bi , i = 1, 2, . . . , m
where x, c, ai ∈ Rn , b ∈ Rm .
• Time complexity n2 m if m ≥ n
Affine Set:
Line through x1 , x2 : x = θx1 + (1 − θ)x2 where θ ∈ R.
The affine set is the set that contains the line through any two distinct points in
the set.
The solution set of linear equations, {x|Ax − b = 0} is an affine set, and, conversely,
any affine set could be expressed as solution set of set of linear equations.
Convex Set:
Same idea as affine set except that instead of line, we talk about line segment.
Line segment through x1 , x2 : x = θx1 + (1 − θ)x2 where θ ∈ [0, 1].
Convex set contains the line segment through any two distinct points in the set.
        “any point in the set can see any other point in the set, through a clear
        line of sight path in between”
                                              19
3.2.3       Convex Combination and Convex Hull
The shape looks like: a normal to the hyperplane is a, and then x is pointing to
“right-hand side” along the boundary. When b is changed, the hyperplane moves up
and down, parallel.
The distance between two parallel line with parameter b1 and b2 respectively, is
|b1 −b2 |
  kak2
Halfspace: Convex!
{x|aT x ≤ b} (a 6= 0)
The half of the space that a is pointing to is aT x > b, the half where −a will point
to is aT x < b. Boundary is the hyperplane. a is an outward normal.
                                              20
3.2.6   Euclidean Balls and Ellipsoids (example 2 of convex set)
                              B(xc , r) = {x | kx − xc k2 ≤ r}
                                        = {xc + ru | kuk2 ≤ 1}
where u is a vector of norm with length less than or equal to 1.
Euclidean refers to the `2 norm.
Ellipsoid: a generalization of ball.
                         {x | k(x − xc )T P −1 (x − xc )k2 ≤ 1}
                        ={xc + Au | kuk2 ≤ 1}
with P ∈ Sn++ , symmetric positive definite. A: Non-square and Non-singular (linear
transformation A of a ball plus the offset xc ).
The semiaxes of the ellipsoid are given by the eigenvectors of P . The semiaxis lengths
are the square roots of the eigenvalues of P .
When P = r2 I it is a ball.
The representation of P is unique, that is to say, when two sets are equal the P has
to be the same.
But the representation of A is not unique, multiple As might give the same set. For
example, if Q is orthogonal, which means that QT Q = I, then A could be replaced
by AQ.
Norm: k·k, nothing but a function, just like absolute value in multiple dimensions.
• Positive Definiteness:
        – Positive: kxk ≥ 0
        – Definiteness: kxk = 0 ⇐⇒ x = 0
                                             21
   • kxk∞ = maxni=1 |xi |
{x | kx − xc k ≤ r}
Convex.
Norm Cone:
{(x, t) | kxk ≤ t}
Convex.
Euclidean Norm Cone (Second-Order Cone):
{(x, t) | kxk2 ≤ t}
Ax b, Cx = d
A ∈ Rm×n , C ∈ Rp×n , x ∈ Rn , b ∈ Rm , d ∈ Rp .
It is the intersection of finite number of halfspaces and hyperplanes. Defined by each
row of A or C.
 in this 1-D case is equivalent with componentwise inequality.
                                            22
    3.2.10    Operations that Preserve Convexity
                                                 23
            – Hyperbolic cone:
                                    {x | xT P x ≤ (cT x)2 , cT x ≥ 0}
              with P ∈ Sn+ . It is an inverse image of a standard cone under an
              affine function.
   • Perspective (a.k.a. projective mapping) functions P : Rn+1 → Rn
                         P (x, t) = x/t,          dom P = {(x, t)|t > 0}
     basically, it is dividing the first n element with the last one.
     Images and inverse images under perspective are convex.
   • Linear-fractional functions f : Rn → Rm
                                Ax + b
                      f (x) =            ,    dom f = {x | cT x + d > 0}
                                cT x + d
     It is just like the image put into your camera or your retina.
     Images and inverse images under linear-fractional functions are
     convex.
     A quick example:
                                                       x
                                        f (x) =
                                                  x1 + x2 + 1
     where x ∈ R2 .
                                 x K y ⇐⇒ y − x ∈ K
                                x ≺K y ⇐⇒ y − x ∈ int K
int here refers to interior, that is the inner part, not the boundary.
Some way-too-common (so that we drop the K when expressing) examples:
                                             24
   • K = R+ (not really generalized, just the basis, used for comparison):
x K y ⇐⇒ y − x ∈ K
                               x R+ y ⇐⇒ y − x ∈ R+
                                 x ≤ y ⇐⇒ y − x ≥ 0
   • K = Rn+ :
                                x K y ⇐⇒ y − x ∈ K
                               x Rn+ y ⇐⇒ y − x ∈ Rn+
                         x  y ⇐⇒ yi − xi ≥ 0 (i = 1, 2, . . . n)
   • K = Sn+ :
                                x K y ⇐⇒ y − x ∈ K
                               x Sn+ y ⇐⇒ y − x ∈ Sn+
                         x  y ⇐⇒ y − x positive semidefinite
• x K y, a b =⇒ (x + a) (y + b)
Minimum Element:
x ∈ S is the minimum element of S with respect to K if:
y ∈ S =⇒ x K y
Minimal Element:
x ∈ S is a minimal element of S with respect to K if:
y ∈ S, y x =⇒ y = x
                                        25
3.2.13    Separating Hyperplanes and Supporting Hyperplanes
                             K ∗ = {y | y T x ≥ 0, ∀x ∈ K}
Some examples:
                                  K                 K∗
                                  R∗+               R∗+
                                  S∗+               S∗+
                          {(x, t)|kxk2 ≤ t} {(x, t)|kxk2 ≤ t}
                          {(x, t)|kxk1 ≤ t} {(x, t)|kxk∞ ≤ t}
The dual cone, geographically, is: starting from the boundary, the “original point”
(o) of the set, draw a hyperplane, with norm y, if the set is fully included in the
halfspace where y points to, then y ∈ K ∗ .
If K is thin, then K ∗ is thick. Normally, if K is “90 degrees”, then it is self-dual. Also
normally, (K ∗ )∗ is K. For example, x ∈ R, then for K = {(x, t)||x| ≤ t}, K ∗ = K.
                                            26
3.2.15     Minimum and Minimal Elements via Dual Inequalities
That is, geographically, all points where, from that point, the line segments (in right
angle) to any of the axis, doesn’t have intersection with the rest of the set.
Optimal Production Frontier
Different production methods use different amount of resources x ∈ Rn .
P : The production set. Resource vector x for all possible production methods.
Efficient (Pareto optimal) methods correspond to resource vectors x that are
minimal w.r.t. Rn+ .
f : Rn → R is convex iff:
   • The line segment in the graph space (from x to y) is sometimes called chord.
     An old way of talking about convexity is saying that f is below its chord.
                                            27
3.3.2     Convex and Concave Examples
Some examples on R we have for convex and concave (in respect to x):
with f : Rn → R, g : R → R.
It is also true statement for concave cases.
If, for any choice of x and v, g is always convex (/concave) in t, then f
must be convex (/concave) as well.
                                           28
It is useful in high dimensions when n is large, and you can check the convexity of f
by checking convexity of a line. If you can find a sample that does not hold, then it
is definitely not convex.
An example: dom f = Sn++ , f : Sn → R, and it is the log-determinant:
                                       f (X) = log det X
We could have:
                     g(t) = log det(X + tV )
                                                                 
                                      1/2     −1/2    −1/2    1/2
                          = log det X (I + tX      VX      )X
                          = log det(X) + log det(I + tX −1/2 V X −1/2 )
                                         Xn
                          = log det(X) +    (1 + tλi )
                                             i=1
This extension often simplifies the notation. Most of the operations on infinity work
out fine.
f is differentiable iff:
   • dom f is open (end-points not included)
   • There exists ∇f (x) at each x ∈ dom f such that:
                                            ∂f (x) ∂f (x)       ∂f (x)
                               ∇f (x) = (         ,       ,...,        )
                                             ∂x1    ∂x2          ∂xn
The first-order condition refers to that:
                                               29
3.3.6      Trick 3.2: Second-Order Conditions
                                                                 ∂ 2 f (x)
                                                  ∇2 f (x)ij =
                                                                 ∂xi ∂xj
        for i, j = 1, 2, . . . , n.
∇2 f (x) 0
Some examples:
                                                          30
We need to prove that, ∀v:
                               ( k zk vk2 )( k zk ) − ( k zk vk )2
                                P           P          P
                 T      2
                v (∇ f (x))v =               P                     ≥0
                                            ( k zk )2
So it always holds.
And the proof of that the geometric mean is concave is alike.
The log-sum-exp is very important because:
Cα = {x ∈ dom f | f (x) ≤ α}
epigraph of f : Rn → R:
If you have a convex function, the sublevel sets are all convex. But if you have a
convex sublevel set, you can’t say for sure whether or not the function is convex.
                                             31
3.3.8     Jensen’s Inequality
                                              32
3. Pointwise maximum and pointwise supremum:
  Pointwise maximum: if f1 , . . . , fm are convex, then:
  is convex.
  Examples:
  is convex.
  Examples:
                                     SC (x) = sup y T x
                                                  y∈C
                                    f (x) = supkx − yk
                                              y∈C
                                       33
4. Composition with scalar functions:
  f is the composition of g : Rn → R and h : R → R:
f (x) = h(g(x))
  f is convex if:        (
                          g convex, h convex, h̃ nondecreasing
                          g concave, h convex, h̃ nonincreasing
5. Vector Composition:
  f is the composition of g : Rn → Rk and h : Rk → R:
  f is convex if:
           (
             gi convex, h convex, h̃ nondecreasing in each argument
             gi concave, h convex, h̃ nonincreasing in each argument
Examples:
    • log m
          P
             i=1 exp gi (x) is convex if gi are convex (choose h to be the log-sum-exp
      function)
      Pm
    •    i=1 log gi (x) is concave if gi are concave and positive
                                             34
6. Minimization (a.k.a. Partial Minimization):
  if f (x, y) is convex in (x, y) and C is a convex set, then:
  is convex.
  Note that the conditions are stronger (more restrictions) than the maximum
  and supremum case. It has to be jointly-convex in minimum.
  Examples:
is convex if S is convex.
7. Perspective:
  The perspective g : Rn × R → R of a function f : Rn → R,
  is convex if f is convex.
  Examples:
                                                               xT x
     • f (x) = xT x is convex, so for t > 0, g(x, t) =          t
                                                                      is convex
     • negative logarithm f (x) = − log x is convex, hence the relative entropy:
       is convex on R2++ .
     • for any convex f ,
                                                            Ax + b
                                  g(x) = (cT x + d)f (               )
                                                            cT x + d
       is convex on domain:
                                                            Ax + b
                      dom g = {x | cT x + d > 0,                     ∈ dom f }
                                                            cT x + d
                                           35
3.3.11   The Conjugate Function
  1. negative logarithm:
                                            f (x) = − log x
                              f ∗ (x) = sup(xy + log x)
                                        x>0
                                        (
                                          −1 − log(−y) y < 0
                                      =
                                          ∞             otherwise
                                               36
   • f is quasiconcave if −f is quasiconvex
 function
 p                                 domain          quasiconvex           quasiconcave   quasilinear
    |x|                            R
 ceil(x)                           R
 log x                             R++
 f (x) = x1 x2                     R2++
 f (x) = x11x2                     R2++              (convex)
 f (x) = xx12                        2
                                   R++
 linear fractional function        dom f         =
           T x+b
 f (x) = acT x+d                       T
                                   {x|c x + d > 0}
 distance ratio f (x) =            dom f         =
 kx−ak2
 kx−bk2
                                   {x|kx − ak2 ≤
                                   kx − bk2 }
which means that, instead of “below the chord”, it goes below the “box”.
  2. first-order condition:
        if f is
           • differentiable
           • dom f is convex set
        in other words, it is like another way of describing the general idea that “it is a
        collection of centered, cascade shapes” or something alike.
Do not care too much about the function f , think about f ≥ α or f ≤ α directly.
  4
      See the lecture note for convex functions for more details.
                                                  37
3.3.13   Log-concave and Log-convex Functions (2/3 Generalization)
Log-concave
A positive function f is log-concave =⇒ log f is concave:
Log-convex
A positive function f is log-convex =⇒ log f is convex:
It is not a simple extension. And it happens to be that most of the interesting cases
are log-concave.
Examples:
         • twice-differentiable
         • with convex domain
                                             38
  3. sum of log-concave functions is not always log-concave:
        it means that the mixture distribution, with log-concave distributions, is not
        always log-concave.
  4. integration: if f : Rn × Rm → R is log-concave, then,
                                        Z
                                 g(x) = f (x, y)dy
        is log-concave.5
Important Consequences of the Integration Property:
  1. convolution of log-concave functions is log-concave:
        convolution of functions f and g is h = f ∗ g:
                                                 Z
                             h(x) = (f ∗ g)(x) = f (x − y)g(y)dy
                                                39
3.3.14      Convexity with respect to Generalized Inequalities (3/3 General-
            ization)
                              minimize f0 (x)
                             subject to fi (x) ≤ 0 (i = 1, 2, . . . , m)
                                        hi (x) = 0 (i = 1, 2, . . . , p)
where the optimal value p∗ (the inferior 7 value of f0 (x) under all those constraints)
is an ordinary value if the problem is bounded and feasible, is ∞ when not feasible (no
x satisfies the constraints, the feasible set is empty), −∞ if the problem is unbounded
below (can reach any smaller number).
Some explanation:
Some concepts:
• x is feasible if:
           – x ∈ dom f0
           – x satisfies the constraints
   • x is optimal if:
  7
      It is inferior, not minimum or minimal.
                                                 40
        – x is feasible
        – f0 (x) = p∗
• x is locally optimal if, ∃R > 0 such that x is optimal for the problem:
                              minimize f0 (x)
                             subject to fi (x) ≤ 0 (i = 1, 2, . . . , m)
                                        hi (x) = 0 (i = 1, 2, . . . , p)
                                        kz − xk2 ≤ R
And quite naturally, we have some implicit constraints for the standard form
optimization problem:
                                 m         p
                                 \        \
                         x∈D=      dom fi    dom hi
                                        i=1         i=1
• inf(0, 1] = 0, sup[0, 1) = 1
                                find x
                          subject to fi (x) ≤ 0 (i = 1, 2, . . . , m)
                                     hi (x) = 0 (i = 1, 2, . . . , p)
and it is equivalent with a special case of the general optimization problem where
f0 (x) = 0, then p∗ = 0 when feasible, p∗ = ∞ when infeasible. (Any x is optimal in
this case.)
                                              41
3.4.2      Convex Optimization Problems
                               minimize f0 (x)
                              subject to fi (x) ≤ 0 (i = 1, 2, . . . , m)
                                         hi (x) = 0 (i = 1, 2, . . . , p)
where f0 and all fi (inequality constraints) are convex functions; and all hi are
affine (in the form of aTi x − bi = 0).
The problem is quasiconvex if:
• f0 is quasiconvex;
• fi (i = 1, 2, . . . , m) are convex.
Note that there’s an important property: the feasible set of a convex optimization problem
is convex. A convex optimization problem might be viewed as minimizing a convex
function over a convex set in some abstract cases, but not strictly this way.
Also note that sometimes even if a problem is not a convex optimization problem, it
could have an equivalent expression that is convex optimization problem.
For example, an optimization problem that is significantly not convex:
                                                  42
It could be proved by the definition of local optimal with radius R and optimal point
x, neighbor feasible point z within the distance of R; having another y that might
locates far away and together with:
                                                         R
                         z = θy + (1 − θ)x,     θ=
                                                     2ky − xk2
and let y be a global optimal point with f0 (y) smaller than f0 (x), then there’s a
conflict in comparing z’s f0 value with x’s.
Optimality Criterion for Differentiable f0 :
x is optimal when f0 is differentiable ⇐⇒ :
   • x is feasible
   • ∀y, if y is feasible:
                                    ∇f0 (x)T (y − x) ≥ 0
If nonzero, ∇f0 (x) defines a supporting hyperplane for the feasible set X at point
x, with −∇f0 (x) being the outward norm. In general:
   • unconstrained problem:
                                      minimize f0 (x)
     then:                                   (
                                              x ∈ dom f0
                             x is optimal ⇐⇒
                                              ∇f0 (x) = 0
   • equality-constrained problem:
                                      minimize f0 (x)
                                     subject to Ax = b
     then:                              
                                        x ∈ dom f0
                                        
                         x is optimal ⇐⇒ Ax = b
                                        
                                          ∇f0 (x) + AT v = 0
                                        
                                          43
Here naturally comes the definition of the Equivalent Convex Problems.
For example:
   • epigraph form (very important!): from any standard form convex problem,
     we have it equivalent with:
                            minimize t (minimizing over x, t)
                           subject to f0 (x) − t ≤ 0
                                      fi (x) ≤ 0 (i = 1, 2, . . . , m)
                                      Ax = b
                                            44
   • partial minimization (minimizing over some variables):
                                 minimize f0 (x1 , x2 )
                                subject to fi (x) ≤ 0 (i = 1, 2, . . . , m)
        is equivalent to:
                                 minimize f˜0 (x1 )
                                subject to fi (x) ≤ 0 (i = 1, 2, . . . , m)
        where we have:
                                         f˜0 (x1 ) = inf f0 (x1 , x2 )
                                                       x2
                                        minimize f0 (x)
                                       subject to fi (x) ≤ 0
                                                  Ax = b
with f0 : Rn → R quasiconvex, f1 , . . . , fm convex.
Feature: can have locally optimal points that are not (globally) optimal.
Recall the definition of quasiconvex functions, we have that f0 (x) ≤ t is t-sublevel set
of f0 , and its domain is convex set. Having t-sublevel set if f0 denoted as 0-sublevel
set of φt , which means:
                               f0 (x) ≤ t ⇐⇒ φt (x) ≤ 0
and for each fixed t, φt (x) is convex in x.
We define the family of function φt such that:
                                                  45
3.4.4      Linear Optimization (LP)
• none
• one
• infinite Many
solutions.
Linear programs with fewer constraints than variables are NOT guaranteed to be
feasible.
Linear Program (LP)
                                          minimize cT x + d
                                         subject to Gx  h
                                                    Ax = b
it is convex problem with affine objective and constraint functions.
Its feasible set is always polyhedron.
In fact, d could be removed without influencing the solutions. x∗ is always at an
angle of the feasible set, and −c points outward from x∗ .
LP could be solved extremely fast, with total reliability.
Examples:
is equivalent with,
                                 minimize t
                                subject to aTi x + bi ≤ t (i = 1, 2, . . . , m)
                                   P = {x|aTi x ≤ bi , i = 1, 2, . . . , m}
                                                                     10
        which is the center of the largest inscribed ball:
                                         B = {xc + u|kuk2 ≤ r}
 10
      It means that the ball is the largest ball inside the shape of the set.
                                                   46
     and we have:
                                     ai x ≤ bi (∀x ∈ B)
                               ⇐⇒ sup{aTi (xc + u)|kuk2 ≤ r}
                                     = aTi xc + rkai k2
                                     ≤ bi
     thus this whole problem could be solved by solving the LP:
                       minimize r
                      subject to aTi xc + rkai k2 ≤ bi (i = 1, 2, . . . , m)
Linear-fractional Program
                                                      cT x + d
                               minimize f0 (x) =
                                                      eT x + f
                              subject to Gx  h
                                         Ax = b
where
                              dom f0 = {x|eT x + f > 0}
It is a significant sort of generalization of LP. A kind of quasiconvex problem. It is
also equal to LP with variables y, z:
                                minimize cT y + dz
                               subject to Gy  hz
                                          Ay = bz
                                            eT y + f z = 1
                                            z≥0
                                                            cTi x + di
                          minimize f0 (x) = max
                                                 i=1,2,...m eT x + fi
                                                              i
                         subject to Gx  h
                                    Ax = b
where
                     dom f0 = {x|eTi x + fi > 0 (i = 1, 2, . . . , r)}
is also a quasiconvex problem solvable by bisection.
Robust Linear Programming is described in QP (3.4.5) part.
                                            47
3.4.5     Quadratic Optimization (QP, SOCP, QCQP)
Non-affine problems.
Quadratic Program (QP)
                                         1 T
                               minimize    x P x + qT x + r
                                         2
                              subject to Gx  h
                                         Ax = b
where P ∈ Sn+ , thus objective function is convex quadratic.
Note that 12 xT P x + q T x + r is guaranteed convex only when P ∈ Sn+ .
In the polyhedron feasible set, the x∗ always lies on an edge, with −∇f (x∗ ) be a norm
of the corresponding edge pointing outward of the feasible set. Level sets (α-sublevel
sets) are ellipsoids.
Examples:
   • Least-Squares:
                                    minimize kAx − bk22
        with:
          – analytical solution x∗ = A† b (A† is the pseudo-inverse);
          – optional linear constraints l  x  u.
   • Linear Program (LP) with Random Cost:
                               minimize cT x + γxT Σx
                                         = EcT x + γvar(C T x)
                              subject to Gx  h
                                         Ax = b
        with:
          – random vector c has mean c and covariance Σ (hence cT x has mean cT x
            and covariance xT Σx)
          – aversion parameter γ > 0, controls the trade-off between the expected cost
            and risk (variation)
                                            48
   • Pi ∈ Sn+ , thus objective and constraints are convex quadratic;
   • If P1 , P2 , . . . , Pm ∈ Sn++ , then the feasible region is intersection of m ellipsoids
     and an affine set.
Note that, LP ⊆ QP ⊆ QCQP ⊆ SOCP .
Second-order Cone Programming (SOCP)
                    minimize f T x
                  subject to kAi x + bi k2 ≤ cTi x + di (i = 1, 2, . . . m)
                             Fx = g
where:
   • Ai ∈ Rni ×n , F ∈ Rp×n ;
   • kAi x + bi k2 ≤ cTi x + di are called second-order cone (SOC) constraints;
   • (Ai x + bi , cTi x + di ) is in a second-order cone in Rni +1
   • If ni = 0, it reduces to LP, if ci = 0, reduces to QCQP;
   • LP ⊆ QP ⊆ QCQP ⊆ SOCP .
Robust Linear Programming
                           minimize cT x + d
                          subject to ai x ≤ bi , i = 1, 2, . . . , m
How to handle uncertainty in c, ai , bi ? Take ai as an example. Two common
approaches:
   • deterministic model: constraints must hold for all ∀ai ∈ Ei :
                         minimize cT x + d
                        subject to ai x ≤ bi , ∀ai ∈ Ei , i = 1, 2, . . . , m
     a.k.a. “worst-case” model, to guarantee that it works in the worst cases.
     Could be done via SOCP:
                                   Ei = {ai + Pi u | kuk2 ≤ 1}
     where ai ∈ Rn and Pi ∈ Rn×n , then,
                                sup (ai + Pi u)T x = ai x + kPiT xk2
                              kuk2 ≤1
                                             49
   • stochastic model: for random variable ai , constraints hold with probability
     η:
                   minimize cT x + d
                  subject to prob(ai x ≤ bi ) ≥ η, i = 1, 2, . . . , m
        It is suitable if you are pretty sure about the distribution.
        Could be solved via SOCP as well:
        Assuming ai ’s distribution be Gaussian random variable with mean ai and
        covariance Σi :
                                       ai ∼ N (ai , Σi )
        hence,
                                                                b − aT x 
                                                                  i   i
                                  prob(aTi x ≤ bi ) = Φ                1
                                                                  kΣi2 xk2
        where Φ(x), the CDF (Cumulative Distribution Function) of N (0, 1) is:
                                             Z x
                                         1          t2
                                Φ(x) = √          e− 2 dt
                                         2π −∞
        thus when η ≥ 12 :
                       minimize cT x + d
                                                        1
                      subject to aTi + Φ−1 (η)kΣi2 xk2 ≤ bi , i = 1, 2, . . . , m
These models have meanings, they originally came from some practical problems in
real life.
Generally speaking, it is not convex problem, but you may change the variables and
make it convex.
Geometric Program (GP)
                              minimize f0 (x)
                             subject to fi (x) ≤ 1, i = 1, 2, . . . , m
                                        hi (x) = 1, i = 1, 2, . . . , p
where:
   • fi is posynomial:
        A posynomial function f (x) is:
                                              K
                                              X
                                    f (x) =         ck xa11k xa22k . . . xannk
                                              k=1
                                                50
   • hi is monomial:
     A monomial function f (x) is:
   • yi = log xi
   • take logarithm of cost and constraints
such that:
   • monomial functions:
                                  f (x) = cxa11 xa22 . . . xann
                                          Xn
                           ⇐⇒ log f (x) =      ai log xi
                                                     i=1
                                                = a y + b, (xi = eyi , b = log c)
                                                      T
   • posynomial functions:
                                           K
                                           X
                                f (x) =          ck xa11k xa22k . . . xannk
                                           k=1
                                                  K
                                                 X                      
                                                               aT
                                                                k y+bk
                   ⇐⇒ log f (x) = log                      e                 , (xi = eyi , bi = log ci )
                                                     k=1
An GP example: the design of the cantilever beam. (Multiple segments, from the
wall to the end, becoming smaller.) See slides or textbook for details.
                                                         51
Forming a problem as a standard GP will already enable libraries such as the cvx (or
cvxpy) automatically handle the rest for you.
Note that two posynomial functions: f, g, for positive variable z, that f (z) ≤ g(z)
doesn’t make a posynomial constraint, and couldn’t be automatically handled by
library.
An arithmetic mean of the entries of a variable divided by the geometric mean,
is posynomial.
                        minimize f0 (x)
                       subject to fi (x) Ki 0, i = 1, 2, . . . , m
                                  Ax = b
where:
• f0 : Rn → R is convex;
It has the same properties as standard convex problems. For example, convex
feasible set, and the local optimum is global optimum.
Examples:
• conic form problem: a special case with affine cost and affine constraints,
                                   minimize cT x
                                  subject to F x + g K 0
                                             Ax = b
                    minimize cT x
                   subject to x1 F1 + x2 F2 + · · · + xn Fn + G  0
                              Ax = b
where:
• Fi , G ∈ Sk
                                           52
   • the inequality constraint is called linear matrix inequality (LMI)
   • it includes problems with multiple LMI constraints, since the sum of two LMI
     is also LMI:
         ∵ x1 F11 + x2 F12 + · · · + xn F1n + G1  0
           x1 F21 + x2 F22 + · · · + xn F2n + G2  0
                                                                      
               F11 0               F12 0                     F1n 0      G1 0
         ∴ x1              + x2               + · · · + xn           +         0
                0 F21               0 F22                     0 F2n     0 G2
                                              53
where A(x) = A0 + x1 A1 + · · · + xn An , with given Ai ∈ Rp×q , and t ∈ R, x ∈ Rn .
Since:
                        kAk2 ≤ t ⇐⇒ AT A  t2 I (t ≥ 0)
                                                        0
                                          
                                      tI A
                                 ⇐⇒    T
                                      A tI
we have that, it is equivalent with the SDP:
                             minimize t
                                                  
                                          tI   A(x)
                            subject to               0
                                         A(x)T  tI
                          minimize f0 (x)
                         subject to fi (x) ≤ 0, i = 1, 2, . . . , m
                                    hi (x) = 0, i = 1, 2, . . . , p
where f0 (x) : Rn → Rq is minimized with respect to proper cone K ∈ Rq .
Convex Vector Optimization Problem:
                          minimize f0 (x)
                         subject to fi (x) ≤ 0, i = 1, 2, . . . , m
                                    Ax = b
• optimal, if f0 (x) is the minimum value (x∗ ) of O, where minimum means that:
                                            54
An example of the optimal and Pareto optimal points:
Multicriterion Optimization:
• Regularized Least-Squares:
      we could draw a curve of F2 ∼ F1 , and find the Pareto optimal points to solve
      it.
   • Risk Return Trade-Off in Portfolio Optimization:
                              minimize (w.r.t. R2+ ) (−pT x, xT Σx)
                                            subject to 1T x = 1,
                                                       x0
      it is, minimizing the vector of risk of return and return variance. x, p ∈ Rn , x
      is the investment portfolio, p is the asset price changes.
   3. By varying λ, we could find almost all Pareto optimal points in the original
      problem. They are optimal points in the scalar problem.
   4. If xi is Pareto optimal, then the corresponding λi should be the inward norm
      of the tangent line at point f0 (xi ).
   5. For multicriterion problems:
      for the case where f0 (x) = (kAx−bk22 , kxk22 ), or the risk return trade-off case, we
      could have λ = (1, γ) and thus we have a form similar with what we frequently
      observe in ML, lost with regularization.
                                                55
Suppose x minimizes f (x) + g(x). Then x is Pareto optimal for the bi-criterion
optimization problem minimize (f (x), g(x)).
3.5     Duality
It is an organized way of forming highly nontrivial bounds on convex optimization
problems. It works even for hard problems that are not necessarily convex (but the
functions, the problems involved must be convex to make it work).
3.5.1 Lagrangian
it is basically a weighted sum, with λ and ν being the Lagrange multiplier associated
with the constraints.
                                              56
g is always concave, and could be −∞ for some λ, ν.
There’s an important property, called the lower-bound property:
If λ 0, then g(λ, ν) ≤ p∗ .
minimizing all feasible x̃ gives p∗ ≥ g(λ, ν). It holds for all λ and all ν.
For differentiable L, how we naturally calculate g is to calculate x that makes
∇x L(x, λ, ν) = 0, and plug it in L to obtain g.
However, if L is unbounded in x (e.g. affine), in the form of:
Original problem:
                                         minimize f0 (x)
                                        subject to Ax  b
                                                   Cx = d
Then the dual function is:
                                       f0 (x) + (AT λ + C T ν)T x − (bT λ + dT ν)
                                                                                    
               g(λ, ν) =     inf
                           x∈dom f0
                                                   57
3.5.4   (Lagrange) dual problem
                                     maximize g(λ, ν)
                                    subject to λ  0
this is obviously a convex optimization problem, where the optimal value is d∗ .
(λ, ν) is feasible if: (1) λ  0, and (2) (λ, ν) ∈ dom g. The dual problem is often
simplified by making the implicit constraint of (λ, ν) ∈ dom g explicit.
The dual function provides a lower bound on the optimal value for both convex
optimization problems and non-convex problems.
That is to say, if the primal (original) and the dual problem have the same optimal
values.
Weak Duality: d∗ ≤ p∗
Strong Duality: d∗ = p∗
                                              58
   • The conditions also guarantee the dual optimum is attained if p∗ > −∞;
                             11
It always apply to LP, QP
Strong duality may occur in cases where convexity isn’t
satisfied.
When this occurs, it means that the original problem could be solved
by convex optimization.
Every problem involving two quadratic functions (e.g. f0 being quadratic, and
subject to a quadratic function) can be solved exactly, convex or not. Because,
for all those problems, the dual is an SDP. This guarantees the zero duality gap
(strong duality).
For example,
                                    minimizing xT P x
                                     subject to kxk2 = 1
It is not convex but it is solvable by convex optimization. So as:
                                  minimizing xT P x + 2bT x
                                   subject to xT x ≤ 1
etc. We say they are not convex problem because, note that P can be anything, not
guaranteed symmetric.
In details,
                                  minimizing xT P x + 2bT x
                                   subject to xT x ≤ 1
has dual function:
                              maximize − bT (A + λI)†b − λ
                             subject to A + λI  0
                                        b ∈ R(A + λI)
and this dual function has an equivalent SDP:
                                maximize − t − λ
                                                    
                                            A + λI b
                               subject to              0
                                              bT   t
                                             59
3.5.7   Geometric interpretation
The duality gap somehow represents the “best line” that is tangent to the set G =
{(f1 (x), f0 (x))|x ∈ D}. An illustration is in the lecture note.
It is equivalent with understanding it with epigraph:
• x∗ minimizes L(x, λ∗ , ν ∗ )
           “if one of them holds with some slack, the other must hold without
           slack; you can’t have slack on both.”
For a problem with differentiable fi and hi , we have four conditions that togetherly
named KKT conditions:
   • Primal Constraints:
                                    (
                                     fi (x) ≤ 0 i = 1, 2, . . . , m
                                     hi (x) = 0 i = 1, 2, . . . , p
                                               60
   • Dual Constraints: λ  0
   • If strong duality holds and x, λ, ν are optimal, then KKT condition must be
     satisfied.
   • If the KKT condition is satisfied by x, λ, ν, strong duality must hold and the
     variables are optimal.
We name the new optimal value p∗ (u, v), as a function of parameters u, v. And we
can get some information from the unperturbed version that is helpful on it.
global sensitivity result:
                                             (
                                              Strong duality holds
         Assume for the unperturbed problem,
                                              λ∗ , ν ∗ are dual optimal
                                 then p∗ (u, v) ≥ g(λ∗ , ν ∗ ) − uT λ∗ − v T ν ∗
                                                     = p∗ (0, 0) − uT λ∗ − v T ν ∗
                                              61
where ui > 0 means loosen constraint, ui < 0 means tighten constraint.
We could gain some interpretations in respect with λ∗ , ν ∗ influence on p∗ (u, v), under
certain conditions of u, v (> 0 or < 0 in specific).
local sensitivity:
If, in addition, p∗ (u, v) is differentiable on u and on v, then we have:
                                     ∂p∗ (0, 0)                   ∂p∗ (0, 0)
                           λ∗i = −                      νi∗ = −
                                       ∂ui                          ∂vi
there’s proof in lecture note and in textbook.
These sensitivity provides us theory bases if we want to tighten or loosen some
constraints.
       it’ll be exactly the same if we replace νi with νiT , since hi (x) suppose to be zero.
   • Dual function is defined as:
                        g(λ1 , λ2 , . . . , λm , ν) = inf L(x, λ1 , λ2 , . . . , λm , ν)
                                                       x∈D
                                                  62
   • Lagrange multiplier: Z ∈ Sk
• Lagrangian:
                    L(x, Z) = cT x + tr Z(x1 F1 + x2 F2 + · · · + xn Fn − G)
                                                                            
   • dual function:
                                   (
                                    − tr(GZ) tr(Fi Z) + ci = 0, i = 1, . . . , n
              g(Z) = inf L(x, Z) =
                      x             −∞       otherwise
                                    minimize kAx − bk
where A ∈ Rm×n , m ≥ n. This is a norm on Rm .
There are multiple ways of interpreting the solution of this problem. See lecture
notes. (e.g. geometric, estimation, optimization problem.)
• least-square approximation:
AT Ax = AT b
                                             63
   • Chebyshev approximation:
• quadratic: φ(u) = u2
                                           64
3.6.2     Least-norm problems
                                      minimize kxk
                                     subject to Ax = b
• least-square approximation:
                                         minimize kxk2
                                        subject to Ax = b
2x + AT ν = 0, Ax = b
                                         minimize kxk∞
                                        subject to Ax = b
                                              65
3.6.3     Regularized approximation
   • Other common methods such as minimize kAx − bk2 + δkxk2 with δ > 0. e.g.
     Tikhonov regularization (ridge regression):
                                  minimize kAx − bk
with uncertain A.
General idea of two ways of solving it:
A = A + U, U random, EU = 0, EU T U = P
                                              66
                          E(kAx − bk22 ) = E(kAx − b + U xk22 )
                                        = kAx − bk22 + E(xT U T U x)
                                        = kAx − bk22 + xT P x
                                        = kAx − bk22 + kP 1/2 xk22
        and the robust LS problem is transformed into an LS problem this way.
        It is equivalent to a Tikhonov regularized nominal problem if the entries of A
        are i.i.d.
   • worst case: minimize supA kAx−bk; refer to the lecture notes for some special-
     cases.
                                           67
3.8     Geometric problems
3.8.1    Extremal volume ellipsoids
Minimum volume ellipsoid around a set (C), also known as Löwner − John
Ellipsoid, denoted as E:
it is convex, but for general C it is hard to solve, because evaluating the constraints
is hard. Solvable for finite set:
                  minimize (over A, b) log det A−1
                            subject to kAxi + bk2 ≤ 1, i = 1, 2, . . . , m
it gives a Löwner − John Ellipsoid for a polyhedron, the convex hull formed by all
possible x points. (This is not obvious but it’s true.)
it is convex, but for general C it is hard to solve, because evaluating the constraints
is hard.
Solvable for polyhedron {x|aTi x ≤ bi , i = 1, 2, . . . , m}
                                                68
 Ellipsoid Type    Löwner − John Ellipsoid Maximum volume inscribed Ellipsoid
     Original             Covers C                   Lies inside C
    Behavior         Shrunk by a factor n        Expanded by a factor n
      Result            Lies inside C                  Covers C
                                                     √
If C is symmetric, then n could be reduced to            n.
                                n
Any norm on set of R could be projected into the quadratic
norm within the factor of 41 .
The smallest norm from infinite set P to a point a is always easy, while for the largest
norm, Euclidean is not easy but `∞ is.
3.8.2 Centering
                                fi (x) ≤ 0, i = 1, 2, . . . , m
                                Fx = g
is easier to compute than ellipsoid centers, and two convex optimization problems
could have the same feasible set but different centers.
It is a function of the description of the set; not the feasible set itself.
3.8.3 Classification
This part is basically the idea that give rise to algorithms such as SVM. Very standard
and nothing new.
Just why it works, how to estimate the values, soft margin (called slack in this case),
hinge loss, non-linear SVM, etc. Focusing on why they are solvable, they could be
transformed into convex optimization problems.
See the lecture note.
                                              69
3.9      Unconstrained minimization
3.9.1     Terminology and assumptions
                                      minimize f (x)
with no constraint, and f is convex, twice continuously differentiable (hence dom f
is open), assuming that p∗ = inf x f (x) is attained and finite.
unconstrained minimization methods:
∇f (x∗ ) = 0
   • requirement on x(0) : x(0) ∈ dom f and the sublevel set S = {x|f (x) ≤
     f (x(0) )} is closed.
   • it is hard to verify that a certain sublevel set is closed, but in certain conditions
     all sublevel sets are closed:
   • for x, y ∈ S:
                                                              m
                          f (y) ≥ f (x) + ∇f (x)T (y − x) +     kx − yk22
                                                              2
        hence, S is bounded.
   • p∗ > −∞ and ∀x ∈ S:
                                                   1
                                   f (x) − p∗ ≤      k∇f (x)k22
                                                  2m
        if m is known then this is a useful stopping criterion.
                                            70
3.9.2     Gradient descent method
Descent Methods:
where ∆x(k) is called step, and t the step size (learning rate).
From convexity, it implies that:
∇f (x)T ∆x < 0
Starting at a point near the optimal point doesn’t necessarily means it’ll converge
fast in gradient descent.
f (x + v) ≈ f (x) + ∇f (x)T v
∆xnsd is the unit-norm step with the most (/ the most significant) negative-direction
derivative.
                                            71
unnormalized steepest descent direction
The Newton’s method comes from the idea of “doing steepest descent method, but
let’s change the P each iteration to the temporary best guess”.
                                                  ∇f (x)
                                       ∆xnt = −
                                                  ∇2 f (x)
Interpretations includes:
                                             72
3.9.5    Newton decrement
• directional derivative:
                                           ∇f (x)
                                 ∆xnt = −
                                           ∇2 f (x)
                                    λ2 = (∇f (x)T ∇2 f (x)−1 ∇f (x))
                                            λ2
        (b) (stopping criterion) quit if    2
                                                 ≤
        (c) Line search: choose t by backtracking line search
        (d) Update x = x + t∆xnt
                                            73
3.9.7     Classical Convergence Analysis for Newton method
Assume:
                                            74
3.9.8   Newton Method and Cholesky factorization
Evaluate derivatives and solve Newton system (the main task each step):
H∆x = g
   • it is generally not practical to form or store the Hessian in such problems, due
     to large problem size.
                                      minimize f0 (x)
                                     subject to Ax = b
where we assume that: f is a twice continuously differentiable convex function; A ∈
Rp×n with rank A = p; p∗ is finite and attained.
The optimality conditions (for x∗ being optimal, iff), according to KKT (see section
3.5), is that: there exists ν ∗ :
∇f (x∗ ) + AT ν = 0 Ax∗ = b
they come from the dual residual and the primal residual.
The equality-constrained quadratic minimization with P ∈ Sn+ :
                                           1 T
                                 minimize    x P x + qT x + r
                                           2
                                subject to Ax = b
                                             75
optimality conditions are:
                                P A T x∗
                                       
                                            −q
                                          =
                                 A 0   v∗    b
the coefficient matrix is also called the KKT matrix; this matrix is nonsingular
iff:
                           Ax = 0, x 6= 0 =⇒ xT P x > 0
this nonsingular-condition is equivalent with
                                     P + AT A  0
Interpretations:
                                           76
   • gives an estimation:
                                                              λ(x)2
                             f (x) − p∗ ≈ f (x) − inf fˆ(y) =
                                                 Ay=b           2
   • in general,
                              λ(x) 6= (∇f (x)T ∇2 f (x)−1 ∇f (x))1/2
      it is not equivalent with the value without constraints.
The Newton’s method (the procedure) is the same with without constraints, and it
is also affine invariant.
A feasible descent method: x(k) feasible and f (x(k+1) ) < f (x(k) ).
• z ∈ Rn−p
Don’t need separate convergence analysis. It is about the same with the original one.
With infeasible x:
                                 x ∈ dom f,          Ax 6= b
we have that                2                      
                            ∇ f (x) AT v         ∇f (x)
                                            =−
                               A     0   w       Ax − b
where still, v’s solution is ∆xnt .
There are similar interpretations, for details see the lecture notes.
The infeasible start Newton method has different process than that of the feasible
one, for details see the lecture notes. Not a descent method!
                                             77
3.10.4   Implementation of the Newton Method
                                   
                             H AT v      g
                                      =
                             A 0    w    h
solution methods:
• LDLT factorization
AH −1 AT w = h − AH −1 g Hv = −(g + AT w)
   • primal problem
                                                  n
                                                  X
                                    minimize −          log xi
                                                  i=1
                                   subject to Ax = b
   • dual problem
                                                n
                                                X
                            maximize − bT ν +         log(AT ν)i + n
                                                i=1
                          diag(x)−2 AT ∆x       diag(x)−1 1
                                                      
                                              =
                              A       0    w        0
     reduces to solving
                                    A diag(x)2 AT w = b
                                           78
  3. block elimination to solve the KKT system:
                          diag(x)−2 AT ∆x       diag(x)−1 1
                                                      
                                              =
                              A       0   ∆ν      Ax − b
       reduces to solving
                                   A diag(x)2 AT w = 2Ax − b
                             minimize f0 (x)
                            subject to fi (x) ≤ 0 i = 1, 2, . . . m
                                       Ax = b
assume that:
                                              79
for t > 0, − 1t log(−u) is a smooth approximation of I− (u), and the approximation
improves as t → ∞.
Logarithm barrier function:
                    m
                    X
         φ(x) = −         log(−fi (x)), dom φ = {x|fi (x) < 0, i = 1, 2, . . . , m}
                    i=1
• it is convex
Central Path:
For t > 0, define x∗ (t) as the solution of
assuming that x∗ (t) exists and is unique for each t > 0, then the central path is
defined as
                                    {x∗ (t)|t > 0}
where we have:                         (
                                        λ∗i (t) =          1
                                                     −tfi (x∗ (t))
                                         ν ∗ (t) =   w
                                                     t
                                                     80
this confirms the intuitive idea that
proof :
                                       p∗ ≥ g(λ∗ (t), ν ∗ (t))
                                          = L(x∗ (t), λ∗ (t), ν ∗ (t))
                                                            m
                                          = f0 (x∗ (t)) −
                                                            t
m
t
     is called a duality gap.
Interpretations via KKT conditions:
x = x∗ (t), λ = λ∗ (t), ν = ν ∗ (t) satisfy:
     2. dual constraints: λ  0
                                                                12
     3. approximate complementary slackness                          :
                                                    1
                                        −λi fi (x) = , i = 1, 2, . . . , m
                                                    t
2. repeat:
                                                     81
        (d) Increase t: t = µt
where we have:
Phase I is to compute the strictly feasible starting point for barrier method.
Basic phase I method:
                    minimize (over x, s) s
                              subject to fi (x) ≤ s, i = 1, 2, . . . , m
                                         Ax = b
Analyzes the time complexity. e.g. Newton’s method iterations per centering step.
                         minimize f0 (x)
                        subject to fi (x) Ki 0, i = 1, 2, . . . , m
                                   Ax = b
where
• f0 convex
• A ∈ Rp×n , rank A = p
• assume strict feasibility =⇒ (1) strong duality; (2) dual optimum attained
                                            82
Examples of greatest interest: SOCP, SDP.
Generalized logarithm for proper cone:
ψ : Rn → R is called the generalized logarithm for proper cone K ⊆ Rq if:
               R
    • dom ψ = K
   • ∇2 ψ(y) ≺ 0 for ∀y K 0
   • ψ(sy) = ψ(y) + θ log s, for ∀s > 0, y K 0 (θ is the degree of ψ)
Examples:
Properties: for y K 0,
                            ∇ψ(y) K ∗ 0,           y T ∇ψ(y) = θ
Examples:
                                                       Pn
   • nonnegative orthant (K = Rn+ , ψ(y) =                i=1   log yi , θ = n):
                                     1 1      1
                         ∇ψ(y) = (     , ,..., )                y T ∇ψ(y) = n
                                     y1 y2    yn
                                              83
   • ψi is the generalized logarithm for Ki , with degree θi ;
   • φ is convex and twice continuously differentiable
where Dfi (x)T ∈ Rki ×n is derivative matrix of fi ; therefore, x∗ (t) minimizes the
Lagrangian:
                                                 m
                                                 X
                    ∗     ∗
              L(x, λ (t), ν (t)) = f0 (x) +            λ∗i (t)fi (x) + ν ∗ (t)T (Ax − b)
                                                 i=1
where we have:                 (
                                λ∗i (t) = 1t ∇ψi (−fi (x∗ (t)))
                                ν ∗ (t) = wt
besides, the properties of ψi implies that
Example: SDP, Fi ∈ Sp
                           minimize cT x
                                                   n
                                                   X
                          subject to F (x) =                 x i Fi + G  0
                                                       i=1
   • logarithm barrier:
                                      φ(x) = log det(−F (x)−1 )
     hence,
                          tci − tr(Fi F (x∗ (t))−1 ) = 0, i = 1, 2, . . . , n
                                                 84
    • dual point on central path: Z ∗ (t) = − 1t F (x∗ (t))−1 is feasible for
                         maximize tr(GZ)
                        subject to tr(Fi Z) + ci = 0, i = 1, 2, . . . , n
                                   Z0
All vectors of form Rn in this course are, by default, vertical, instead of horizontal.
                                            85
4.2     Math Tools
4.2.1   Cauchy-Schwarz Inequality
Abbreviated as “Cauchy Inequality” in most Chinese materials.
Generally, it means:
                            (uT v)2 ≤ (uT u)(vT v)
for ∀u, v ∈ RT .
                                           86
4.3.2     To prove convex function
   • Show that f is obtained from some known convex functions by certain operations
     (the operations that preserve convexity). Refer to part 3.3.10 for more details.
An example:                                 √
                             f (x) = e−a          x
                                                      ,        dom f = R+
when will f be convex?
Solution: let f (x) = h(g(x)), then we have
                                       √
                             g(x) = −a x,                       h(x) = ex
• quasiconvex:
• quasiconcave:
• quasilinear:
                                                          87
4.3.4     Relaxations on Constraints’ Expressions
Examples:
   • minimize f0 (φ(x)) ←→ minimize f0 (y) & s.t. φ(x) − y = 0
                                            88
4.4     Matrix Tricks
4.4.1   Dealing with Sn+ or Sn++
z T M z ≤ z T N z =⇒ M N
goes to −∞ as t → ∞.
Appeared in:
• (A7.1 (b))
With Q ∈ Sn++ ,
                                 tr(Qai aTi ) = aTi Qai
XQ = QΛ
                                          89
And we also have:
                           X = QΛQ−1
                          X 2 = (QΛQ−1 )(QΛQ−1 )
                              = QΛQ−1 QΛQ−1
                              = QΛ2 Q−1
                          X n = QΛn Q−1
                         X −1 = QΛ−1 Q−1
                                 p          
                                 λ1 . . .
                          Λp =  ...      .. 
                                
                                           .
                                     . . . λpn
90