Parametric Programming
   HOME

TheInfoList



OR:

Parametric programming is a type of
mathematical optimization Mathematical optimization (alternatively spelled ''optimisation'') or mathematical programming is the selection of a best element, with regard to some criteria, from some set of available alternatives. It is generally divided into two subfiel ...
, where the
optimization problem In mathematics, engineering, computer science and economics Economics () is a behavioral science that studies the Production (economics), production, distribution (economics), distribution, and Consumption (economics), consumption of goo ...
is solved as a function of one or multiple
parameters A parameter (), generally, is any characteristic that can help in defining or classifying a particular system (meaning an event, project, object, situation, etc.). That is, a parameter is an element of a system that is useful, or critical, when ...
. Developed in parallel to
sensitivity analysis Sensitivity analysis is the study of how the uncertainty in the output of a mathematical model or system (numerical or otherwise) can be divided and allocated to different sources of uncertainty in its inputs. This involves estimating sensitivity ...
, its earliest mention can be found in a
thesis A thesis (: theses), or dissertation (abbreviated diss.), is a document submitted in support of candidature for an academic degree or professional qualification presenting the author's research and findings.International Standard ISO 7144: D ...
from 1952. Since then, there have been considerable developments for the cases of multiple parameters, presence of
integer An integer is the number zero (0), a positive natural number (1, 2, 3, ...), or the negation of a positive natural number (−1, −2, −3, ...). The negations or additive inverses of the positive natural numbers are referred to as negative in ...
variables as well as nonlinearities.


Notation

In general, the following optimization problem is considered : \begin J^*(\theta) = & \min_ f(x,\theta) \\ & \text g(x,\theta)\leq 0.\\ & \theta \in \Theta \subset \mathbb R^m \end where x is the optimization variable, \theta are the parameters, f(x,\theta) is the
objective function In mathematical optimization and decision theory, a loss function or cost function (sometimes also called an error function) is a function that maps an event or values of one or more variables onto a real number intuitively representing some "cost ...
and g(x,\theta) denote the constraints. J^* denotes a function whose output is the optimal value of the objective function f. The set \Theta is generally referred to as parameter space. The optimal value (i.e. result of solving the optimization problem) is obtained by evaluating the function with an argument \theta.


Classification

Depending on the nature of f(x,\theta) and g(x,\theta) and whether the optimization problem features integer variables, parametric programming problems are classified into different sub-classes: * If more than one parameter is present, i.e. m > 1, then it is often referred to as multiparametric programming problem * If integer variables are present, then the problem is referred to as (multi)parametric mixed-integer programming problem * If constraints are
affine Affine may describe any of various topics concerned with connections or affinities. It may refer to: * Affine, a Affinity_(law)#Terminology, relative by marriage in law and anthropology * Affine cipher, a special case of the more general substi ...
, then additional classifications depending to nature of the objective function in (multi)parametric (mixed-integer) linear, quadratic and nonlinear programming problems is performed. Note that this generally assumes the constraints to be affine.


Applications


In control theory generally and in process industries

The connection between parametric programming and
model predictive control Model predictive control (MPC) is an advanced method of process control that is used to control a process while satisfying a set of constraints. It has been in use in the process industries in chemical plants and oil refineries since the 1980s. I ...
for
process manufacturing Process manufacturing is a branch of manufacturing that is associated with formulas and manufacturing recipes,
, established in 2000, has contributed to an increased interest in the topic. Parametric programming supplies the idea that optimization problems can be parametrized as functions that can be evaluated (similar to a lookup table). This in turns allows the optimization algorithms in optimal controllers to be implemented as pre-computed (off-line) mathematical functions, which may in some cases be simpler and faster to evaluate than solving a full optimization problem on-line. This also opens up the possibility of creating optimal controllers on chips (MPC on chipMPC on a chip—Recent advances on the application of multi-parametric model-based control , Request PDF
/ref>). However, the off-line parametrization of optimal solutions runs into the curse of dimensionality as the number of possible solutions grows with the dimensionality and number of constraints in the problem.


In CNC programming

Parametric programming in the context of CNC (
computer numerical control Computer numerical control (CNC) or CNC machining is the Automation, automated control of machine tools by a computer. It is an evolution of numerical control (NC), where machine tools are directly managed by data storage media such as punched ...
) is defining part-cutting cycles in terms of variables with reassignable values rather than via hardcoded/hardwired instances. An archetypically simple example is writing a
G-code G-code (abbreviation for geometric code; also called RS-274, standardized today in ISO 6983-1) is the most widely used computer numerical control (CNC) and 3D printing programming language. It is used mainly in computer-aided manufacturing t ...
program to machine a family of
washers Washer most commonly refers to: *Washer (hardware), a thin usually disc-shaped plate with a hole in the middle typically used with a bolt or nut *Washing machine, for cleaning clothes Washer may also refer to: *Dishwasher, a machine for cleani ...
: there is often no need to write 15 programs for 15 members of the family with various hole diameters, outer diameters, thicknesses, and materials, when it is practical instead to write 1 program that calls various variables and reads their current values from a table of assignments. The program then instructs the machine slides and spindles to move to various positions at various velocities, accordingly, addressing not only the sizes of the part (i.e., OD, ID, thickness) but also even the
speeds and feeds The phrase speeds and feeds or feeds and speeds refers to two separate parameters in machine tool practice, cutting speed and feed rate. They are often considered as a pair because of their combined effect on the cutting process. Each, however, ...
needed for any given material (e.g., low-carbon steel, high-carbon steel; stainless steel of whichever grade; bronze, brass, or aluminum of whichever grade; polymer of whichever type). Custom Macros are often used in such programming.


References

{{reflist Optimization algorithms and methods