\newglossaryentry{gls:graphical-model}
{
        name={
            graphical model        },
        description={
            ($\MDef$). Mathematical tool for modeling complex systems composed of a set of variables $\X$, a set of domains $\D = \{ D_{X} | X \in \X \}$ for each variable $X$, and a set of functions $\F$ with each function defined over a subset of the model's variables $\alpha \subseteq \X$.
        }
}


\newglossaryentry{gls:osprey}
{
        name={
            OSPREY        },
        description={
            (Open Source Protein Engineering Software). A computational tool for protein design developed by the Bruce Donald Lab at Duke University, first released in 2010. \citep{hallen18-osprey-3}
        }
}

\newglossaryentry{gls:variable-elimination}
{
        name={
            variable elimination        },
        description={
            (VE). An inference technique that involves an ordered computational processing of variables, each elimination step removing the processed variable from the resulting expression.
        }
}

\newglossaryentry{gls:primal-graph}
{
        name={
            primal graph        },
        description={
            The primal graph of a graphical model captures an underlying structure of the model, where each node corresponds to a random variable of the model and edges connect any two variables that are both part of a function's scope thus indicating direct dependencies between variables.
        }
}


\newglossaryentry{gls:tau-underflowed-function}
{
        name={
            $\tau$-underflowed function        },
        description={
            ($\ftau$) A function such that output values less than $\tau$ are replaced with $0.0$.
            \begin{align*}
              f_{\alpha_{\tau}}(\bs{a} \in D_{\alpha}) = \begin{cases}
                f_{\alpha}(\bs{a}),& f_{\alpha}(\bs{a}) \geq \tau\\
                0,                & \textnormal{otherwise}.
              \end{cases}
            \end{align*}
        }
}

\newglossaryentry{gls:tau-underflowed-model}
{
        name={
            $\tau$-underflowed model        },
        description={
            ($\MtauDef$)  A model with each of its functions replaced with the corresponding \gls{gls:tau-underflowed-function}.
        }
}

\newglossaryentry{gls:tau-underflow}
{
        name={
            $\tau$-underflow        },
        description={
            See \gls{gls:tau-underflowed-function} and \gls{gls:tau-underflowed-model}.
        }
}

\newglossaryentry{gls:thresholded-underflow}
{
        name={
            thresholded-underflow        },
        description={
            See \gls{gls:tau-underflowed-function} and \gls{gls:tau-underflowed-model}.
        }
}

\newglossaryentry{gls:underflow-threshold}
{
        name={
            underflow-threshold        },
        description={
            ($\tau$)  A value $\tau \in (0,\infty)$ used to underflow functions (see \gls{gls:tau-underflowed-function} and \gls{gls:tau-underflowed-model}).
        }
}



\newglossaryentry{gls:configuration}
{
        name={
            configuration        },
        description={
            A joint assignment to a set of variables.  (See \gls{gls:full-configuration} and \gls{gls:partial-configuration} for more specific uses of the term).  
        }
}

\newglossaryentry{gls:partition-function}
{
        name={
            partition function        },
        description={
            (Z). A mathematical quantity that characterizes the distribution among a system's possible states and serves as a normalizing constant for calculating probabilistic measures associated with these states.\\
            In the context of discrete graphical models, $Z = \sum_{\X} \prod_{f_{\alpha} \in \F} f_{\alpha}(\xx)$.
        }
}

\newglossaryentry{gls:most-probable-explanation}
{
        name={
            most probable explanation        },
        description={
            (MPE). Assignment to variables the variables of a graphical model that maximizes the conditional probability of the observed evidence.\\
            In the context of discrete graphical models without any evidence, $MPE = \argmax_{\Q = \X} \prod_{f_{\alpha} \in \F} f_{\alpha}(\qq)$.
        }
}

\newglossaryentry{gls:maximum-a-posteriori}
{
        name={
            maximum a-posteriori        },
        description={
            (MAP). With respect to a graphical model, the likelihood value associated with the \gls{gls:most-probable-explanation} or \gls{abrv:MPE}.\\
            In the context of discrete graphical models without evidence, $MAP = \max_{\Q = \X} \prod_{f_{\alpha} \in \F} f_{\alpha}(\qq)$.
        }
}


\newglossaryentry{gls:marginal-maximum-a-posteriori}
{
        name={
            marginal maximum a-posteriori        },
        description={
            (MMAP). The marginal likelihood associated with the configuration of a target subset of variables $\Q$ that maximizes their marginal likelihood.\\
            In the context of discrete graphical models without evidence, with $\Q \subset \X$, $\SSS = \X \setminus \Q$ be the variables to sum over, $\FQ = \{ \falpha \;|\; \alpha \subseteq \Q \}$ be the set of functions defined only over $\alpha \in \Q$, and $\FS = \F \setminus \FQ$ be functions that include some $X \in \SSS$ in their scope,
            \begin{align}
              MMAP  
                    =& \max_{\Q} \sum_{\SSS} \prod_{f_{\alpha} \in \F} f_{\alpha}(\qq \cup \ssss)\\
                    =& \max_{\Q}  \prod_{f_{\alpha}' \in \FS} f_{\alpha}'(\qq) \sum_{\SSS} \prod_{f_{\alpha}'' \in \FS} f_{\alpha}''(\qq \cup \ssss)
            \end{align}
        }
}


\newglossaryentry{gls:de-novo-protein-design}
{
        name={
            \textit{de novo} protein design        },
        sort={de-novo protein design},
        description={
            The process of creating novel proteins in order to achieve desired criteria without relying on existing protein templates, using computational or experimental approaches.
        }
}

\newglossaryentry{gls:protein-re-design}
{
        name={
            protein re-design        },
        description={
            The process of modifying existing protein sequences or structures to enhance or alter their function, stability, or other desired properties using computational or experimental approaches.
        }
}

\newglossaryentry{gls:full-configuration}
{
        name={
            full configuration        },
        description={
            A joint assignment to all the variables of a graphical model.
        }
}

\newglossaryentry{gls:partial-configuration}
{
        name={
            partial configuration        },
        description={
            A joint assignment to a subset of the variables of a graphical model.
        }
}

\newglossaryentry{gls:conformation}
{
        name={
            conformation        },
        description={
            The three-dimensional orientation of a molecule.
        }
}

\newglossaryentry{gls:scope}
{
        name={
            scope        },
        description={
            The set of variables a function is defined over.  Denoted as $\alpha$ in the general case.
        }
}

\newglossaryentry{gls:computational-protein-design}
{
        name={
            computational protein design        },
        description={
            The process of using computational methods and algorithms to create novel protein sequences or structures with desired properties.
        }
}

\newglossaryentry{gls:elimination-order}
{
        name={
            elimination order        },
        description={
            Order in which to process and eliminate variables during variable elimination inference.
        }
}

\newglossaryentry{gls:bucket-elimination}
{
        name={
            bucket elimination        },
        description={
            A variable elimination framework that uses a dynamic programming approach leveraging commutability of mathematical expressions.
        }
}

\newglossaryentry{gls:constrained-ordering}
{
        name={
            constrained ordering        },
        description={
            An elmination ordering that satisfies given constraints for some variables to be eliminated before others.
        }
}

\newglossaryentry{gls:bucket}
{
        name={
            bucket        },
        description={
            Data structure used in \gls{gls:bucket-elimination}, each corresponding to a particular variable to be eliminated, that collects functions to be processed during an elimination step.  Processing of a bucket involves applying an elimination operator (such as maximization or marginalization) over the bucket's variable to the combined functions of the bucket.
        }
}

\newglossaryentry{gls:bucket-message}
{
        name={
            bucket message        },
        description={
            The function resulting after processing of a bucket during a \gls{gls:bucket-elimination} elimination step.
        }
}

\newglossaryentry{gls:bucket-tree}
{
        name={
            bucket tree        },
        description={
            In the context of \gls{gls:bucket-elimination}: A directed tree with nodes corresponding to buckets and directed edges corresponding to the origin and destination of computed messages.
        }
}

\newglossaryentry{gls:induced-width}
{
        name={
            induced width        },
        description={
            ($w^{*}$) One less than the largest clique size of the \gls{gls:induced-primal-graph}.
        }
}

\newglossaryentry{gls:induced-graph}
{
        name={
            induced graph        },
        description={
            \Gls{gls:induced-primal-graph}.
        }
}

\newglossaryentry{gls:induced-primal-graph}
{
        name={
            induced primal graph        },
        description={
            With respect to a variable elimination procedure: the primal graph of a graphical model augmented with additional edges corresponding to the scope of messages created through the variable elimination procedure.
        }
}

\newglossaryentry{gls:heuristic-proportionality-value}
{
        name={
            heuristic proportionality value        },
        description={
            (\hprop{h})  For a given heuristic value $h$ whose estimate is for a value $v^{*}$, the heuristic proportionality value is defined as $\hprop{h} = \frac{h}{v^{*}}$
        }
}

\newglossaryentry{gls:heuristic-proportionality-value-of-a-node}
{
        name={
            heuristic proportionality value of a node        },
        description={
            (\hpropn{h}{n})  For a given search node $n$ having an associated heuristic value $h(n)$ which estimates the subproblem value of the node $v^{*}(n)$, the heuristic proportionality value of the node $n$ is defined as $\hpropn{h}{n} = \frac{h(n)}{v^{*}(n)}$.  See also \gls{gls:heuristic-proportionality-value}.
        }
}