texlive[41330] Master: optidef (8jun16)
commits+karl at tug.org
commits+karl at tug.org
Fri Jun 10 00:53:42 CEST 2016
Revision: 41330
http://tug.org/svn/texlive?view=revision&revision=41330
Author: karl
Date: 2016-06-10 00:53:41 +0200 (Fri, 10 Jun 2016)
Log Message:
-----------
optidef (8jun16)
Modified Paths:
--------------
trunk/Master/tlpkg/bin/tlpkg-ctan-check
trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc
Added Paths:
-----------
trunk/Master/texmf-dist/doc/latex/optidef/
trunk/Master/texmf-dist/doc/latex/optidef/README.md
trunk/Master/texmf-dist/doc/latex/optidef/optidef.pdf
trunk/Master/texmf-dist/doc/latex/optidef/optidef.tex
trunk/Master/texmf-dist/tex/latex/optidef/
trunk/Master/texmf-dist/tex/latex/optidef/optidef.sty
trunk/Master/tlpkg/tlpsrc/optidef.tlpsrc
Added: trunk/Master/texmf-dist/doc/latex/optidef/README.md
===================================================================
--- trunk/Master/texmf-dist/doc/latex/optidef/README.md (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/optidef/README.md 2016-06-09 22:53:41 UTC (rev 41330)
@@ -0,0 +1,73 @@
+# optidef - Version 08/06/2016
+
+
+Copyright 2016 J. Lago Garcia
+
+This work may be distributed and/or modified under the conditions of the LaTeX Project Public License, either version 1.3 of this license or (at your option) any later version.
+The latest version of this license is in http://www.latex-project.org/lppl.txt and version 1.3 or later is part of all distributions of LaTeX version 2005/12/01 or later.
+
+This work has the LPPL maintenance status 'maintained'. The Current Maintainer of this work is J. Lago Garcia, under the supervision of Prof. Dr. Moritz Diehl and Prof. Dr. Sebastien Gross.
+
+E-mail: jesus.lago.garcia at venus.uni-freiburg.de
+
+This work consists of the file optidef.sty.
+
+----------
+FEATURES
+Optidef is a small library that provides a standard set of environments for writing optimization problems. The most important features are:
+
+- It automatically aligns the problems in three points with an optional fourth:
+
+ * Beginning of the words "minimize/argmin" and "subject to"
+ * The objective function and the longest left hand side of the constraints
+ * The $= | > | <$ signs of the constraints.
+ * Optionally, the user can add manually a double align character \&\& to align some common constraints feature. A clear example could be the constraints names, e.g. (boundary constraint) alignment with (dynamic constraint), or the index of the constraints, e.g. in the case of having something like $h(x_k,u_k)\leq 0,\quad k=0,\ldots,N$, align the indexes $k=0,\ldots,N$ across constraint lines.
+
+- It provides an easy interface to define optimization problem for three different reference situations:
+
+ * Where no equation is referenced/numbered.
+ * Where the problem is referenced with a single number.
+ * Where each equation has an individual reference.
+
+- It also allows a definition of any optimization problem without a limitless number of constraints.
+
+- It defines four types of optimization problems:
+
+ * minimize
+ * maximize
+ * arg mini
+ * arg maxi
+
+
+------
+# Syntax
+
+The syntax to define an optimization problem is given by:
+
+ >\begin{mini#}
+ {Number of constraints}
+ {Optimization variable}
+ {Objective function \label{Objective function referece}}
+ {LHS Constraint 1}{RHS Constraint 1 \label{Reference Constraint 1}}
+ {\label{Global referece of Optimization Problem}}
+ {Result of the optimization problem or any expression on the left of the minimize word}
+ \addConstraint{LHS Constraint 2}{RHS Constraint 2 \label{Reference Constraint 2}}
+ \addConstraint{LHS Constraint 3}{RHS Constraint 3 \label{Reference Constraint 3}}
+ .
+ .
+ \finalConstraint{LHS N} {RHSConstraint N \label{Reference Constraint N}}
+ \end{mini#}
+
+
+where mini# takes any of the following values:
+
+ - mini\* for no referencing
+ - mini! for referencing each equation
+ - mini for referencing with a single label the whole problem.
+
+Notice that only the first three will be really necessary in every definition, nevertheless and for the sake of having homogeneous definitions, we opted for requiring the 7 parameters in every definition and expecting empty parameters definitions, i.e. \{\}, when they are not needed.
+
+After the definition of this parameters, the environment accepts the definition of an infinite number of constraints. Notice that the last constraint has to be defined using the \finalConstraint command, instead of the \addConstraint.
+
+
+Finally note that \begin{mini#} can be substituted by \begin{maxi#}, \begin{argmini#} or \begin{argmaxi#}.
\ No newline at end of file
Property changes on: trunk/Master/texmf-dist/doc/latex/optidef/README.md
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/optidef/optidef.pdf
===================================================================
(Binary files differ)
Index: trunk/Master/texmf-dist/doc/latex/optidef/optidef.pdf
===================================================================
--- trunk/Master/texmf-dist/doc/latex/optidef/optidef.pdf 2016-06-09 22:52:48 UTC (rev 41329)
+++ trunk/Master/texmf-dist/doc/latex/optidef/optidef.pdf 2016-06-09 22:53:41 UTC (rev 41330)
Property changes on: trunk/Master/texmf-dist/doc/latex/optidef/optidef.pdf
___________________________________________________________________
Added: svn:mime-type
## -0,0 +1 ##
+application/pdf
\ No newline at end of property
Added: trunk/Master/texmf-dist/doc/latex/optidef/optidef.tex
===================================================================
--- trunk/Master/texmf-dist/doc/latex/optidef/optidef.tex (rev 0)
+++ trunk/Master/texmf-dist/doc/latex/optidef/optidef.tex 2016-06-09 22:53:41 UTC (rev 41330)
@@ -0,0 +1,768 @@
+\documentclass[]{report}
+\usepackage{remreset}
+\usepackage{optidef}
+
+% Title Page
+\title{\textit{\textbf{Optidef}} \\ A Latex library for minimization/maximization problems definition}
+
+\author{Jesus Lago Garcia}
+
+\makeatletter
+\renewcommand \thesection {\@arabic\c at section}
+\@removefromreset{section}{chapter}
+\makeatother
+
+
+\begin{document}
+\maketitle
+
+\section{Introduction and features}
+
+This small library provides a standard set of environments for writing minimization problems. The most important features are:
+\begin{enumerate}
+ \item It automatically aligns the problems in three points with an optional fourth:
+ \begin{enumerate}
+ \item Beginning of the words "minimize/argmin" and "subject to"
+ \item The objective function and the longest left hand side of the constraints
+ \item The $= | > | <$ signs of the constraints.
+ \item Optionally, the user can add manually a double align character \&\& to align some common constraints feature. A clear example could be the constraints names, e.g. (boundary constraint) alignment with (dynamic constraint), or the index of the constraints, e.g. in the case of having something like $h(x_k,u_k)\leq 0,\quad k=0,\ldots,N$, align the indexes $k=0,\ldots,N$ across constraint lines.
+ \end{enumerate}
+
+\item It provides an easy interface to define optimization problem for three different reference situations:
+\begin{enumerate}
+ \item Where no equation is referenced/numbered.
+ \item Where the problem is referenced with a single number.
+ \item Where each equation has an individual reference.
+\end{enumerate}
+
+\item It also allows a definition of any optimization problem without a limitless number of constraints.
+
+\end{enumerate}
+
+\section{Environment types}
+There are three basic environments depending on the type of referencing that should be used.
+\begin{enumerate}
+ \item The \textbf{mini} environment for defining problems with a single reference label:
+ \begin{mini}{1}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+ {\label{eq:Ex1}}{}
+ \end{mini}
+ \item The \textbf{mini*} environment if the problem does not have to be referenced:
+ \begin{mini*}{1}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+ {}{}
+ \end{mini*}
+ \item The \textbf{mini!} environment if each equation should be referenced:
+ \begin{mini!}{1}
+ {w}{f(w)+ R(w+6x) + \nabla_w R \label{eq:Ex2}}
+ {g(w)}{=0}
+ {\label{eq:Ex1}}{}
+ \end{mini!}
+\end{enumerate}
+
+\section{Environment Syntaxes}
+The three environments use the same syntax with the same number of parameters. In particular, considering that LHS stands for Left-hand-side and RHS for Right-hand-side, the basic structure to define a general optimization problem is:
+\begin{verbatim}
+
+\begin{mini#}{Number of constraints}
+ {Optimization variable}
+ {Objective function \label{Objective function referece}}
+ {LHS Constraint 1}{RHS Constraint 1 \label{Reference Constraint 1}}
+ {\label{Global referece of Optimization Problem}}
+ {Result of the optimization problem or any expression on
+ the left of the minimize word}
+
+ \addConstraint{LHS Constraint 2}{RHS Constraint 2 \label{Reference Constraint 2}}
+ \addConstraint{LHS Constraint 3}{RHS Constraint 3 \label{Reference Constraint 3}}
+ .
+ .
+ \finalConstraint{LHS N} {RHSConstraint N \label{Reference Constraint N}}
+\end{mini#}
+\end{verbatim}
+
+\noindent where \# $\in \{*, !, ~ \}$.
+\subsection{Parameters definition}
+The number of parameters that the environment uses is 7:
+
+\begin{enumerate}
+ \item \verb|Number of constraints|, e.g. 0,1,2,3,4...
+ \item \verb|Optimization variable|, e.g. $w \in \Re^N$.
+ \item \verb|Objective function|, e.g. $\|w\|_2$.
+ \item \verb|LHS Constraint 1| (optional): the left-hand side of the first constraint, e.g. $3w^\top w$. For unconstrained problems leave it blank, i.e. \{\}
+ \item \verb|RHS Constraint 1| (optional): the right-hand side of the first constraints including the equal, less and greater signs, e.g. $\leq \|w\|_\infty$. For unconstrained problems leave it blank, i.e. \{\}
+ \item \verb|\label{Global referece of Optimization Problem}|: it defines the main and general reference for the optimization problem. It is used for the \verb|mini| and \verb|mini!| enviroments. In the \verb|mini*| environment leave it blank, i.e. \{\}.
+ \item \verb|Result of the optimization problem|: optionally a term expressing the result of the optimization problem, e.g. $J(w^*)~=$.
+\end{enumerate}
+
+\noindent Notice that only the first three will be really necessary in every definition, nevertheless and for the sake of having homogeneous definitions, we opted for requiring the 7 parameters in every definition and expecting empty parameters definitions, i.e. \{\}, when they are not needed.
+
+After the definition of this parameters, the environment accepts the definition of an infinite number of constraints. For this definitions the command:
+
+\verb|\addConstraint{LHS Constraint k}|
+
+\verb|{RHS Constraint k \label{Reference Constraint k}}|
+
+\noindent has to be used, where the left hand side and right hand side syntax is the same as used for the mandatory third and fourth environment parameters.
+
+Notice that the last constraint has to be defined using the \verb|\finalConstraint| command, instead of the \verb|\addConstraint|.
+
+\subsubsection{Constraints referencing}
+Notice that the label for the constraints is always included in the right hand side expression and it only makes sense for the case of using the \verb|mini!| enviroment. The label of the objective function can also be included in a similar way.
+
+\subsubsection{Example 1 - mini environment}
+The code:
+
+\begin{verbatim}
+\begin{mini}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+
+ {\label{eq:Example1}}
+ {}
+
+ \addConstraint{n(w)}{= 6}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{mini}
+\end{verbatim}
+
+\noindent outputs:
+
+\begin{mini}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+ {\label{eq:Ex1}}{}
+ \addConstraint{n(w)}{= 6}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{mini}
+
+\subsubsection{Example 2 - mini* environment}
+
+On the other hand:
+
+\begin{verbatim}
+\begin{mini*}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0,}
+
+ {}{}
+
+ \addConstraint{n(w)}{= 6,}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{mini*}
+\end{verbatim}
+
+\noindent it is almost the same but removing the reference:
+
+\begin{mini*}{3}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0,}
+ {}{}
+ \addConstraint{n(w)}{= 6, }
+ \addConstraint{L(w)+r(x)}{=Kw+p, }
+ \finalConstraint{h(x)}{=0.}
+\end{mini*}
+
+\subsubsection{Example 3 - mini! environment}
+
+\noindent Finally, the multireferencing environment outputs:
+
+\begin{verbatim}
+\begin{mini!}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R \label{eq:ObjectiveExample1}}
+ {g(w)}{=0 \label{eq:C1Example1}}
+
+ {\label{eq:Example1}}
+ {}
+
+ \addConstraint{n(w)}{= 6 \label{eq:C2Example1}}
+ \addConstraint{L(w)+r(x)}{=Kw+p \label{eq:C3Example1}}
+ \finalConstraint{h(x)}{=0. \label{eq:C4Example1}}
+\end{mini!}
+\end{verbatim}
+
+\begin{mini!}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R\label{eq:ObjectiveExample3}}
+ {g(w)}{=0 \label{eq:C1Example3}}
+ {\label{eq:Example3}}
+ {}
+ \addConstraint{n(w)}{= 6 \label{eq:C2Example3}}
+ \addConstraint{L(w)+r(x)}{=Kw+p \label{eq:C3Example3}}
+ \finalConstraint{h(x)}{=0. \label{eq:C4Example3}}
+\end{mini!}
+
+\subsubsection{Example 4 - mini + problem result}
+
+\noindent Adding the problem result:
+
+\begin{verbatim}
+\begin{mini}{4}
+{w}{f(w)+ R(w+6x) + \nabla_w R}
+{g(w)}{=0}
+
+{\label{eq:Example1}}
+{J(w^*)=}
+
+\addConstraint{n(w)}{= 6}
+\addConstraint{L(w)+r(x)}{=Kw+p}
+\finalConstraint{h(x)}{=0.}
+\end{mini}
+\end{verbatim}
+
+\noindent outputs:
+
+\begin{mini}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+ {\label{eq:Ex1}}{J(w^*)~=~}
+ \addConstraint{n(w)}{= 6}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{mini}
+
+\subsubsection{Example 5 - mini* + extra constraint alignment}
+Adding the fourth optional alignment to add constraint names:
+
+\begin{verbatim}
+\begin{mini*}{4}
+{w}{f(w)+ R(w+6x) + \nabla_w R}
+{g(w)}{=0, \quad && \text{(Dynamic constraint)}}
+
+{}{}
+
+\addConstraint{n(w)}{= 6, \quad && \text{(Boundary constraint)}}
+\addConstraint{L(w)+r(x)}{=Kw+p, \quad && \text{(Random constraint)}}
+\finalConstraint{h(x)}{=0.\quad && \text{(Path constraint)}}
+\end{mini*}
+\end{verbatim}
+
+
+\begin{mini*}{3}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0, \quad && \text{(Dynamic constraint)}}
+ {}{}
+ \addConstraint{n(w)}{= 6, \quad && \text{(Boundary constraint)}}
+ \addConstraint{L(w)+r(x)}{=Kw+p, \quad && \text{(Random constraint)}}
+ \finalConstraint{h(x)}{=0. \quad && \text{(Path constraint).}}
+\end{mini*}
+
+
+\subsubsection{Example 6 - mini environment on the unconstrained case}
+
+\begin{verbatim}
+
+\begin{mini}{0}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {}{}
+ {}{}
+ {\label{eq:Ex4}}
+ {}
+\end{mini}
+\end{verbatim}
+
+\noindent outputs:
+
+\begin{mini}{0}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {}{}
+ {\label{eq:Ex4}}{}
+\end{mini}
+
+\section{The \textit{argmini} environment}
+ Similar to the \verb|mini|, \verb|mini*| and \verb|mini!| environments, the environments \verb|argmini|, \verb|argmini*| and \verb|argmini!| are very similar environments that use the same syntax but the output is slightly different. The following code serves for illustration:
+
+\begin{verbatim}
+\begin{argmini}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+
+ {\label{eq:Example1}}{w^*=}
+
+ \addConstraint{n(w)}{= 6}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{argmini}
+\end{verbatim}
+
+\noindent outputs:
+
+\begin{argmini}{3}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+ {\label{eq:Ex1}}{w^*~=~}
+ \addConstraint{n(w)}{= 6}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{argmini}
+
+\section{The \textit{maxi} and \textit{argmaxi} environments}
+Exactly the same syntax and definition as the previous environments, but now for defining maximization environments. The following code serves for illustration:
+
+\begin{verbatim}
+\begin{maxi}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+
+ {\label{eq:Example1}}{}
+
+ \addConstraint{n(w)}{= 6}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{maxi}
+\end{verbatim}
+
+\noindent outputs:
+
+\begin{maxi}{4}
+ {w}{f(w)+ R(w+6x) + \nabla_w R}
+ {g(w)}{=0}
+ {\label{eq:Example1}}{}
+ \addConstraint{n(w)}{= 6}
+ \addConstraint{L(w)+r(x)}{=Kw+p}
+ \finalConstraint{h(x)}{=0.}
+\end{maxi}
+
+
+\section{Problems and limitations}
+One current limitation is that the size of the optimization variables must be smaller than the word minimize, otherwise, the output is not properly aligned. Example:
+
+\begin{mini!}{3}
+ {x_0,u_0,x_1,\hdots,u_{N-1},x_N}
+ {\sum_{k=0}^{N-1} L(x_k,u_k)\!\!+\!\!E(x_N)\label{OCPobj}}
+ {x_{k+1}-f(x_k,u_k)}{= 0, \label{dOCP:modelc}\quad k=0,\dots,N-1}
+ {\label{eq:OCP}}{}
+ \addConstraint{h(x_k,u_k)}{\leq 0, \quad k=0,\dots,N-1}
+ \finalConstraint{r(x_0,x_N)}{= 0. \label{dOCP:boundary}}
+\end{mini!}
+
+\noindent A possible way to avoid this is to stack them with the command: \begin{verbatim}
+\substack{x_0,u_0,x_1,\hdots,\\u_{N-1},x_N}
+\end{verbatim}
+
+\begin{mini!}{3}
+ {\substack{x_0,u_0,x_1,\hdots,\\ u_{N-1},x_N}}
+ {\sum_{k=0}^{N-1} L(x_k,u_k)\!\!+\!\!E(x_N)\label{OCPobj}}
+ {x_{k+1}-f(x_k,u_k)}{= 0, \label{dOCP:modelc}\quad k=0,\dots,N-1}
+ {\label{eq:OCP}}{}
+ \addConstraint{h(x_k,u_k)}{\leq 0, \quad k=0,\dots,N-1}
+ \finalConstraint{r(x_0,x_N)}{= 0. \label{dOCP:boundary}}
+\end{mini!}
+
+\noindent If you want to increase the size of the optimization variables:
+\noindent A possible way to avoid this is to stack them with the command: \begin{verbatim}
+\substack{\displaystyle x_0,u_0,x_1,\hdots,\\ \displaystyle u_{N-1},x_N}
+\end{verbatim}
+
+\begin{mini!}{3}
+ {\substack{\displaystyle x_0,u_0,x_1,\hdots,\\ \displaystyle u_{N-1},x_N}}
+ {\sum_{k=0}^{N-1} L(x_k,u_k)\!\!+\!\!E(x_N)\label{OCPobj}}
+ {x_{k+1}-f(x_k,u_k)}{= 0, \label{dOCP:modelc}\quad k=0,\dots,N-1}
+ {\label{eq:OCP}}{}
+ \addConstraint{h(x_k,u_k)}{\leq 0, \quad k=0,\dots,N-1}
+ \finalConstraint{r(x_0,x_N)}{= 0. \label{dOCP:boundary}}
+\end{mini!}
+
+The other option is to define the set of variables before the problem definition as a single variable, i.e. $w = [x_0,u_0,x_1,\hdots,u_{N-1},x_N]$ and:
+
+%\begin{mini3!}
+% {w}
+% {\sum_{k=0}^{N-1} L(x_k,u_k)\!\!+\!\!E(x_N)}{\label{OCPobj}}
+% {x_{k+1}-f(x_k,u_k)}{= 0, \label{dOCP:modelc}\quad k=0,\dots,N-1}
+% {h(x_k,u_k)} {\leq 0, \quad k=0,\dots,N-1}
+% {r(x_0,x_N)}{= 0. \label{dOCP:boundary}}
+% \label{eq:OCP}
+%\end{mini3!}
+
+\section{Code definition}
+\begin{verbatim}
+% optidef - Version 08/06/2016
+%
+%Copyright 2016 J. Lago Garcia
+%
+%This work may be distributed and/or modified under the conditions of the LaTeX Project Public License, either version 1.3 of this license or (at your option) any later version.
+%The latest version of this license is in http://www.latex-project.org/lppl.txt and version 1.3 or later is part of all distributions of LaTeX version 2005/12/01 or later.
+%
+%This work has the LPPL maintenance status 'maintained'. The Current Maintainer of this work is J. Lago Garcia, under the supervision of Prof. Dr. Moritz Diehl and Prof. Dr. Sebastien Gross.
+%
+%E-mail: jesus.lago.garcia at venus.uni-freiburg.de
+%
+%This work consists of the file optidef.sty.
+
+ \NeedsTeXFormat{LaTeX2e}
+ \ProvidesPackage{optidef}[2016/06/06 Package for defining optimization problems]
+
+ \RequirePackage{environ}
+ \RequirePackage{ifthen}
+ \RequirePackage{mathtools}
+ \RequirePackage{xifthen}
+
+ % Input minimization evironments
+
+ % Macros for objective definition, constraint definition and extra constraint definition
+ \newcommand{\bodyobj}[4]
+ {
+ \ifthenelse{\isempty{#4}}
+ {
+ &\underset{\displaystyle #1}{\mbox{#3}} \quad #2\span\span\span\span
+ }
+ {
+ #4 ~~ &\underset{\displaystyle #1}{\mbox{#3}} \quad #2\span\span\span\span
+ }
+ }
+
+
+ \newcommand{\bodyconst}[2]
+ {&\mbox{subject to} \quad  & #2\span\span}
+
+ \newcommand{\addConstraint}[2]{&\quad  & #2, \\}
+ \newcommand{\finalConstraint}[2]{&\quad  & #2}
+
+
+ %\newcommand(\breakObjectiveUnconstraint)[1]{\\%
+ %\bodyobjUn{}{#1}{\phantom{minimize}}{}}
+ \newcommand{\breakObjectiveOneConstraint}[1]{&&\\}
+ %\newcommand(\breakObjective)[1]{\bodyobj{}{#4}{\phantom{minimize}}{}\nonumber\\} }
+
+ \newcommand{\bodyconstOne}[2]
+ {&\text{subject to} \quad & #2}
+
+ % This body of the objective is only valid for
+ % one constraint problem since there is no need to
+ % use mathllap to achieve second alignment level
+ \newcommand{\bodyobjOne}[4]
+ {
+ \ifthenelse{\isempty{#4}}
+ {
+ &\underset{\displaystyle #1}{\text{#3}} \quad &
+ }
+ {
+ #4 ~~ &\underset{\displaystyle #1}{\text{#3}} \quad &}
+ }
+
+
+ % This body of the objective is only valid for
+ % no constraint problem since there is no need to
+ % align
+ \newcommand{\bodyobjUn}[4]
+ {
+ \ifthenelse{\isempty{#4}}
+ {
+ }
+ {
+ #4~
+ }
+ \underset{\displaystyle #1}{\text{#3}} \quad #2
+ }
+
+ %MINIMIZATION ENVIRONMENTS
+
+ \NewEnviron{mini}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{minimize}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{minimize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{minimize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmini}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{arg min}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{arg min}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{arg min}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{mini*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{minimize}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{minimize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{5}
+ \bodyobj{#2}{#3}{minimize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmini*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{arg min}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{arg min}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{4}
+ \bodyobj{#2}{#3}{arg min}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+
+ \NewEnviron{mini!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{minimize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{minimize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
+
+ \NewEnviron{argmini!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{arg min}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{arg min}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
+
+ %MAXIMIZATION ENVIRONMENTS
+
+ \NewEnviron{maxi}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{maximize}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{maximize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{maximize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmaxi}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{arg max}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{arg max}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{arg max}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{maxi*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{maximize}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{maximize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{5}
+ \bodyobj{#2}{#3}{maximize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmaxi*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{arg max}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{arg max}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{4}
+ \bodyobj{#2}{#3}{arg max}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+
+ \NewEnviron{maxi!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{maximize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{maximize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
+
+ \NewEnviron{argmaxi!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{arg max}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{arg max}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
+\end{verbatim}
+
+\end{document}
Property changes on: trunk/Master/texmf-dist/doc/latex/optidef/optidef.tex
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Added: trunk/Master/texmf-dist/tex/latex/optidef/optidef.sty
===================================================================
--- trunk/Master/texmf-dist/tex/latex/optidef/optidef.sty (rev 0)
+++ trunk/Master/texmf-dist/tex/latex/optidef/optidef.sty 2016-06-09 22:53:41 UTC (rev 41330)
@@ -0,0 +1,383 @@
+% optidef - Version 08/06/2016
+%
+%Copyright 2016 J. Lago Garcia
+%
+%This work may be distributed and/or modified under the conditions of the LaTeX Project Public License, either version 1.3 of this license or (at your option) any later version.
+%The latest version of this license is in http://www.latex-project.org/lppl.txt and version 1.3 or later is part of all distributions of LaTeX version 2005/12/01 or later.
+%
+%This work has the LPPL maintenance status 'maintained'. The Current Maintainer of this work is J. Lago Garcia, under the supervision of Prof. Dr. Moritz Diehl and Prof. Dr. Sebastien Gross.
+%
+%E-mail: jesus.lago.garcia at venus.uni-freiburg.de
+%
+%This work consists of the file optidef.sty.
+
+\NeedsTeXFormat{LaTeX2e}
+\ProvidesPackage{optidef}[2016/06/06 Package for defining optimization problems]
+
+\RequirePackage{environ}
+\RequirePackage{mathtools}
+\RequirePackage{xifthen}
+
+ % Input minimization evironments
+
+ % Macros for objective definition, constraint definition and extra constraint definition
+ \newcommand{\bodyobj}[4]
+ {
+ \ifthenelse{\isempty{#4}}
+ {
+ &\underset{\displaystyle #1}{\mbox{#3}} \quad #2\span\span\span\span
+ }
+ {
+ #4 ~~ &\underset{\displaystyle #1}{\mbox{#3}} \quad #2\span\span\span\span
+ }
+ }
+
+
+ \newcommand{\bodyconst}[2]
+ {&\mbox{subject to} \quad  & #2\span\span}
+
+ \newcommand{\addConstraint}[2]{&\quad  & #2, \\}
+ \newcommand{\finalConstraint}[2]{&\quad  & #2}
+
+
+ %\newcommand(\breakObjectiveUnconstraint)[1]{\\%
+ %\bodyobjUn{}{#1}{\phantom{minimize}}{}}
+ \newcommand{\breakObjectiveOneConstraint}[1]{&&\\}
+ %\newcommand(\breakObjective)[1]{\bodyobj{}{#4}{\phantom{minimize}}{}\nonumber\\} }
+
+ \newcommand{\bodyconstOne}[2]
+ {&\text{subject to} \quad & #2}
+
+ % This body of the objective is only valid for
+ % one constraint problem since there is no need to
+ % use mathllap to achieve second alignment level
+ \newcommand{\bodyobjOne}[4]
+ {
+ \ifthenelse{\isempty{#4}}
+ {
+ &\underset{\displaystyle #1}{\text{#3}} \quad &
+ }
+ {
+ #4 ~~ &\underset{\displaystyle #1}{\text{#3}} \quad &}
+ }
+
+
+ % This body of the objective is only valid for
+ % no constraint problem since there is no need to
+ % align
+ \newcommand{\bodyobjUn}[4]
+ {
+ \ifthenelse{\isempty{#4}}
+ {
+ }
+ {
+ #4~
+ }
+ \underset{\displaystyle #1}{\text{#3}} \quad #2
+ }
+
+ %MINIMIZATION ENVIRONMENTS
+
+ \NewEnviron{mini}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{minimize}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{minimize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{minimize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmini}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{arg min}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{arg min}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{arg min}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{mini*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{minimize}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{minimize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{5}
+ \bodyobj{#2}{#3}{minimize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmini*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{arg min}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{arg min}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{4}
+ \bodyobj{#2}{#3}{arg min}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+
+ \NewEnviron{mini!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{minimize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{minimize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
+
+ \NewEnviron{argmini!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{arg min}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{arg min}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
+
+ %MAXIMIZATION ENVIRONMENTS
+
+ \NewEnviron{maxi}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{maximize}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{maximize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{maximize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmaxi}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation}
+ #6
+ \bodyobjUn{#2}{#3}{arg max}{#7}
+ \end{equation}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{equation}
+ #6
+ \begin{alignedat}{3}
+ \bodyobjOne{#2}{#3}{arg max}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignedat}
+ \end{equation}
+ }%
+ {%
+ \begin{equation}
+ #6
+ \begin{alignedat}{4}
+ \bodyobj{#2}{#3}{arg max}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignedat}
+ \end{equation}
+ }%
+ }%
+ }
+
+ \NewEnviron{maxi*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{maximize}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{maximize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{5}
+ \bodyobj{#2}{#3}{maximize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+ \NewEnviron{argmaxi*}[7]{%
+ \ifthenelse{\equal{#1}{0}}{%
+ \begin{equation*}
+ \bodyobjUn{#2}{#3}{arg max}{#7}
+ \end{equation*}
+ }%
+ {%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{alignat*}{3}
+ \bodyobjOne{#2}{#3}{arg max}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat*}
+ }%
+ {%
+ \begin{alignat*}{4}
+ \bodyobj{#2}{#3}{arg max}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat*}
+ }%
+ }%
+ }
+
+
+ \NewEnviron{maxi!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{maximize}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{maximize}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
+
+ \NewEnviron{argmaxi!}[7]{%
+ \ifthenelse{\equal{#1}{1}}{%
+ \begin{subequations}
+ #6
+ \begin{alignat}{3}
+ \bodyobjOne{#2}{#3}{arg max}{#7}\\
+ \bodyconstOne{#4}{#5}
+ \end{alignat}
+ \end{subequations}
+ }%
+ {%
+ \begin{subequations}
+ #6
+ \begin{alignat}{4}
+ \bodyobj{#2}{#3}{arg max}{#7}\\
+ \bodyconst{#4}{#5,} \\
+ \BODY
+ \end{alignat}
+ \end{subequations}
+ }%
+ }
\ No newline at end of file
Property changes on: trunk/Master/texmf-dist/tex/latex/optidef/optidef.sty
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Modified: trunk/Master/tlpkg/bin/tlpkg-ctan-check
===================================================================
--- trunk/Master/tlpkg/bin/tlpkg-ctan-check 2016-06-09 22:52:48 UTC (rev 41329)
+++ trunk/Master/tlpkg/bin/tlpkg-ctan-check 2016-06-09 22:53:41 UTC (rev 41330)
@@ -423,7 +423,7 @@
ocg-p ocgx ocgx2 ocherokee ocr-b ocr-b-outline ocr-latex octavo
odsfile ofs
ogham oinuit old-arrows oldlatin oldstandard oldstyle
- onlyamsmath onrannual opcit opensans opteng optional options
+ onlyamsmath onrannual opcit opensans opteng optidef optional options
ordinalpt orkhun oscola ot-tableau othello othelloboard
oubraces outline outliner outlines overlock overpic
pacioli pagecolor pagecont pagenote pagerange pageslts
Modified: trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc
===================================================================
--- trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc 2016-06-09 22:52:48 UTC (rev 41329)
+++ trunk/Master/tlpkg/tlpsrc/collection-latexextra.tlpsrc 2016-06-09 22:53:41 UTC (rev 41330)
@@ -717,6 +717,7 @@
depend oldstyle
depend onlyamsmath
depend opcit
+depend optidef
depend optional
depend options
depend outline
Added: trunk/Master/tlpkg/tlpsrc/optidef.tlpsrc
===================================================================
More information about the tex-live-commits
mailing list