Geometric programming

From Cornell University Computational Optimization Open Textbook - Optimization Wiki
Revision as of 16:07, 20 November 2021 by Wz274 (talk | contribs)
Jump to navigation Jump to search

Authors: Wenjun Zhu(wz274), Sam Olsen(sgo23) (SYSEN5800, FALL 2021)

Introduction

A geometric programming (GP) is a family of non-linear optimization problems. Geometric programming optimization problems are typically not convex optimization problems. However, geometric programming optimization problems can be transformed from non-convex optimization problems to convex optimization problems given by their special properties. The convexification for geometric programming optimization problems is implemented by a mathematical transformation of the objective function and constraint functions and a change of decision variables. Though a number of practical problems are not equivalent to geometric programming, geometric programming is generally considered an effective solution for practical problems and it is used to well approximate and analyze various large-scale applications. Typical applications include but are not limited to optimizing power control in communication systems [1], optimizing doping profile in semiconductor device engineering [1], optimizing electronic component sizing in IC design [1], and optimizing aircraft design in aerospace engineering [2].

Theory/Methodology

Monomial function

A monomial function, or a monomial, is defined as:

= ...

where > 0, is a function: with domain

The exponents of a monomial can be any real numbers, including fractional or negative, but the coefficient can only be positive [3].

Posynomial function

Posynomial

A posynomial function, or a posynomial, is defined as: = ...

where > 0,

This is a function of sum of monomial functions defined in the above section 2.1 [3].

Generalized Posynomial

A generalized posynomial function, or a general posynomial, is defined as a function of positive variables if it can be formed from posynomials using the operations of addition, multiplication, positive (fractional) power, and maximum [1].

For example:

where ,

,

is a generalized posynomial function and it can be seen as follows:

  • is a posynomial so is a posynomial function
  • is a posynomial so is a posynomial function
  • is a generalized posynomial so is a generalized posynomial function
  • is expressed by addition, multiplication, and positive (fractional) power from , , functions

Therefore is a generalized posynomial function.

Definition

The standard form of Geometric Programming optimization is to minimize the objective function which must be posynomial. The inequality constraints can only have the form of a posynomial less than or equal to one, and the equality constraints can only have the form of a monomial equal to one.

Standard Form

Minimize

Subject to: , = 1,...,m,

, = 1,...,p,

, = 1,...,q,

where are posynomial functions, are monomials, and are the decision variables.

Generalized Geometric Programming Form

Minimize

Subject to: , = 1,...,m,

, = 1,...,p,

where are generalized posynomial functions, are monomials, and are the decision variables.

Since any posynomial is also a generalized posynomial, any geometric programming is also generalized geometric programming.

Generalized geometric programming can be converted to equivalent geometric programming by different mathematical transformations.

Numerical Examples

Transform a non-standard form GP to standard form GP

The non-standard form GP is as follows:

Minimize

Subject to: ,

,

,

,

The equivalent standard form GP is as follows:

Minimize

Subject to: ,

,

,

,

Transform Non-convex Optimization Problems to Convex Optimization problem

The non-convex mixed integer non-linear programming (MINLP) is as follows:

Minimize

Subject to: ,

,

,

,

The reformulation of the MINLP above, from non-convex optimization problem to convex optimization problem, is as follows:

Minimize

Subject to: ,

,

,

,

Applications

Power Control

Optimal Doping Profile

Floor Planning

Digital Gate Sizing

Conclusion

In general, geometric programming is a simple but powerful family of non-linear optimization problems. Though geometric programming optimization problems are typically not convex optimization problems, they can be transformed to convex optimization problems by multiple convexification techniques. This makes the optimization problems more tractable. Because of this special property, geometric programming is one of the best ways to solve and analyze various large-scale applications.

References

  1. 1.0 1.1 1.2 1.3 S. Boyd, S. J. Kim, L. Vandenberghe, and A. Hassibi. A Tutorial on Geometric Programming. Retrieved 20 October 2019.
  2. W. Hoburg and P. Abbeel. Geometric programming for aircraft design optimization. AIAA Journal 52.11 (2014): 2414-2426.
  3. 3.0 3.1 S. Boyd, L. Vandenberghe, Convex Optimization. Cambridge University Press, 2009.