% \documentclass{uai2022} % for initial submission
\documentclass[accepted]{uai2022} % after acceptance, for a revised
                                    % version; also before submission to
                                    % see how the non-anonymous paper
                                    % would look like
%% There is a class option to choose the math font
% \documentclass[mathfont=ptmx]{uai2022} % ptmx math instead of Computer
                                         % Modern (has noticable issues)
% \documentclass[mathfont=newtx]{uai2022} % newtx fonts (improves upon
                                          % ptmx; less tested, no support)
% NOTE: Only keep *one* line above as appropriate, as it will be replaced
%       automatically for papers to be published. Do not make any other
%       change above this note for an accepted version.

%% Choose your variant of English; be consistent
\usepackage[american]{babel}
% \usepackage[british]{babel}

%% Some suggested packages, as needed:
\usepackage{natbib} % has a nice set of citation styles and commands
    \bibliographystyle{plainnat}
    \renewcommand{\bibsection}{\subsubsection*{References}}
\usepackage{mathtools} % amsmath with fixes and additions
% \usepackage{siunitx} % for proper typesetting of numbers and units
\usepackage{booktabs} % commands to create good-looking tables
\usepackage{tikz} % nice language for creating drawings and diagrams

\usepackage[FIGBOTCAP,TABBOTCAP,center,nooneline]{subfigure}
\usepackage[dvips]{rotating}
\usepackage[noend]{RSalgorithmic}
\usepackage{algorithm}
\usepackage{amscd}
\usepackage{amsfonts}
%\usepackage{amsmath}
\usepackage{amssymb}
%\usepackage{booktabs}
\usepackage{color}
\usepackage{comment}
\usepackage{datetime}
\usepackage{epsfig}
%\usepackage{graphicx}
%\usepackage{ifthen}
\usepackage{xifthen}
%\usepackage{etoolbox}
\usepackage{latexsym}
\usepackage{marginnote}
\usepackage{multirow}
\usepackage{placeins}
\usepackage{rotate} 
\usepackage{stmaryrd}
\usepackage{tikz}
\usepackage[draft]{todonotes}
%\usepackage{url}
\usepackage{varwidth}
\usepackage{verbatim} 
\usepackage{wrapfig}
\usepackage{xcolor,colortbl}
\usepackage{xspace}

\usepackage[dvips]{rotating}
\usepackage[noend]{RSalgorithmic}
\usepackage{algorithm}
\usepackage{amscd}
\usepackage{amsfonts}
%\usepackage{amsmath}
\usepackage{amssymb}
%\usepackage{booktabs}
\usepackage{color}
\usepackage{comment}
\usepackage{datetime}
\usepackage{epsfig}
%\usepackage{graphicx}
\usepackage{ifthen}
\usepackage{latexsym}
\usepackage{marginnote}
\usepackage{multirow}
\usepackage{placeins}
\usepackage{rotate} 
\usepackage{stmaryrd}
\usepackage{tikz}
%\usepackage{url}
\usepackage{varwidth}
\usepackage{verbatim} 
\usepackage{wrapfig}
\usepackage{xcolor,colortbl}
\usepackage{xspace}
\usepackage{caption}
%\usepackage{subcaption}
\usepackage{colour-blind}
\usepackage{lipsum}  

%% Provided macros
% \smaller: Because the class footnote size is essentially LaTeX's \small,\usepackage[FIGBOTCAP,TABBOTCAP,center,nooneline]{subfigure}
\usepackage[dvips]{rotating}
\usepackage[noend]{RSalgorithmic}
\usepackage{algorithm}
\usepackage{amscd}
\usepackage{amsfonts}
%\usepackage{amsmath}
\usepackage{amssymb}
%\usepackage{booktabs}
\usepackage{color}
\usepackage{comment}
\usepackage{datetime}
\usepackage{epsfig}
%\usepackage{graphicx}
%\usepackage{ifthen}
\usepackage{xifthen}
%\usepackage{etoolbox}
\usepackage{latexsym}
\usepackage{marginnote}
\usepackage{multirow}
\usepackage{placeins}
\usepackage{rotate} 
\usepackage{stmaryrd}
\usepackage{tikz}
\usepackage[draft]{todonotes}
%\usepackage{url}
\usepackage{varwidth}
\usepackage{verbatim} 
\usepackage{wrapfig}
\usepackage{xcolor,colortbl}
\usepackage{xspace}

\usepackage[dvips]{rotating}
\usepackage[noend]{RSalgorithmic}
\usepackage{algorithm}
\usepackage{amscd}
\usepackage{amsfonts}
%\usepackage{amsmath}
\usepackage{amssymb}
%\usepackage{booktabs}
\usepackage{color}
\usepackage{comment}
\usepackage{datetime}
\usepackage{epsfig}
%\usepackage{graphicx}
\usepackage{ifthen}
\usepackage{latexsym}
\usepackage{marginnote}
\usepackage{multirow}
\usepackage{placeins}
\usepackage{rotate} 
\usepackage{stmaryrd}
\usepackage{tikz}
%\usepackage{url}
\usepackage{varwidth}
\usepackage{verbatim} 
\usepackage{wrapfig}
\usepackage{xcolor,colortbl}
\usepackage{xspace}
\usepackage{caption}
%\usepackage{subcaption}
\usepackage{colour-blind}
\usepackage{lipsum}  
%           redefining \footnotesize, we provide the original \footnotesize
%           using this macro.
%           (Use only sparingly, e.g., in drawings, as it is quite small.)

\newtheorem{example}{Example}
\newtheorem{theorem}{Theorem}

%% Self-defined macros
\newcommand{\swap}[3][-]{#3#1#2} % just an example


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%% This file is an hard link, whose source is in   
%%%%%%% cipeciop.science.unitn.it:/home/rseba/latex/macros
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% general-use macros 
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%% rgb.tex
%% this file defines the X11 rgb color names for use with pstricks
%% put \usepackage{pstricks, pstcol} in the preamble of your document
%% the put \input{rgb.tex} in the body of your document.
%% Color in pstricks works like a switch.  If you enter
%%    The text will become \color{red}red.
%% Then all text after the \color command will printed in red in the
%% postscript file.  You can restrict the range of the red text in this
%% manner
%%    One {\color{red}some text} will be red.
%% The color will NOT show up in the dvi file, only in the .ps file!
%%
%% this file was created by rgb2tex.pl
%% rgb2tex.pl is by Bruce Ravel <bruce.ravel@nist.gov>
%% --------------------------------------------------------------------------

\definecolor {snow}                {rgb}{1.00,0.98,0.98}
\definecolor {ghostwhite}          {rgb}{0.97,0.97,1.00}
\definecolor {whitesmoke}          {rgb}{0.96,0.96,0.96}
\definecolor {gainsboro}           {rgb}{0.86,0.86,0.86}
\definecolor {floralwhite}         {rgb}{1.00,0.98,0.94}
\definecolor {oldlace}             {rgb}{0.99,0.96,0.90}
\definecolor {linen}               {rgb}{0.98,0.94,0.90}
\definecolor {antiquewhite}        {rgb}{0.98,0.92,0.84}
\definecolor {papayawhip}          {rgb}{1.00,0.94,0.84}
\definecolor {blanchedalmond}      {rgb}{1.00,0.92,0.80}
\definecolor {bisque}              {rgb}{1.00,0.89,0.77}
\definecolor {peachpuff}           {rgb}{1.00,0.85,0.73}
\definecolor {navajowhite}         {rgb}{1.00,0.87,0.68}
\definecolor {moccasin}            {rgb}{1.00,0.89,0.71}
\definecolor {cornsilk}            {rgb}{1.00,0.97,0.86}
\definecolor {ivory}               {rgb}{1.00,1.00,0.94}
\definecolor {lemonchiffon}        {rgb}{1.00,0.98,0.80}
\definecolor {seashell}            {rgb}{1.00,0.96,0.93}
\definecolor {honeydew}            {rgb}{0.94,1.00,0.94}
\definecolor {mintcream}           {rgb}{0.96,1.00,0.98}
\definecolor {azure}               {rgb}{0.94,1.00,1.00}
\definecolor {aliceblue}           {rgb}{0.94,0.97,1.00}
\definecolor {lavender}            {rgb}{0.90,0.90,0.98}
\definecolor {lavenderblush}       {rgb}{1.00,0.94,0.96}
\definecolor {mistyrose}           {rgb}{1.00,0.89,0.88}
\definecolor {white}               {rgb}{1.00,1.00,1.00}
\definecolor {black}               {rgb}{0.00,0.00,0.00}
\definecolor {darkslategray}       {rgb}{0.18,0.31,0.31}
\definecolor {dimgray}             {rgb}{0.41,0.41,0.41}
\definecolor {slategray}           {rgb}{0.44,0.50,0.56}
\definecolor {lightslategray}      {rgb}{0.47,0.53,0.60}
\definecolor {gray}                {rgb}{0.75,0.75,0.75}
\definecolor {lightgrey}           {rgb}{0.83,0.83,0.83}
\definecolor {midnightblue}        {rgb}{0.10,0.10,0.44}
\definecolor {navy}                {rgb}{0.00,0.00,0.50}
\definecolor {cornflowerblue}      {rgb}{0.39,0.58,0.93}
\definecolor {darkslateblue}       {rgb}{0.28,0.24,0.55}
\definecolor {slateblue}           {rgb}{0.42,0.35,0.80}
\definecolor {mediumslateblue}     {rgb}{0.48,0.41,0.93}
\definecolor {lightslateblue}      {rgb}{0.52,0.44,1.00}
\definecolor {mediumblue}          {rgb}{0.00,0.00,0.80}
\definecolor {royalblue}           {rgb}{0.25,0.41,0.88}
\definecolor {blue}                {rgb}{0.00,0.00,1.00}
\definecolor {dodgerblue}          {rgb}{0.12,0.56,1.00}
\definecolor {deepskyblue}         {rgb}{0.00,0.75,1.00}
\definecolor {skyblue}             {rgb}{0.53,0.81,0.92}
\definecolor {lightskyblue}        {rgb}{0.53,0.81,0.98}
\definecolor {steelblue}           {rgb}{0.27,0.51,0.71}
\definecolor {lightsteelblue}      {rgb}{0.69,0.77,0.87}
\definecolor {lightblue}           {rgb}{0.68,0.85,0.90}
\definecolor {powderblue}          {rgb}{0.69,0.88,0.90}
\definecolor {paleturquoise}       {rgb}{0.69,0.93,0.93}
\definecolor {darkturquoise}       {rgb}{0.00,0.81,0.82}
\definecolor {mediumturquoise}     {rgb}{0.28,0.82,0.80}
\definecolor {turquoise}           {rgb}{0.25,0.88,0.82}
\definecolor {cyan}                {rgb}{0.00,1.00,1.00}
\definecolor {lightcyan}           {rgb}{0.88,1.00,1.00}
\definecolor {cadetblue}           {rgb}{0.37,0.62,0.63}
\definecolor {mediumaquamarine}    {rgb}{0.40,0.80,0.67}
\definecolor {aquamarine}          {rgb}{0.50,1.00,0.83}
\definecolor {darkgreen}           {rgb}{0.00,0.39,0.00}
\definecolor {darkolivegreen}      {rgb}{0.33,0.42,0.18}
\definecolor {darkseagreen}        {rgb}{0.56,0.74,0.56}
\definecolor {seagreen}            {rgb}{0.18,0.55,0.34}
\definecolor {mediumseagreen}      {rgb}{0.24,0.70,0.44}
\definecolor {lightseagreen}       {rgb}{0.13,0.70,0.67}
\definecolor {palegreen}           {rgb}{0.60,0.98,0.60}
\definecolor {springgreen}         {rgb}{0.00,1.00,0.50}
\definecolor {lawngreen}           {rgb}{0.49,0.99,0.00}
\definecolor {green}               {rgb}{0.00,1.00,0.00}
\definecolor {chartreuse}          {rgb}{0.50,1.00,0.00}
\definecolor {mediumspringgreen}   {rgb}{0.00,0.98,0.60}
\definecolor {greenyellow}         {rgb}{0.68,1.00,0.18}
\definecolor {limegreen}           {rgb}{0.20,0.80,0.20}
\definecolor {yellowgreen}         {rgb}{0.60,0.80,0.20}
\definecolor {forestgreen}         {rgb}{0.13,0.55,0.13}
\definecolor {olivedrab}           {rgb}{0.42,0.56,0.14}
\definecolor {darkkhaki}           {rgb}{0.74,0.72,0.42}
\definecolor {khaki}               {rgb}{0.94,0.90,0.55}
\definecolor {palegoldenrod}       {rgb}{0.93,0.91,0.67}
\definecolor {lightgoldenrodyellow} {rgb}{0.98,0.98,0.82}
\definecolor {lightyellow}         {rgb}{1.00,1.00,0.88}
\definecolor {yellow}              {rgb}{1.00,1.00,0.00}
\definecolor {gold}                {rgb}{1.00,0.84,0.00}
\definecolor {lightgoldenrod}      {rgb}{0.93,0.87,0.51}
\definecolor {goldenrod}           {rgb}{0.85,0.65,0.13}
\definecolor {darkgoldenrod}       {rgb}{0.72,0.53,0.04}
\definecolor {rosybrown}           {rgb}{0.74,0.56,0.56}
\definecolor {indianred}           {rgb}{0.80,0.36,0.36}
\definecolor {saddlebrown}         {rgb}{0.55,0.27,0.07}
\definecolor {sienna}              {rgb}{0.63,0.32,0.18}
\definecolor {peru}                {rgb}{0.80,0.52,0.25}
\definecolor {burlywood}           {rgb}{0.87,0.72,0.53}
\definecolor {beige}               {rgb}{0.96,0.96,0.86}
\definecolor {wheat}               {rgb}{0.96,0.87,0.70}
\definecolor {sandybrown}          {rgb}{0.96,0.64,0.38}
\definecolor {tan}                 {rgb}{0.82,0.71,0.55}
\definecolor {chocolate}           {rgb}{0.82,0.41,0.12}
\definecolor {firebrick}           {rgb}{0.70,0.13,0.13}
\definecolor {brown}               {rgb}{0.65,0.16,0.16}
\definecolor {darksalmon}          {rgb}{0.91,0.59,0.48}
\definecolor {salmon}              {rgb}{0.98,0.50,0.45}
\definecolor {lightsalmon}         {rgb}{1.00,0.63,0.48}
\definecolor {orange}              {rgb}{1.00,0.65,0.00}
\definecolor {darkorange}          {rgb}{1.00,0.55,0.00}
\definecolor {coral}               {rgb}{1.00,0.50,0.31}
\definecolor {lightcoral}          {rgb}{0.94,0.50,0.50}
\definecolor {tomato}              {rgb}{1.00,0.39,0.28}
\definecolor {orangered}           {rgb}{1.00,0.27,0.00}
\definecolor {red}                 {rgb}{1.00,0.00,0.00}
\definecolor {hotpink}             {rgb}{1.00,0.41,0.71}
\definecolor {deeppink}            {rgb}{1.00,0.08,0.58}
\definecolor {pink}                {rgb}{1.00,0.75,0.80}
\definecolor {lightpink}           {rgb}{1.00,0.71,0.76}
\definecolor {palevioletred}       {rgb}{0.86,0.44,0.58}
\definecolor {maroon}              {rgb}{0.69,0.19,0.38}
\definecolor {mediumvioletred}     {rgb}{0.78,0.08,0.52}
\definecolor {violetred}           {rgb}{0.82,0.13,0.56}
\definecolor {magenta}             {rgb}{1.00,0.00,1.00}
\definecolor {violet}              {rgb}{0.93,0.51,0.93}
\definecolor {plum}                {rgb}{0.87,0.63,0.87}
\definecolor {orchid}              {rgb}{0.85,0.44,0.84}
\definecolor {mediumorchid}        {rgb}{0.73,0.33,0.83}
\definecolor {darkorchid}          {rgb}{0.60,0.20,0.80}
\definecolor {darkviolet}          {rgb}{0.58,0.00,0.83}
\definecolor {blueviolet}          {rgb}{0.54,0.17,0.89}
\definecolor {purple}              {rgb}{0.63,0.13,0.94}
\definecolor {mediumpurple}        {rgb}{0.58,0.44,0.86}
\definecolor {thistle}             {rgb}{0.85,0.75,0.85}
\definecolor {snow2}               {rgb}{0.93,0.91,0.91}
\definecolor {snow3}               {rgb}{0.80,0.79,0.79}
\definecolor {snow4}               {rgb}{0.55,0.54,0.54}
\definecolor {seashell2}           {rgb}{0.93,0.90,0.87}
\definecolor {seashell3}           {rgb}{0.80,0.77,0.75}
\definecolor {seashell4}           {rgb}{0.55,0.53,0.51}
\definecolor {antiquewhite1}       {rgb}{1.00,0.94,0.86}
\definecolor {antiquewhite2}       {rgb}{0.93,0.87,0.80}
\definecolor {antiquewhite3}       {rgb}{0.80,0.75,0.69}
\definecolor {antiquewhite4}       {rgb}{0.55,0.51,0.47}
\definecolor {bisque2}             {rgb}{0.93,0.84,0.72}
\definecolor {bisque3}             {rgb}{0.80,0.72,0.62}
\definecolor {bisque4}             {rgb}{0.55,0.49,0.42}
\definecolor {peachpuff2}          {rgb}{0.93,0.80,0.68}
\definecolor {peachpuff3}          {rgb}{0.80,0.69,0.58}
\definecolor {peachpuff4}          {rgb}{0.55,0.47,0.40}
\definecolor {navajowhite2}        {rgb}{0.93,0.81,0.63}
\definecolor {navajowhite3}        {rgb}{0.80,0.70,0.55}
\definecolor {navajowhite4}        {rgb}{0.55,0.47,0.37}
\definecolor {lemonchiffon2}       {rgb}{0.93,0.91,0.75}
\definecolor {lemonchiffon3}       {rgb}{0.80,0.79,0.65}
\definecolor {lemonchiffon4}       {rgb}{0.55,0.54,0.44}
\definecolor {cornsilk2}           {rgb}{0.93,0.91,0.80}
\definecolor {cornsilk3}           {rgb}{0.80,0.78,0.69}
\definecolor {cornsilk4}           {rgb}{0.55,0.53,0.47}
\definecolor {ivory2}              {rgb}{0.93,0.93,0.88}
\definecolor {ivory3}              {rgb}{0.80,0.80,0.76}
\definecolor {ivory4}              {rgb}{0.55,0.55,0.51}
\definecolor {honeydew2}           {rgb}{0.88,0.93,0.88}
\definecolor {honeydew3}           {rgb}{0.76,0.80,0.76}
\definecolor {honeydew4}           {rgb}{0.51,0.55,0.51}
\definecolor {lavenderblush2}      {rgb}{0.93,0.88,0.90}
\definecolor {lavenderblush3}      {rgb}{0.80,0.76,0.77}
\definecolor {lavenderblush4}      {rgb}{0.55,0.51,0.53}
\definecolor {mistyrose2}          {rgb}{0.93,0.84,0.82}
\definecolor {mistyrose3}          {rgb}{0.80,0.72,0.71}
\definecolor {mistyrose4}          {rgb}{0.55,0.49,0.48}
\definecolor {azure2}              {rgb}{0.88,0.93,0.93}
\definecolor {azure3}              {rgb}{0.76,0.80,0.80}
\definecolor {azure4}              {rgb}{0.51,0.55,0.55}
\definecolor {slateblue1}          {rgb}{0.51,0.44,1.00}
\definecolor {slateblue2}          {rgb}{0.48,0.40,0.93}
\definecolor {slateblue3}          {rgb}{0.41,0.35,0.80}
\definecolor {slateblue4}          {rgb}{0.28,0.24,0.55}
\definecolor {royalblue1}          {rgb}{0.28,0.46,1.00}
\definecolor {royalblue2}          {rgb}{0.26,0.43,0.93}
\definecolor {royalblue3}          {rgb}{0.23,0.37,0.80}
\definecolor {royalblue4}          {rgb}{0.15,0.25,0.55}
\definecolor {blue2}               {rgb}{0.00,0.00,0.93}
\definecolor {blue4}               {rgb}{0.00,0.00,0.55}
\definecolor {dodgerblue2}         {rgb}{0.11,0.53,0.93}
\definecolor {dodgerblue3}         {rgb}{0.09,0.45,0.80}
\definecolor {dodgerblue4}         {rgb}{0.06,0.31,0.55}
\definecolor {steelblue1}          {rgb}{0.39,0.72,1.00}
\definecolor {steelblue2}          {rgb}{0.36,0.67,0.93}
\definecolor {steelblue3}          {rgb}{0.31,0.58,0.80}
\definecolor {steelblue4}          {rgb}{0.21,0.39,0.55}
\definecolor {deepskyblue2}        {rgb}{0.00,0.70,0.93}
\definecolor {deepskyblue3}        {rgb}{0.00,0.60,0.80}
\definecolor {deepskyblue4}        {rgb}{0.00,0.41,0.55}
\definecolor {skyblue1}            {rgb}{0.53,0.81,1.00}
\definecolor {skyblue2}            {rgb}{0.49,0.75,0.93}
\definecolor {skyblue3}            {rgb}{0.42,0.65,0.80}
\definecolor {skyblue4}            {rgb}{0.29,0.44,0.55}
\definecolor {lightskyblue1}       {rgb}{0.69,0.89,1.00}
\definecolor {lightskyblue2}       {rgb}{0.64,0.83,0.93}
\definecolor {lightskyblue3}       {rgb}{0.55,0.71,0.80}
\definecolor {lightskyblue4}       {rgb}{0.38,0.48,0.55}
\definecolor {slategray1}          {rgb}{0.78,0.89,1.00}
\definecolor {slategray2}          {rgb}{0.73,0.83,0.93}
\definecolor {slategray3}          {rgb}{0.62,0.71,0.80}
\definecolor {slategray4}          {rgb}{0.42,0.48,0.55}
\definecolor {lightsteelblue1}     {rgb}{0.79,0.88,1.00}
\definecolor {lightsteelblue2}     {rgb}{0.74,0.82,0.93}
\definecolor {lightsteelblue3}     {rgb}{0.64,0.71,0.80}
\definecolor {lightsteelblue4}     {rgb}{0.43,0.48,0.55}
\definecolor {lightblue1}          {rgb}{0.75,0.94,1.00}
\definecolor {lightblue2}          {rgb}{0.70,0.87,0.93}
\definecolor {lightblue3}          {rgb}{0.60,0.75,0.80}
\definecolor {lightblue4}          {rgb}{0.41,0.51,0.55}
\definecolor {lightcyan2}          {rgb}{0.82,0.93,0.93}
\definecolor {lightcyan3}          {rgb}{0.71,0.80,0.80}
\definecolor {lightcyan4}          {rgb}{0.48,0.55,0.55}
\definecolor {paleturquoise1}      {rgb}{0.73,1.00,1.00}
\definecolor {paleturquoise2}      {rgb}{0.68,0.93,0.93}
\definecolor {paleturquoise3}      {rgb}{0.59,0.80,0.80}
\definecolor {paleturquoise4}      {rgb}{0.40,0.55,0.55}
\definecolor {cadetblue1}          {rgb}{0.60,0.96,1.00}
\definecolor {cadetblue2}          {rgb}{0.56,0.90,0.93}
\definecolor {cadetblue3}          {rgb}{0.48,0.77,0.80}
\definecolor {cadetblue4}          {rgb}{0.33,0.53,0.55}
\definecolor {turquoise1}          {rgb}{0.00,0.96,1.00}
\definecolor {turquoise2}          {rgb}{0.00,0.90,0.93}
\definecolor {turquoise3}          {rgb}{0.00,0.77,0.80}
\definecolor {turquoise4}          {rgb}{0.00,0.53,0.55}
\definecolor {cyan2}               {rgb}{0.00,0.93,0.93}
\definecolor {cyan3}               {rgb}{0.00,0.80,0.80}
\definecolor {cyan4}               {rgb}{0.00,0.55,0.55}
\definecolor {darkslategray1}      {rgb}{0.59,1.00,1.00}
\definecolor {darkslategray2}      {rgb}{0.55,0.93,0.93}
\definecolor {darkslategray3}      {rgb}{0.47,0.80,0.80}
\definecolor {darkslategray4}      {rgb}{0.32,0.55,0.55}
\definecolor {aquamarine2}         {rgb}{0.46,0.93,0.78}
\definecolor {aquamarine4}         {rgb}{0.27,0.55,0.45}
\definecolor {darkseagreen1}       {rgb}{0.76,1.00,0.76}
\definecolor {darkseagreen2}       {rgb}{0.71,0.93,0.71}
\definecolor {darkseagreen3}       {rgb}{0.61,0.80,0.61}
\definecolor {darkseagreen4}       {rgb}{0.41,0.55,0.41}
\definecolor {seagreen1}           {rgb}{0.33,1.00,0.62}
\definecolor {seagreen2}           {rgb}{0.31,0.93,0.58}
\definecolor {seagreen3}           {rgb}{0.26,0.80,0.50}
\definecolor {palegreen1}          {rgb}{0.60,1.00,0.60}
\definecolor {palegreen2}          {rgb}{0.56,0.93,0.56}
\definecolor {palegreen3}          {rgb}{0.49,0.80,0.49}
\definecolor {palegreen4}          {rgb}{0.33,0.55,0.33}
\definecolor {springgreen2}        {rgb}{0.00,0.93,0.46}
\definecolor {springgreen3}        {rgb}{0.00,0.80,0.40}
\definecolor {springgreen4}        {rgb}{0.00,0.55,0.27}
\definecolor {green2}              {rgb}{0.00,0.93,0.00}
\definecolor {green3}              {rgb}{0.00,0.80,0.00}
\definecolor {green4}              {rgb}{0.00,0.55,0.00}
\definecolor {chartreuse2}         {rgb}{0.46,0.93,0.00}
\definecolor {chartreuse3}         {rgb}{0.40,0.80,0.00}
\definecolor {chartreuse4}         {rgb}{0.27,0.55,0.00}
\definecolor {olivedrab1}          {rgb}{0.75,1.00,0.24}
\definecolor {olivedrab2}          {rgb}{0.70,0.93,0.23}
\definecolor {olivedrab4}          {rgb}{0.41,0.55,0.13}
\definecolor {darkolivegreen1}     {rgb}{0.79,1.00,0.44}
\definecolor {darkolivegreen2}     {rgb}{0.74,0.93,0.41}
\definecolor {darkolivegreen3}     {rgb}{0.64,0.80,0.35}
\definecolor {darkolivegreen4}     {rgb}{0.43,0.55,0.24}
\definecolor {khaki1}              {rgb}{1.00,0.96,0.56}
\definecolor {khaki2}              {rgb}{0.93,0.90,0.52}
\definecolor {khaki3}              {rgb}{0.80,0.78,0.45}
\definecolor {khaki4}              {rgb}{0.55,0.53,0.31}
\definecolor {lightgoldenrod1}     {rgb}{1.00,0.93,0.55}
\definecolor {lightgoldenrod2}     {rgb}{0.93,0.86,0.51}
\definecolor {lightgoldenrod3}     {rgb}{0.80,0.75,0.44}
\definecolor {lightgoldenrod4}     {rgb}{0.55,0.51,0.30}
\definecolor {lightyellow2}        {rgb}{0.93,0.93,0.82}
\definecolor {lightyellow3}        {rgb}{0.80,0.80,0.71}
\definecolor {lightyellow4}        {rgb}{0.55,0.55,0.48}
\definecolor {yellow2}             {rgb}{0.93,0.93,0.00}
\definecolor {yellow3}             {rgb}{0.80,0.80,0.00}
\definecolor {yellow4}             {rgb}{0.55,0.55,0.00}
\definecolor {gold2}               {rgb}{0.93,0.79,0.00}
\definecolor {gold3}               {rgb}{0.80,0.68,0.00}
\definecolor {gold4}               {rgb}{0.55,0.46,0.00}
\definecolor {goldenrod1}          {rgb}{1.00,0.76,0.15}
\definecolor {goldenrod2}          {rgb}{0.93,0.71,0.13}
\definecolor {goldenrod3}          {rgb}{0.80,0.61,0.11}
\definecolor {goldenrod4}          {rgb}{0.55,0.41,0.08}
\definecolor {darkgoldenrod1}      {rgb}{1.00,0.73,0.06}
\definecolor {darkgoldenrod2}      {rgb}{0.93,0.68,0.05}
\definecolor {darkgoldenrod3}      {rgb}{0.80,0.58,0.05}
\definecolor {darkgoldenrod4}      {rgb}{0.55,0.40,0.03}
\definecolor {rosybrown1}          {rgb}{1.00,0.76,0.76}
\definecolor {rosybrown2}          {rgb}{0.93,0.71,0.71}
\definecolor {rosybrown3}          {rgb}{0.80,0.61,0.61}
\definecolor {rosybrown4}          {rgb}{0.55,0.41,0.41}
\definecolor {indianred1}          {rgb}{1.00,0.42,0.42}
\definecolor {indianred2}          {rgb}{0.93,0.39,0.39}
\definecolor {indianred3}          {rgb}{0.80,0.33,0.33}
\definecolor {indianred4}          {rgb}{0.55,0.23,0.23}
\definecolor {sienna1}             {rgb}{1.00,0.51,0.28}
\definecolor {sienna2}             {rgb}{0.93,0.47,0.26}
\definecolor {sienna3}             {rgb}{0.80,0.41,0.22}
\definecolor {sienna4}             {rgb}{0.55,0.28,0.15}
\definecolor {burlywood1}          {rgb}{1.00,0.83,0.61}
\definecolor {burlywood2}          {rgb}{0.93,0.77,0.57}
\definecolor {burlywood3}          {rgb}{0.80,0.67,0.49}
\definecolor {burlywood4}          {rgb}{0.55,0.45,0.33}
\definecolor {wheat1}              {rgb}{1.00,0.91,0.73}
\definecolor {wheat2}              {rgb}{0.93,0.85,0.68}
\definecolor {wheat3}              {rgb}{0.80,0.73,0.59}
\definecolor {wheat4}              {rgb}{0.55,0.49,0.40}
\definecolor {tan1}                {rgb}{1.00,0.65,0.31}
\definecolor {tan2}                {rgb}{0.93,0.60,0.29}
\definecolor {tan4}                {rgb}{0.55,0.35,0.17}
\definecolor {chocolate1}          {rgb}{1.00,0.50,0.14}
\definecolor {chocolate2}          {rgb}{0.93,0.46,0.13}
\definecolor {chocolate3}          {rgb}{0.80,0.40,0.11}
\definecolor {firebrick1}          {rgb}{1.00,0.19,0.19}
\definecolor {firebrick2}          {rgb}{0.93,0.17,0.17}
\definecolor {firebrick3}          {rgb}{0.80,0.15,0.15}
\definecolor {firebrick4}          {rgb}{0.55,0.10,0.10}
\definecolor {brown1}              {rgb}{1.00,0.25,0.25}
\definecolor {brown2}              {rgb}{0.93,0.23,0.23}
\definecolor {brown3}              {rgb}{0.80,0.20,0.20}
\definecolor {brown4}              {rgb}{0.55,0.14,0.14}
\definecolor {salmon1}             {rgb}{1.00,0.55,0.41}
\definecolor {salmon2}             {rgb}{0.93,0.51,0.38}
\definecolor {salmon3}             {rgb}{0.80,0.44,0.33}
\definecolor {salmon4}             {rgb}{0.55,0.30,0.22}
\definecolor {lightsalmon2}        {rgb}{0.93,0.58,0.45}
\definecolor {lightsalmon3}        {rgb}{0.80,0.51,0.38}
\definecolor {lightsalmon4}        {rgb}{0.55,0.34,0.26}
\definecolor {orange2}             {rgb}{0.93,0.60,0.00}
\definecolor {orange3}             {rgb}{0.80,0.52,0.00}
\definecolor {orange4}             {rgb}{0.55,0.35,0.00}
\definecolor {darkorange1}         {rgb}{1.00,0.50,0.00}
\definecolor {darkorange2}         {rgb}{0.93,0.46,0.00}
\definecolor {darkorange3}         {rgb}{0.80,0.40,0.00}
\definecolor {darkorange4}         {rgb}{0.55,0.27,0.00}
\definecolor {coral1}              {rgb}{1.00,0.45,0.34}
\definecolor {coral2}              {rgb}{0.93,0.42,0.31}
\definecolor {coral3}              {rgb}{0.80,0.36,0.27}
\definecolor {coral4}              {rgb}{0.55,0.24,0.18}
\definecolor {tomato2}             {rgb}{0.93,0.36,0.26}
\definecolor {tomato3}             {rgb}{0.80,0.31,0.22}
\definecolor {tomato4}             {rgb}{0.55,0.21,0.15}
\definecolor {orangered2}          {rgb}{0.93,0.25,0.00}
\definecolor {orangered3}          {rgb}{0.80,0.22,0.00}
\definecolor {orangered4}          {rgb}{0.55,0.15,0.00}
\definecolor {red2}                {rgb}{0.93,0.00,0.00}
\definecolor {red3}                {rgb}{0.80,0.00,0.00}
\definecolor {red4}                {rgb}{0.55,0.00,0.00}
\definecolor {deeppink2}           {rgb}{0.93,0.07,0.54}
\definecolor {deeppink3}           {rgb}{0.80,0.06,0.46}
\definecolor {deeppink4}           {rgb}{0.55,0.04,0.31}
\definecolor {hotpink1}            {rgb}{1.00,0.43,0.71}
\definecolor {hotpink2}            {rgb}{0.93,0.42,0.65}
\definecolor {hotpink3}            {rgb}{0.80,0.38,0.56}
\definecolor {hotpink4}            {rgb}{0.55,0.23,0.38}
\definecolor {pink1}               {rgb}{1.00,0.71,0.77}
\definecolor {pink2}               {rgb}{0.93,0.66,0.72}
\definecolor {pink3}               {rgb}{0.80,0.57,0.62}
\definecolor {pink4}               {rgb}{0.55,0.39,0.42}
\definecolor {lightpink1}          {rgb}{1.00,0.68,0.73}
\definecolor {lightpink2}          {rgb}{0.93,0.64,0.68}
\definecolor {lightpink3}          {rgb}{0.80,0.55,0.58}
\definecolor {lightpink4}          {rgb}{0.55,0.37,0.40}
\definecolor {palevioletred1}      {rgb}{1.00,0.51,0.67}
\definecolor {palevioletred2}      {rgb}{0.93,0.47,0.62}
\definecolor {palevioletred3}      {rgb}{0.80,0.41,0.54}
\definecolor {palevioletred4}      {rgb}{0.55,0.28,0.36}
\definecolor {maroon1}             {rgb}{1.00,0.20,0.70}
\definecolor {maroon2}             {rgb}{0.93,0.19,0.65}
\definecolor {maroon3}             {rgb}{0.80,0.16,0.56}
\definecolor {maroon4}             {rgb}{0.55,0.11,0.38}
\definecolor {violetred1}          {rgb}{1.00,0.24,0.59}
\definecolor {violetred2}          {rgb}{0.93,0.23,0.55}
\definecolor {violetred3}          {rgb}{0.80,0.20,0.47}
\definecolor {violetred4}          {rgb}{0.55,0.13,0.32}
\definecolor {magenta2}            {rgb}{0.93,0.00,0.93}
\definecolor {magenta3}            {rgb}{0.80,0.00,0.80}
\definecolor {magenta4}            {rgb}{0.55,0.00,0.55}
\definecolor {orchid1}             {rgb}{1.00,0.51,0.98}
\definecolor {orchid2}             {rgb}{0.93,0.48,0.91}
\definecolor {orchid3}             {rgb}{0.80,0.41,0.79}
\definecolor {orchid4}             {rgb}{0.55,0.28,0.54}
\definecolor {plum1}               {rgb}{1.00,0.73,1.00}
\definecolor {plum2}               {rgb}{0.93,0.68,0.93}
\definecolor {plum3}               {rgb}{0.80,0.59,0.80}
\definecolor {plum4}               {rgb}{0.55,0.40,0.55}
\definecolor {mediumorchid1}       {rgb}{0.88,0.40,1.00}
\definecolor {mediumorchid2}       {rgb}{0.82,0.37,0.93}
\definecolor {mediumorchid3}       {rgb}{0.71,0.32,0.80}
\definecolor {mediumorchid4}       {rgb}{0.48,0.22,0.55}
\definecolor {darkorchid1}         {rgb}{0.75,0.24,1.00}
\definecolor {darkorchid2}         {rgb}{0.70,0.23,0.93}
\definecolor {darkorchid3}         {rgb}{0.60,0.20,0.80}
\definecolor {darkorchid4}         {rgb}{0.41,0.13,0.55}
\definecolor {purple1}             {rgb}{0.61,0.19,1.00}
\definecolor {purple2}             {rgb}{0.57,0.17,0.93}
\definecolor {purple3}             {rgb}{0.49,0.15,0.80}
\definecolor {purple4}             {rgb}{0.33,0.10,0.55}
\definecolor {mediumpurple1}       {rgb}{0.67,0.51,1.00}
\definecolor {mediumpurple2}       {rgb}{0.62,0.47,0.93}
\definecolor {mediumpurple3}       {rgb}{0.54,0.41,0.80}
\definecolor {mediumpurple4}       {rgb}{0.36,0.28,0.55}
\definecolor {thistle1}            {rgb}{1.00,0.88,1.00}
\definecolor {thistle2}            {rgb}{0.93,0.82,0.93}
\definecolor {thistle3}            {rgb}{0.80,0.71,0.80}
\definecolor {thistle4}            {rgb}{0.55,0.48,0.55}
\definecolor {gray1}               {rgb}{0.01,0.01,0.01}
\definecolor {gray2}               {rgb}{0.02,0.02,0.02}
\definecolor {gray3}               {rgb}{0.03,0.03,0.03}
\definecolor {gray4}               {rgb}{0.04,0.04,0.04}
\definecolor {gray5}               {rgb}{0.05,0.05,0.05}
\definecolor {gray6}               {rgb}{0.06,0.06,0.06}
\definecolor {gray7}               {rgb}{0.07,0.07,0.07}
\definecolor {gray8}               {rgb}{0.08,0.08,0.08}
\definecolor {gray9}               {rgb}{0.09,0.09,0.09}
\definecolor {gray10}              {rgb}{0.10,0.10,0.10}
\definecolor {gray11}              {rgb}{0.11,0.11,0.11}
\definecolor {gray12}              {rgb}{0.12,0.12,0.12}
\definecolor {gray13}              {rgb}{0.13,0.13,0.13}
\definecolor {gray14}              {rgb}{0.14,0.14,0.14}
\definecolor {gray15}              {rgb}{0.15,0.15,0.15}
\definecolor {gray16}              {rgb}{0.16,0.16,0.16}
\definecolor {gray17}              {rgb}{0.17,0.17,0.17}
\definecolor {gray18}              {rgb}{0.18,0.18,0.18}
\definecolor {gray19}              {rgb}{0.19,0.19,0.19}
\definecolor {gray20}              {rgb}{0.20,0.20,0.20}
\definecolor {gray21}              {rgb}{0.21,0.21,0.21}
\definecolor {gray22}              {rgb}{0.22,0.22,0.22}
\definecolor {gray23}              {rgb}{0.23,0.23,0.23}
\definecolor {gray24}              {rgb}{0.24,0.24,0.24}
\definecolor {gray25}              {rgb}{0.25,0.25,0.25}
\definecolor {gray26}              {rgb}{0.26,0.26,0.26}
\definecolor {gray27}              {rgb}{0.27,0.27,0.27}
\definecolor {gray28}              {rgb}{0.28,0.28,0.28}
\definecolor {gray29}              {rgb}{0.29,0.29,0.29}
\definecolor {gray30}              {rgb}{0.30,0.30,0.30}
\definecolor {gray31}              {rgb}{0.31,0.31,0.31}
\definecolor {gray32}              {rgb}{0.32,0.32,0.32}
\definecolor {gray33}              {rgb}{0.33,0.33,0.33}
\definecolor {gray34}              {rgb}{0.34,0.34,0.34}
\definecolor {gray35}              {rgb}{0.35,0.35,0.35}
\definecolor {gray36}              {rgb}{0.36,0.36,0.36}
\definecolor {gray37}              {rgb}{0.37,0.37,0.37}
\definecolor {gray38}              {rgb}{0.38,0.38,0.38}
\definecolor {gray39}              {rgb}{0.39,0.39,0.39}
\definecolor {gray40}              {rgb}{0.40,0.40,0.40}
\definecolor {gray42}              {rgb}{0.42,0.42,0.42}
\definecolor {gray43}              {rgb}{0.43,0.43,0.43}
\definecolor {gray44}              {rgb}{0.44,0.44,0.44}
\definecolor {gray45}              {rgb}{0.45,0.45,0.45}
\definecolor {gray46}              {rgb}{0.46,0.46,0.46}
\definecolor {gray47}              {rgb}{0.47,0.47,0.47}
\definecolor {gray48}              {rgb}{0.48,0.48,0.48}
\definecolor {gray49}              {rgb}{0.49,0.49,0.49}
\definecolor {gray50}              {rgb}{0.50,0.50,0.50}
\definecolor {gray51}              {rgb}{0.51,0.51,0.51}
\definecolor {gray52}              {rgb}{0.52,0.52,0.52}
\definecolor {gray53}              {rgb}{0.53,0.53,0.53}
\definecolor {gray54}              {rgb}{0.54,0.54,0.54}
\definecolor {gray55}              {rgb}{0.55,0.55,0.55}
\definecolor {gray56}              {rgb}{0.56,0.56,0.56}
\definecolor {gray57}              {rgb}{0.57,0.57,0.57}
\definecolor {gray58}              {rgb}{0.58,0.58,0.58}
\definecolor {gray59}              {rgb}{0.59,0.59,0.59}
\definecolor {gray60}              {rgb}{0.60,0.60,0.60}
\definecolor {gray61}              {rgb}{0.61,0.61,0.61}
\definecolor {gray62}              {rgb}{0.62,0.62,0.62}
\definecolor {gray63}              {rgb}{0.63,0.63,0.63}
\definecolor {gray64}              {rgb}{0.64,0.64,0.64}
\definecolor {gray65}              {rgb}{0.65,0.65,0.65}
\definecolor {gray66}              {rgb}{0.66,0.66,0.66}
\definecolor {gray67}              {rgb}{0.67,0.67,0.67}
\definecolor {gray68}              {rgb}{0.68,0.68,0.68}
\definecolor {gray69}              {rgb}{0.69,0.69,0.69}
\definecolor {gray70}              {rgb}{0.70,0.70,0.70}
\definecolor {gray71}              {rgb}{0.71,0.71,0.71}
\definecolor {gray72}              {rgb}{0.72,0.72,0.72}
\definecolor {gray73}              {rgb}{0.73,0.73,0.73}
\definecolor {gray74}              {rgb}{0.74,0.74,0.74}
\definecolor {gray75}              {rgb}{0.75,0.75,0.75}
\definecolor {gray76}              {rgb}{0.76,0.76,0.76}
\definecolor {gray77}              {rgb}{0.77,0.77,0.77}
\definecolor {gray78}              {rgb}{0.78,0.78,0.78}
\definecolor {gray79}              {rgb}{0.79,0.79,0.79}
\definecolor {gray80}              {rgb}{0.80,0.80,0.80}
\definecolor {gray81}              {rgb}{0.81,0.81,0.81}
\definecolor {gray82}              {rgb}{0.82,0.82,0.82}
\definecolor {gray83}              {rgb}{0.83,0.83,0.83}
\definecolor {gray84}              {rgb}{0.84,0.84,0.84}
\definecolor {gray85}              {rgb}{0.85,0.85,0.85}
\definecolor {gray86}              {rgb}{0.86,0.86,0.86}
\definecolor {gray87}              {rgb}{0.87,0.87,0.87}
\definecolor {gray88}              {rgb}{0.88,0.88,0.88}
\definecolor {gray89}              {rgb}{0.89,0.89,0.89}
\definecolor {gray90}              {rgb}{0.90,0.90,0.90}
\definecolor {gray91}              {rgb}{0.91,0.91,0.91}
\definecolor {gray92}              {rgb}{0.92,0.92,0.92}
\definecolor {gray93}              {rgb}{0.93,0.93,0.93}
\definecolor {gray94}              {rgb}{0.94,0.94,0.94}
\definecolor {gray95}              {rgb}{0.95,0.95,0.95}
\definecolor {gray97}              {rgb}{0.97,0.97,0.97}
\definecolor {gray98}              {rgb}{0.98,0.98,0.98}
\definecolor {gray99}              {rgb}{0.99,0.99,0.99}
\definecolor {darkgrey}            {rgb}{0.66,0.66,0.66}

%%%%%%%%%%%%%% REDEFINITION OF COMMENTS IN "algorithmic" 
%\renewcommand{\algorithmiccomment}[1]{\ \ \ \ \ // #1}


%%% CONTROL MACROS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

\newcommand{\RSHIGHLIGHT}[1]{\textcolor{blue}{{{#1}}}}


%\renewcommand{\emph}[1]{\darkorange{{\em #1}}}
%\newcommand{\new}[1]{\darkorange{#1}}
\newcommand{\new}[1]{{\blue #1}\/}
\newcommand{\ex}[1]{{\green #1}\/} 
%\newcommand{\ex}[1]{{#1}} 

\newcommand{\resp}[1]{[resp.\ #1]}
\newcommand{\done}{\textcolor{darkgreen}{\checkmark}}


%\newcommand{\TODO}[1]{{\bf \textcolor{blue}{{\fbox{TODO:} #1}}}}
\newcommand{\TODO}[1]{{}}
\newcommand{\ACTODO}[1]{{\bf \textcolor{red}{{\fbox{AC TODO:} #1}}}}
\newcommand{\RS}[1]{\textcolor{blue}{#1}}
\newcommand{\ignore}[1]{}
%\newcommand{\todo}[1] {\noindent \textcolor{blue}{\fbox{{\bf TO DO:}} #1 }}
%\newcommand{\todo}[1] {}
\newcommand{\RSCHANGE}[1]{\textcolor{blue}{#1}}
\renewcommand{\RS}[1]{\textcolor{darkgreen}{#1}}
\newcommand{\PT}[1]{\textcolor{darkviolet}{#1}}
\newcommand{\RSTODO}[1]{{\bf \textcolor{darkgreen}{{\fbox{RS TODO:} #1}}}}
\renewcommand{\RSTODO}[1]{}
%\renewcommand{\RSCHANGE}[1]{#1}
\newcommand{\nota}[1] {\noindent \fbox{{\bf NOTA:}} #1 }
\newcommand{\marg}[1]{\marginpar{\ \\{\em #1\/}}}
\renewcommand{\marg}[1]{\marginpar{\ \\\textcolor{blue}{\ {\sf #1\/}}}}

\newenvironment{rschange}{\color{blue}}{\normalcolor}
\newenvironment{rs}{\color{blue}}{\normalcolor}
\newenvironment{pt}{\color{darkviolet}}{\normalcolor}

\newcommand{\RSNOTE}[1]{\marginpar{\textcolor{darkgreen}{\textbf{RS: }
      {\footnotesize #1}}}}
\renewcommand{\RSNOTE}[1]{\noindent\textcolor{darkgreen}{{\bf RS: #1}}}


%%% FOR SHORTER VERSION
\newcommand{\ignoreinshort}[1]{}
 \newcommand{\ignoreinlong}[1]{{#1}}
 %\renewcommand{\ignoreinshort}[1]{\textcolor{blue}{#1}}
% \renewcommand{\ignoreinlong}[1]{}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%


%%% FREQUENTLY-USED ENVIRONMENTS (from mrg/environments.tex)
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\def\makenewenumerate#1#2{%
\newcounter{cnt#1}
\newenvironment{#1}%
{\begin{list}{\makebox[0pt][r]{#2}}%
{\setlength{\itemsep}{0pt}% 
 \setlength{\parsep}{.2em}%
 \setlength{\leftmargin}{1.5em}%
 \setlength{\labelwidth}{.4em}%
 \usecounter{cnt#1}}}
{\end{list}}}

\makenewenumerate{myenumerate}{\arabic{cntmyenumerate}.}

\makenewenumerate{renumerate}{\rm(\roman{cntrenumerate})}
\makenewenumerate{renumerateprime}{\rm(\roman{cntrenumerateprime}$'$)}
\makenewenumerate{renumeratesecond}{\rm(\roman{cntrenumeratesecond}$''$)}

\makenewenumerate{aenumerate}{({\it\alph{cntaenumerate}})}
\makenewenumerate{aenumerateprime}{({\it\alph{cntaenumerateprime}$'$})}
\makenewenumerate{aenumeratesecond}{({\it\alph{cntaenumeratesecond}$''$})}

\def\newplaintheorem#1#2{%
%\newtheorem{#1plain}{#2}[section]%
\newtheorem{#1plain}{#2}% %% RS: mon mi piace l'indice di sezione
\newenvironment{#1}{\begin{#1plain}\rm }{\end{#1plain}}}

\newtheorem{definition}{Definition}%[section]
\newtheorem{intfact}{Intuitive Fact}%[section]
\newtheorem{proposition}{Proposition}%[section]
\newtheorem{property}{Property}%[section]
%\newtheorem{conjecture}{Conjecture}[section]
%\newtheorem{theorem}{Theorem}%[section]
\newtheorem{corollary}{Corollary}%[section]
\newtheorem{lemma}{Lemma}%[section]
\newplaintheorem{notation}{Notation}
\newplaintheorem{remark}{Remark}
%\newplaintheorem{example}{Example}
\newplaintheorem{cexample}{Counter-Example}
\newtheorem{strategy}{Strategy}
%\newenvironment{proof}{{\bf Proof }}{\mbox{\hspace{0cm}}\hfill $\Box$} 
%\newenvironment{proof}{{\bf Proof }}{} 

%%% TRICK FOR SHORTENING
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\fakesubsubsection}[1]{\smallskip\noindent {\bf #1.}}


%%% FREQUENTLY-USED MACROS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

\newcommand{\sref}[1]{\S{}\ref{#1}}
\newcommand{\noi}{\noindent}


%%% FREQUENTLY-USED logic macros
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

\newcommand{\pair}[2]{\ensuremath{\langle{#1},{#2}\rangle}\xspace}
\newcommand{\triple}[3]{\ensuremath{\langle{#1},{#2},{#3}\rangle}\xspace}
\newcommand{\tuple}[1]{\ensuremath{\langle{#1}\rangle}\xspace}
\newcommand{\set}[1]{\ensuremath{\{{#1}\}}\xspace}
\newcommand{\imp}{\ensuremath{\rightarrow}\xspace}
\newcommand{\limp}{\ensuremath{\leftarrow}\xspace}
\renewcommand{\iff}{\ensuremath{\leftrightarrow}\xspace}
\newcommand{\defas}{\ensuremath{\stackrel{\text{\tiny def}}{=}}\xspace}
\newcommand{\thus}{\ensuremath{\Longrightarrow}\xspace}

\newcommand{\pos}{\phantom{\neg}}



%%% FREQUENTLY-USED symbols
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%% CALYGRAPHIC LETTERS
\newcommand\cala{\ensuremath{\mathcal{A}}\xspace}
\newcommand\calb{\ensuremath{\mathcal{B}}\xspace}
\newcommand\calc{\ensuremath{\mathcal{C}}\xspace}
\newcommand\cald{\ensuremath{\mathcal{D}}\xspace}
\newcommand\cale{\ensuremath{\mathcal{E}}\xspace}
\newcommand\calf{\ensuremath{\mathcal{F}}\xspace}
\newcommand\calg{\ensuremath{\mathcal{G}}\xspace}
\newcommand\calh{\ensuremath{\mathcal{H}}\xspace}
\newcommand\cali{\ensuremath{\mathcal{I}}\xspace}
\newcommand\calj{\ensuremath{\mathcal{J}}\xspace}
\newcommand\calk{\ensuremath{\mathcal{K}}\xspace}
\newcommand\call{\ensuremath{\mathcal{L}}\xspace}
\newcommand\calm{\ensuremath{\mathcal{M}}\xspace}
\newcommand\caln{\ensuremath{\mathcal{N}}\xspace}
\newcommand\calo{\ensuremath{\mathcal{O}}\xspace}
\newcommand\calp{\ensuremath{\mathcal{P}}\xspace}
\newcommand\calq{\ensuremath{\mathcal{Q}}\xspace}
\newcommand\calr{\ensuremath{\mathcal{R}}\xspace}
\newcommand\cals{\ensuremath{\mathcal{S}}\xspace}
\newcommand\calt{\ensuremath{\mathcal{T}}\xspace}
\newcommand\calu{\ensuremath{\mathcal{U}}\xspace}
\newcommand\calv{\ensuremath{\mathcal{V}}\xspace}
\newcommand\calw{\ensuremath{\mathcal{W}}\xspace}
\newcommand\calx{\ensuremath{\mathcal{X}}\xspace}
\newcommand\caly{\ensuremath{\mathcal{Y}}\xspace}
\newcommand\calz{\ensuremath{\mathcal{Z}}\xspace}



%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% macros for handling modification due to reviems
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\rone}{\marginnote{\ \textcolor{red}{\ {\sf R1\/}}}}
\newcommand{\rtwo}{\marginnote{\ \textcolor{red}{\ {\sf R2\/}}}}
\newcommand{\rthree}{\marginnote{\ \textcolor{red}{\ {\sf R3\/}}}}
\newcommand{\ronetwo}{\marginnote{\ \textcolor{red}{\ {\sf R1\/}, {\sf R2\/}}}}
\newcommand{\ronethree}{\marginnote{\ \textcolor{red}{\ {\sf R1\/}, {\sf R3\/}}}}

\newcommand{\ronefour}{\marginnote{\ \textcolor{red}{\ {\sf R1\/}, {\sf R4\/}}}}
\newcommand{\rtwothree}{\marginnote{\ \textcolor{red}{\ {\sf R2\/}, {\sf R3\/}}}}
\newcommand{\rtwofour}{\marginnote{\ \textcolor{red}{\ {\sf R2\/}, {\sf R4\/}}}}

\newcommand{\ronetwothree}{\marginnote{\ \textcolor{red}{\ {\sf
R1\/}, {\sf R2\/} {\sf R3\/}}}}
\newcommand{\ronethreefour}{\marginnote{\ \textcolor{red}{\ {\sf
R1\/}, {\sf R3\/} {\sf R4\/}}}}
\newcommand{\rtwothreefour}{\marginnote{\ \textcolor{red}{\ {\sf
R2\/}, {\sf R3\/} {\sf R4\/}}}}
 
\newcommand{\ronetwothreefour}{\marginnote{\ \textcolor{red}{\ {\sf
R1\/}, {\sf R2\/}, {\sf R3\/}  {\sf R4\/}}}}


\renewcommand{\RSCHANGE}[1]{\textcolor{blue}{{#1}}}
%\renewcommand{\RSCHANGE}[1]{#1}
\newcommand{\RSCHANGEONE}[1]{\rone{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGETWO}[1]{\rtwo{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGETHREE}[1]{\rthree{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGEONETHREE}[1]{\ronethree{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGEONETWO}[1]{\ronetwo{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGETWOTHREE}[1]{\rtwothree{}~\textcolor{blue}{{#1}}}

\newcommand{\RSCHANGEFOUR}[1]{\rfour{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGEONEFOUR}[1]{\ronefour{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGETWOFOUR}[1]{\rtwofour{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGETHREEFOUR}[1]{\rtwothreefour{}~\textcolor{blue}{{#1}}}
\newcommand{\RSCHANGEONETHREEFOUR}[1]{\ronethreefour{}~\textcolor{blue}{{#1}}}

%%%%%%%%%% RS_MACROS_DL %%%%%%%%%%

\newcommand{\en}[2]{{#1}e{#2}}
\newcommand{\den}[4]{\en{#1}{#2}/\en{#3}{#4}}

\newcommand{\mc}[1]{\ensuremath{\mathcal{#1}}}
\newcommand{\msf}[1]{\ensuremath{\mathsf{#1}}}

\newcommand{\snomed}{\textsc{Snomed-CT}\xspace}
\newcommand{\geneonto}{\textsc{GeneOntology}\xspace}
\newcommand{\nci}{\textsc{NCI}\xspace}
\newcommand{\galen}{\textsc{Galen}\xspace}

\newcommand{\shsnomed}{\textsc{Snomed09}\xspace} 
\newcommand{\shnci}{\textsc{NCI}\xspace} 
\newcommand{\shgalen}{\textsc{notGalen}\xspace}
\newcommand{\shfullgalen}{{\textsc{fullGalen}}\xspace}
\newcommand{\shgeneontology}{{\textsc{GeneOnt.}}\xspace}

\newcommand{\conj}{\sqcap}
\newcommand{\disj}{\sqcup}
\newcommand{\exr}[2]{{\exists}#1.#2}

\newcommand{\subs}{\sqsubseteq}
\newcommand{\sups}{\sqsupseteq}
\newcommand{\norm}{\triangleq}
\newcommand{\comp}{\circ}

\newcommand{\topt}{\ensuremath{\top}\xspace}
\newcommand{\bott}{\ensuremath{\bot}\xspace}
\newcommand{\conjt}[2]{\ensuremath{#1 \sqcap #2}\xspace}
\newcommand{\disjt}[2]{\ensuremath{#1 \sqcup #2}\xspace}
\newcommand{\exrt}[2]{\ensuremath{{\exists}#1.#2}\xspace}
\newcommand{\equivt}[2]{\ensuremath{#1 \equiv #2}\xspace}
\newcommand{\subst}[2]{\ensuremath{#1 \sqsubseteq #2}\xspace}
\newcommand{\supst}[2]{\ensuremath{#1 \sqsupseteq #2}\xspace}
%\newcommand{\eqdef}{\stackrel{def}{=}}
%\newcommand{\defas}{\ensuremath{\stackrel{\text{\tiny def}}{=}}\xspace}
 
\newcommand{\pr}[1]{\ensuremath{p_{#1}}\xspace}
\newcommand{\prc}[1]{\ensuremath{p_{[#1]}}\xspace}
\newcommand{\sel}[1]{\ensuremath{s_{#1}}\xspace}
\newcommand{\selc}[1]{\ensuremath{s_{[#1]}}\xspace}

\newcommand{\goal}{\ensuremath{C_i\subs_\T D_i}\xspace}
\newcommand{\goalsure}{\ensuremath{C_i~\subs_\T~D_i}\xspace}
\newcommand{\tgoal}[1]{\ensuremath{C_i\subs_{#1} D_i}\xspace}
\newcommand{\igoal}[1]{\ensuremath{{C_{#1} \subs_\T D_{#1}}}\xspace}
\newcommand{\sgoal}{\ensuremath{\selc{\goal}}\xspace}
\newcommand{\isgoal}[1]{\ensuremath{\selc{\igoal{#1}}}\xspace}
\newcommand{\nsgoal}{\ensuremath{\neg\selc{C_i\subs_\T D_i}}\xspace}

\newcommand{\assumptiongoal}{\ensuremath{\{\neg\prc{D_i},\prc{C_i}\}}\xspace}
\newcommand{\assumptionsgoal}{\ensuremath{\{\neg\sgoal\}}\xspace}

\newcommand{\aenc}[1]{\ensuremath{\elp2sat(#1)}\xspace}
\newcommand{\wffsubs}{\ensuremath{\phi_{\T{}}}\xspace}
\newcommand{\wffsubsnotrans}{\ensuremath{\phi_{\T{}}^{notrans}}\xspace}
\newcommand{\wffmina}{\ensuremath{\wffsubs^{one}}\xspace}
\newcommand{\wffminarule}{\ensuremath{\phi_{\T(po)}^{one}}\xspace}
\newcommand{\wffminaT}[1]{\ensuremath{\phi_{#1}^{one}}\xspace}
\newcommand{\wffminaTrule}[1]{\ensuremath{\phi_{#1}^{one}}\xspace}
\newcommand{\wffallmina}{\ensuremath{\wffsubs^{all}}\xspace}
\newcommand{\wffallminarule}{\ensuremath{\phi_{\T{}(po)}^{all}}\xspace}
\newcommand{\wffallminaT}[1]{\ensuremath{\phi_{#1}^{all}}\xspace}
\newcommand{\wffallminaTrule}[1]{\ensuremath{\phi_{#1 (po)}^{all}}\xspace}
\newcommand{\wffallminaO}{\ensuremath{\phi_{\T^*}^{all}}\xspace}
\newcommand{\wffallminaruleO}{\ensuremath{\phi_{\T^*(po)}^{all}}\xspace}

\newcommand{\pinpointingwff}{\ensuremath{\Phi^{\goal}}\xspace}
\newcommand{\pinpointingwffall}{\ensuremath{\Phi^{all}}\xspace}

\newcommand{\hatT}{\ensuremath{\hat{\T}}\xspace}
\newcommand{\Tp}{\ensuremath{\ensuremath{\mathcal{T'}}\xspace}}

\newcommand{\elsat}{{\elp{}\textsc{SAT}}\xspace}

\newcommand{\el}{\ensuremath{\mathcal{EL}}\xspace}
\newcommand{\elh}{\ensuremath{\mathcal{ELH}}\xspace}
\newcommand{\elp}{\ensuremath{\mathcal{EL^{+}}}\xspace}
\newcommand{\elpp}{\ensuremath{\mathcal{EL^{++}}}\xspace}
\newcommand{\eloh}{\ensuremath{\mathcal{ELOH}}\xspace}
\newcommand{\eqdef}{\stackrel{def}{=}}


% \newcommand{\sel}[1]{\ensuremath{s_{#1}}\xspace}
% \newcommand{\selc}[1]{\ensuremath{s_{[#1]}}\xspace}
% \newcommand{\sgoal}{\ensuremath{\selc{\goal}}\xspace}
% \newcommand{\isgoal}[1]{\ensuremath{\selc{\igoal{#1}}}\xspace}
% \newcommand{\nsgoal}{\ensuremath{\neg\selc{C_i\subs_\T D_i}}\xspace}
% \newcommand{\aenc}[1]{\ensuremath{\elp2sat(#1)}\xspace}
% \newcommand{\elsat}{{\elp{}\textsc{SAT}}\xspace}


%%%%%%%%%% RS_MACROS_MC %%%%%%%%%%

\newcommand{\nusmv}{{\sc NuSMV}}
\newcommand{\PROMELA}{{\sc PROMELA}}
\newcommand{\smv}{{\sc SMV}}

\newcommand{\bdds}{\text{BDD}s\xspace}
\newcommand{\bdd}{\textrm{BDD}\xspace}
%\newcommand{\imp}{\rightarrow}
\newcommand{\dis}{\vee}
\newcommand{\con}{\wedge}
\newcommand{\liff}{\leftrightarrow}
\newcommand{\true}{\top}
\newcommand{\false}{\bot}
\newcommand{\CTL}{\textsc{CTL}\xspace}
\newcommand{\LTL}{\textsc{LTL}\xspace}




%%% MACROS BMC
\newcommand{\E}{{\bf E\/}}
\newcommand{\A}{{\bf A\/}}
\newcommand{\G}{{\bf G\/}}
\newcommand{\F}{{\bf F\/}}
\newcommand{\U}{{\bf U\/}}
\newcommand{\R}{{\bf R\/}}
\newcommand{\X}{{\bf X\/}}
\newcommand{\AG}{{\bf AG\/}}
\newcommand{\AF}{{\bf AF\/}}
\newcommand{\AU}{{\bf AU\/}}
\newcommand{\AR}{{\bf AR\/}}
\newcommand{\AX}{{\bf AX\/}}
\newcommand{\EG}{{\bf EG\/}}
\newcommand{\EF}{{\bf EF\/}}
\newcommand{\EU}{{\bf EU\/}}
\newcommand{\ER}{{\bf ER\/}}
\newcommand{\EX}{{\bf EX\/}}

\newcommand{\n}[2]{[[#1]]_{#2}}
\newcommand{\kil}[3]{\ _{#3}[[#1]]_{k}^{#2}}
\newcommand{\ki}[2]{\kil{#1}{#2}{}}
\renewcommand{\k}[1]{\kil{#1}{}{}}
\newcommand{\kl}[2]{\kil{#1}{}{#2}}

\newcommand{\fkil}[2]{\kil{f}{#1}{#2}}
\newcommand{\fki}[1]{\kil{f}{#1}{}}
\newcommand{\fk}{\kil{f}{}{}}
\newcommand{\fkl}[1]{\kil{f}{}{#1}}

\newcommand{\gkil}[2]{\kil{g}{#1}{#2}}
\newcommand{\gki}[1]{\kil{g}{#1}{}}
\newcommand{\gk}{\kil{g}{}{}}
\newcommand{\gkl}[1]{\kil{g}{}{#1}}

\newcommand{\Lkl}[1]{\ _{#1}{L}_{k}}
\newcommand{\Lkkll}[2]{\ _{#2}{L}_{#1}}
\newcommand{\Lkll}[1]{{L}_{k|#1}}
\newcommand{\Lk}{{L}_{k}}

\newcommand{\Mkil}[3]{\kil{M}{#1}{#2}{#3}}
\newcommand{\Mki}[2]{\kil{M}{#1}{#2}{}}
\newcommand{\Mk}[1]{\kil{M}{#1}{}{}}
\newcommand{\Mkl}[2]{\kil{M}{#1}{}{#2}}


%%%%%%%%%% RS_MACROS_OPTSMT %%%%%%%%%%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% 
%%%               MACROS SPECIFIC FOR SMT WITH COSTS
%%% 
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

 

%%% FUNCTIONS

\newcommand{\omtproblem}{\triple{\vi}{\costfs}{\bounds}\xspace}
\newcommand{\omt}{\ensuremath{\text{OMT}}\xspace}
\newcommand{\bomt}{\ensuremath{\text{BOMT}}\xspace}
\newcommand{\omtt}{\ensuremath{\text{OMT}({\T})}\xspace}
\newcommand{\bomtt}{\ensuremath{\text{BOMT}({\T})}\xspace}

\newcommand{\omtplus}[1]{\ensuremath{\text{OMT}({#1})}\xspace}
\newcommand{\omlarat}{\ensuremath{\text{OMT}(\larat)}\xspace}
\newcommand{\omlaint}{\ensuremath{\text{OMT}(\laint)}\xspace}
\newcommand{\omla}{\ensuremath{\text{OMT}(\la)}\xspace}
\newcommand{\omlaintplus}{\ensuremath{\text{OMT}(\laint\cup\T)}\xspace}
\newcommand{\omlaratplus}{\ensuremath{\text{OMT}(\larat\cup\T)}\xspace}
\newcommand{\omlaplus}{\ensuremath{\text{OMT}(\la\cup\T)}\xspace}

\newcommand{\smtlaratplus}{\smttt{\larat\cup\T}\xspace}
\newcommand{\laratplus}{\ensuremath{\larat\cup\T}\xspace}


%cost function symbols
\newcommand{\costfs}{\ensuremath{\underline{costs}}\xspace}
\newcommand{\costfgen}[1]{\ensuremath{{cost}^{#1}}\xspace}
\newcommand{\costfi}{\costfgen{i}}
\newcommand{\costfone}{\costfgen{1}}
\newcommand{\costfM}{\costfgen{M}}

%cost variable symbols
\newcommand{\costs}{\ensuremath{\underline{c}}\xspace}
\newcommand{\costgen}[1]{\ensuremath{{c}^{#1}}\xspace}
\newcommand{\costi}{\costgen{i}}
\newcommand{\costone}{\costgen{1}}
\newcommand{\costM}{\costgen{M}}

%generic values symbols
\newcommand{\vvgen}[2]{\ensuremath{{\sf v}^{#1}_{#2}}\xspace}
\newcommand{\vvi}[1]{\vvgen{i}{#1}}
\newcommand{\wvgen}[2]{\ensuremath{{\sf w}^{#1}_{#2}}\xspace}
\newcommand{\wvi}[1]{\wvgen{i}{#1}}
\newcommand{\xvgen}[2]{\ensuremath{{\sf x}^{#1}_{#2}}\xspace}
\newcommand{\xvi}[1]{\xvgen{i}{#1}}
\newcommand{\yvgen}[2]{\ensuremath{{\sf y}^{#1}_{#2}}\xspace}
\newcommand{\yvi}[1]{\yvgen{i}{#1}}


%bounds symbols
\newcommand{\lbgen}[2]{\ensuremath{{\sf lb}^{#1}_{#2}}\xspace}
\newcommand{\ubgen}[2]{\ensuremath{{\sf ub}^{#1}_{#2}}\xspace}
\newcommand{\lb}{\lbgen{}{}}
\newcommand{\ub}{\ubgen{}{}}
\newcommand{\lbi}{\lbgen{i}{}}
\newcommand{\ubi}{\ubgen{i}{}}
\newcommand{\lbone}{\lbgen{1}{}}
\newcommand{\ubone}{\ubgen{1}{}}
\newcommand{\lbM}{\lbgen{M}{}}
\newcommand{\ubM}{\ubgen{M}{}}
\newcommand{\lbigen}[1]{\lbgen{i}{(#1)}}
\newcommand{\ubigen}[1]{\ubgen{i}{(#1)}}
\newcommand{\lbimax}{\lbgen{i}{max}}
\newcommand{\ubimin}{\ubgen{i}{min}}
\newcommand{\lbonemax}{\lbgen{1}{max}}
\newcommand{\ubonemin}{\ubgen{1}{min}}

\newcommand{\pivot}{\ensuremath{\mathsf{pivot}}\xspace}
\newcommand{\trueval}{{\ensuremath{\mathsf{true}}}}
\newcommand{\falseval}{{\ensuremath{\mathsf{false}}}}
%preds symbols
\newcommand{\tpredgen}[2]{{\ensuremath{\psi^{#1}_{#2}}}\xspace}
\newcommand{\tpredigen}[1]{\tpredgen{i}{#1}}
\newcommand{\tpredij}{\tpredigen{j}}
\newcommand{\predgen}[2]{{\ensuremath{A^{#1}_{#2}}}\xspace}
\newcommand{\predigen}[1]{\predgen{i}{#1}}
\newcommand{\predij}{\predigen{j}}
\newcommand{\predonej}{\predgen{1}{j}}

% symbols for PB section (to be coherent wrt. teh rest of the paper)
\newcommand{\Agen}[1]{\ensuremath{A_{#1}}\xspace}
\newcommand{\Aj}{\Agen{j}}
\newcommand{\aij}{\ensuremath{{\sf a}_{ij}}\xspace}
\newcommand{\bi}{\ensuremath{{\sf b}_{i}}\xspace}
\newcommand{\cj}{\ensuremath{{\sf c}_{j}}\xspace}
\newcommand{\ddj}{\ensuremath{{\sf d}_{j}}\xspace}
\newcommand{\lj}{\ensuremath{{l}_{j}}\xspace}

%cost values symbols
\newcommand{\cgen}[3]{{\ensuremath{{\sf c}^{#1}_{#2#3}}}\xspace}
\newcommand{\cigen}[2]{{\ensuremath{{\sf c}^{i}_{#1#2}}}\xspace}
\newcommand{\cijgen}[1]{{\ensuremath{{\sf c}^{i}_{j#1}}}\xspace}
\newcommand{\cijone}{{\ensuremath{{\sf c}^{i}_{j1}}}\xspace}
\newcommand{\cijtwo}{{\ensuremath{{\sf c}^{i}_{j2}}}\xspace}
\newcommand{\cij}{{\ensuremath{{\sf c}^{i}_{j}}}\xspace}
\newcommand{\conej}{{\ensuremath{{\sf c}^{1}_{j}}}\xspace}

\newcommand{\cc}{{\ensuremath{{\sf c}}}\xspace}


\newcommand{\bounds}{\ensuremath{\underline{\sf bounds}}\xspace}
\newcommand{\boundi}{\ensuremath{\langle\lbi,\ubi\rangle}\xspace}

\newcommand{\icost}{\ensuremath{{\sf IC}}\xspace}
\newcommand{\icostgen}[3]{\ensuremath{\icost(#3,#2,#1)}\xspace}
%\newcommand{\icostgen}[3]{\ensuremath{\icost_{#1#2}(#3,#1)}\xspace}
\newcommand{\icosti}[1]{\icostgen{\cigen{#1}{}}{#1}{\costgen{i}}}
\newcommand{\icostij}{\icostgen{\cij}{j}{\costgen{i}}}
\newcommand{\icostonej}{\icostgen{\cgen{1}{j}{}}{j}{\costgen{1}}}

\newcommand{\bcost}{\ensuremath{{\sf BC}}\xspace}
\newcommand{\cost}{\ensuremath{{cost}}\xspace}
\renewcommand{\costs}{\ensuremath{{costs}}\xspace}
\newcommand{\mincost}{\ensuremath{{mincost}}\xspace}
\newcommand{\bound}{\ensuremath{{bound}}\xspace}
\newcommand{\guess}{\ensuremath{{guess}}\xspace}
\newcommand{\oldguess}{\ensuremath{{oldguess}}\xspace}
\newcommand{\oldbound}{\ensuremath{{oldbound}}\xspace}
\newcommand{\maxboundi}{\ensuremath{{\sf bound}^{i}_{max}}\xspace}
\newcommand{\maxboundone}{\ensuremath{{\sf bound}^{1}_{max}}\xspace}
\newcommand{\nextsmallerbound}{\ensuremath{{\sf bound}_{next}}\xspace}
\newcommand{\noroom}{\ensuremath{{\sf NR}}\xspace}
\newcommand{\mustbe}{\ensuremath{{\sf MB}}\xspace}
\newcommand{\bleft}{\ensuremath{{lower}}\xspace}
\newcommand{\bright}{\ensuremath{{upper}}\xspace}
\newcommand{\pending}{\ensuremath{{\sf pending}}\xspace}

\newcommand{\tite}{\ensuremath{{ite}}\xspace}
\newcommand{\ite}{\ensuremath{{ITE}}\xspace}

\newcommand{\costof}[2]{\ensuremath{{\sf CostOf_{#1}}(#2)}\xspace}
\newcommand{\costiof}[1]{\costof{i}{#1}}
\newcommand{\mcostof}[2]{\ensuremath{{\sf MCostOf_{#1}}(#2)}\xspace}
\newcommand{\mcostiof}[1]{\mcostof{i}{#1}}

%%% THEORY OF COSTS

\newcommand{\C}{\ensuremath{\mathcal{C}}\xspace}
\newcommand{\Clemma}{\C-lemma\xspace}
\newcommand{\Csolver}{\TsolverGen{\C}}



\newcommand{\TC}{\ensuremath{\mathcal{T}\cup\mathcal{C}}\xspace}
%\newcommand{\TC}{\ensuremath{(\mathcal{T}+\mathcal{C})}\xspace}
\newcommand{\incsmttc}{\ensuremath{\text{IncrementalSMT}_{\TC}}\xspace}
\newcommand{\smttcost}{\ensuremath{\text{SMT}(\T)+cost}\xspace}
\newcommand{\smttc}{\ensuremath{\text{SMT}({\TC})}\xspace}
\newcommand{\smtc}{\ensuremath{\text{SMT}({\C})}\xspace}
\newcommand{\Tlaint}{\ensuremath{\T\cup\laint}\xspace}
\newcommand{\smttlaint}{\ensuremath{\text{SMT}(\T\cup\laint)}\xspace}


\newcommand{\optsmttc}{\ensuremath{\text{OptSMT}_{\TC}}\xspace}

\newcommand{\decproblem}{\ensuremath{\triple{\vi}{\cost}{\bound}}\xspace}
\newcommand{\optproblem}{\ensuremath{\pair{\vi}{\cost}}\xspace}

%%% formulas
\newcommand{\vic}{\ensuremath{\vi_{\C}}\xspace}

%%% interface equalities
\newcommand{\eqij}{\ensuremath{(x_i=x_j)}\xspace}
\newcommand{\neqij}{\ensuremath{\neg(x_i=x_j)}\xspace}
\newcommand{\dij}{\ensuremath{(x_i<x_j)}\xspace}
\newcommand{\dji}{\ensuremath{(x_i>x_j)}\xspace}


%%% assignments
\newcommand{\muc}{\ensuremath{\mu_{\C}}\xspace}
\newcommand{\mucgen}[1]{\ensuremath{\mu^{#1}_{\C}}\xspace}
\newcommand{\muci}{\mucgen{i}}
\newcommand{\mut}{\ensuremath{\mu_{\T}}\xspace}
\newcommand{\mub}{\ensuremath{\mu_{\calb}}\xspace}

\newcommand{\mularat}{\ensuremath{\mu_{\larat}}\xspace}
\newcommand{\mubool}{\ensuremath{\mu_{\mathbb{B}}}\xspace}

\newcommand{\mue}{\ensuremath{\mu_{e}}\xspace}
\newcommand{\mud}{\ensuremath{\mu_{d}}\xspace}
\newcommand{\mui}{\ensuremath{\mu_{i}}\xspace}
\newcommand{\mued}{\ensuremath{\mu_{ed}}\xspace}
\newcommand{\muei}{\ensuremath{\mu_{ei}}\xspace}
\newcommand{\mueid}{\ensuremath{\mu_{eid}}\xspace}

\newcommand{\murelaxed}{\ensuremath{\mu_{rel}}\xspace}




%%% index sets
\newcommand{\Jplus}{\ensuremath{J^{i+}}\xspace}
\newcommand{\Jminus}{\ensuremath{J^{i-}}\xspace}
\newcommand{\Kplus}{\ensuremath{K^{i+}}\xspace}
\newcommand{\Kminus}{\ensuremath{K^{i-}}\xspace}
\newcommand{\Kplusone}{\ensuremath{K^{1+}}\xspace}
\newcommand{\Kminusone}{\ensuremath{K^{1-}}\xspace}


%%% interpretations
\newcommand{\Ilaint}{\ensuremath{\cali_{\laint}}\xspace}
\newcommand{\IT}{\ensuremath{\cali_{\T}}\xspace}
\newcommand{\I}{\ensuremath{\cali}\xspace}

%%% names of tools
\newcommand{\mathsatC}{\mathsat}
\newcommand{\scip}{{\sc Scip}\xspace}
\newcommand{\bsolo}{{\sc Bsolo}\xspace}
\newcommand{\satforj}{{\sc Sat4j}\xspace}
\newcommand{\pbclasp}{{\sc PBClasp}\xspace}

%%% VARIOUS
\newcommand{\bl}{\phantom{0}}



%\definecolor{mygray}{rgb}{0.99,0.99,0.99}
%% \definecolor{mygray}{rgb}{0.85,0.85,0.85}
\newcommand\mysout{\bgroup \markoverwith{{-}}\ULon}
\newcommand\nosout{\bgroup \markoverwith{{ }}\ULon}
\definecolor{mygray}{rgb}{0.90,0.90,0.90}
\definecolor{mywhite}{rgb}{1.00,1.00,1.00}
\def \gbox #1{\colorbox{mygray}{{#1}}}
\newcommand{\fal}[1]{\colorbox{mygray}{$\red{#1}$}}
\newcommand{\tru}[1]{\blue{#1}}

\newcommand{\mycite}[1]{{\footnotesize \textcolor{darkviolet}{#1}}}
\newcommand{\mcite}[1]{{\footnotesize \textcolor{darkviolet}{[#1]}}}
%\newcommand{\mycite}[1]{}

\newcommand{\mueuf}{\ensuremath{\mu_{\euf}}\xspace}
\newcommand{\mulaint}{\ensuremath{\mu_{\laint}}\xspace}
\newcommand{\infrule}[3]{\ensuremath{\displaystyle\frac{#2}{#3}}}
\newcommand{\hyp}{\textsc{Hyp}\xspace}
\newcommand{\comb}{\textsc{Comb}\xspace}

\newcommand{\fakeinfrule}[3]{\ensuremath{\displaystyle\begin{array}{l}\phantom{#2}}\\{#3}\end{array}}


%%% NUOVE DA PAPER TOCL

\newcommand{\currlb}{\ensuremath{\mathsf{l}}\xspace}
\newcommand{\currub}{\ensuremath{\mathsf{u}}\xspace}
\newcommand{\range}{\ensuremath{[\lb,\ub[}\xspace}
\newcommand{\currrange}{\ensuremath{[\currlb,\currub[}\xspace}
\newcommand{\lpivotrange}{\ensuremath{[\currlb,\pivot[}\xspace}
\newcommand{\rpivotrange}{\ensuremath{[\pivot,\currub[}\xspace}
\newcommand{\computepivot}{\ensuremath{{\sf ComputePivot}}\xspace}
%\newcommand{\dopivoting}{\ensuremath{{\sf DoPivoting()}}\xspace}
\newcommand{\dopivoting}{\ensuremath{{\sf BinSearchMode()}}\xspace}

\newcommand{\ubliti}[1]{\ensuremath{(\cost < #1)}\xspace}
\newcommand{\lbliti}[1]{\ensuremath{\neg(\cost < #1)}\xspace}
\newcommand{\pivotatom}{\ensuremath{\mathsf{PIV}}\xspace}
\newcommand{\currlblit}{\ensuremath{\neg(\cost < \currlb)}\xspace}
\newcommand{\currublit}{\ensuremath{(\cost < \currub)}\xspace}
\newcommand{\currubliti}[1]{\ensuremath{(\cost < \currub_{#1})}\xspace}
\newcommand{\negcurrubliti}[1]{\ensuremath{\neg(\cost < \currub_{#1})}\xspace}

\newcommand{\minvalue}{\ensuremath{\mathsf{min}}\xspace}
\newcommand{\maxvalue}{\ensuremath{\mathsf{max}}\xspace}
\newcommand{\mvalue}{\ensuremath{\mathsf{m}}\xspace}
\renewcommand{\mincost}{\ensuremath{\mathsf{min}_\cost}\xspace}

\newcommand{\minimize}{\ensuremath{\mathsf{Minimize}}\xspace}
\newcommand{\isminimum}{\ensuremath{\mathsf{IsMinimum}}\xspace}
%\newcommand{\incrementalsmt}{\ensuremath{\mathsf{IncrementalSMT}}\xspace}
\newcommand{\incrementalsmt}{\ensuremath{\mathsf{SMT.IncrementalSolve}}\xspace}
\newcommand{\smtcoreextract}{\ensuremath{\mathsf{SMT.ExtractUnsatCore}}\xspace}
\newcommand{\incrementalsmtcore}{\ensuremath{\mathsf{SMT.IncrementalSolve\&ExtractCore}}\xspace}
\newcommand{\laqliterals}{\larat\ensuremath{\mathsf{LiteralsOf}}\xspace}
 

\newcommand{\optimathsat}{\textsc{OptiMathSAT}\xspace}
\newcommand{\optmathsat}{\textsc{OptiMathSAT}\xspace}
\newcommand{\symba}{\textsc{Symba}\xspace}

%%%%%%%%%% RS_MACROS_SAT %%%%%%%%%%

\newcommand{\dpll}{\textsc{DPLL}\xspace}

%% SAT TOOLS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\zchaff}    {\textsc{Zchaff}\xspace}
\newcommand{\satelite}  {\textsc{SAT-Elite}\xspace}
\newcommand{\siege}     {\textsc{Siege}\xspace}
\newcommand{\berkmin}   {\textsc{BerkMin}\xspace}
\newcommand{\minisat}   {\textsc{MiniSat}\xspace}
\newcommand{\minisattwo}{\textsc{MiniSat2}\xspace}



%% DPLL FUNCTIONS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\pickassign}{\ensuremath{\sf{pick\_assignment}}\xspace}
\newcommand{\picknewassign}{\ensuremath{\sf{pick\_new\_total\_assignment}}\xspace}
\newcommand{\picktotalassign}{\ensuremath{\sf{pick\_total\_assign}}\xspace}
\newcommand{\decidebranch}{\ensuremath{\sf{decide\_new\_branch}}\xspace}
\newcommand{\decide}{\ensuremath{\sf{decide}}\xspace}
\newcommand{\blevel}{\ensuremath{\sf{blevel}}\xspace}
\newcommand{\analyzeconflict}{\ensuremath{\sf{analyze\_conflict}}\xspace}
\newcommand{\analyzededuction}{\ensuremath{\sf{analyze\_deduction}}\xspace}
\newcommand{\backtrack}{\ensuremath{\sf{backtrack}}\xspace}
\newcommand{\bcp}{\ensuremath{\sf{boolean\_constraint\_propagation}}\xspace}

%% RETURN VALUES
\newcommand{\satres}{\textsc{sat}\xspace}
\newcommand{\unsatres}{\textsc{unsat}\xspace}
\newcommand{\unknownres}{\textsc{unknown}\xspace}
\newcommand{\conflres}{\ensuremath{\mathsf{conflict}}\xspace}

%%% WALKSAT/WALKSMT
\newcommand{\walksat}{WalkSAT\xspace}
\newcommand{\basicwalksmt}{\textsc{Basic-WalkSMT}\xspace}
\newcommand{\walksmt}{\textsc{WalkSMT}\xspace}

\newcommand{\tpreprocess}{\T{}{\sc -preprocess}\xspace}
\newcommand{\initialtruthassignment}{{\sc InitialTruthAssignment}\xspace}
\newcommand{\chooseunsatisfiedclause}{{\sc ChooseUnsatisfiedClause}\xspace}
\newcommand{\nexttruthassignment}{{\sc NextTruthAssignment}\xspace}

%%%%%%%%%% RS_MACROS_SMT %%%%%%%%%%

\newcommand{\proptofol}{\ensuremath{{\cal B}2{\cal T}}\xspace}
\newcommand{\foltoprop}{\ensuremath{{\cal T}2{\cal B}}\xspace}
\newcommand{\btot}{\proptofol}
\newcommand{\ttob}{\foltoprop}
% \newcommand{\satres}{\ensuremath{\mathsf{sat}}\xspace}
% \newcommand{\unsatres}{\ensuremath{\mathsf{unsat}}\xspace}
%\newcommand{\conflres}{\ensuremath{\mathsf{conflict}}\xspace}


%%% FREQUENTLY-USED symbols
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\vip}{\ensuremath{\varphi^p}\xspace}
\newcommand{\mup}{\ensuremath{\mu^p}\xspace}
\newcommand{\muone}{\ensuremath{\mu_1}\xspace}
\newcommand{\mutwo}{\ensuremath{\mu_2}\xspace}
\newcommand{\muonetwo}{\ensuremath{\mu_1 \cup \mu_2}\xspace}
\newcommand{\taup}{\ensuremath{\tau^p}\xspace}
\newcommand{\etap}{\ensuremath{\eta^p}\xspace}
\newcommand{\cp}{\ensuremath{c^p}\xspace}

\newcommand{\atoms}[1]{\ensuremath{Atoms(#1)}\xspace}


%% THEORIES
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\B}{\ensuremath{\mathcal{B}}\xspace}
\newcommand{\T}{\ensuremath{\mathcal{T}}\xspace}
\newcommand{\Tone}{\ensuremath{\T_1}\xspace}
\newcommand{\Ttwo}{\ensuremath{\T_2}\xspace}
\newcommand{\Tonetwo}{\ensuremath{\Tone\cup \Ttwo}\xspace}
\newcommand{\smt}{SMT\xspace}
\newcommand{\smtt}{\ensuremath{\text{SMT}(\T)}\xspace}
\newcommand{\smttt}[1]{\ensuremath{\text{SMT}(#1)}\xspace}
\newcommand{\smttonettwo}{\ensuremath{\text{SMT}(\tonetwo)}\xspace}
\newcommand{\Ti}{\ensuremath{\T_i}\xspace}
\newcommand{\tmany}{\ensuremath{\bigcup_i \T_i}\xspace}
\newcommand{\smtmany}{\ensuremath{\mathit{SMT}(\bigcup_i \T_i)}\xspace}

\newcommand{\utvpi}{\ensuremath{\mathcal{UTVPI}}\xspace}
\newcommand{\utvpiint}{\ensuremath{\mathcal{UTVPI(\mathbb{Z})}}\xspace}
\newcommand{\utvpirat}{\ensuremath{\mathcal{UTVPI(\mathbb{Q})}}\xspace}
\newcommand{\bool}{\ensuremath{\mathcal{BOOL}}\xspace}
\newcommand{\euf}{\ensuremath{\mathcal{EUF}}\xspace}
\newcommand{\sk}{\ensuremath{\mathcal{SK}}\xspace}
\newcommand{\eq}{\ensuremath{\mathcal{E}}\xspace}
\newcommand{\dl}{\ensuremath{\mathcal{DL}}\xspace}
\newcommand{\dlrat}{\ensuremath{\mathcal{DL(\mathbb{Q})}}\xspace}
\newcommand{\dlint}{\ensuremath{\mathcal{DL(\mathbb{Z})}}\xspace}
\newcommand{\la}{\ensuremath{\mathcal{LA}}\xspace}
\newcommand{\larat}{\ensuremath{\mathcal{LA}(\mathbb{Q})}\xspace}
\newcommand{\laint}{\ensuremath{\mathcal{LA}(\mathbb{Z})}\xspace}
\newcommand{\laratint}{\ensuremath{\mathcal{LA}(\mathbb{Q}\mathbb{Z})}\xspace}
%%%%%%%%%%%%% RISCRITTE
\renewcommand{\la}{\ensuremath{\mathcal{LA}}\xspace}
\renewcommand{\larat}{\ensuremath{\mathcal{LRA}}\xspace}
\renewcommand{\laint}{\ensuremath{\mathcal{LIA}}\xspace}
\renewcommand{\laratint}{\ensuremath{\mathcal{LA}}\xspace}


\newcommand{\fl}{\ensuremath{\mathcal{FP}}\xspace}
\newcommand{\nla}{\ensuremath{\mathcal{NLA}}\xspace}
\newcommand{\nlarat}{\ensuremath{\mathcal{NLA}(\mathbb{R})}\xspace}
\newcommand{\nlaint}{\ensuremath{\mathcal{NLA}(\mathbb{Z})}\xspace}
\newcommand{\bv}{\ensuremath{\mathcal{BV}}\xspace}
\newcommand{\mem}{\ensuremath{\mathcal{AR}}\xspace}
\newcommand{\lists}{\ensuremath{\mathcal{LI}}\xspace}
\newcommand{\tonetwo}{\ensuremath{\T_1\cup\T_2}\xspace}

\newcommand{\smteuf}{\smttt{\euf}}
\newcommand{\smtdl}{\smttt{\dl}}
\newcommand{\smtdlrat}{\smttt{\dlrat}}
\newcommand{\smtdlint}{\smttt{\dlint}}
\newcommand{\smtutvpi}{\smttt{\utvpi}}
\newcommand{\smtutvpirat}{\smttt{\utvpirat}}
\newcommand{\smtutvpiint}{\smttt{\utvpiint}}
\newcommand{\smtla}{\smttt{\la}}
\newcommand{\smtlarat}{\smttt{\larat}}
\newcommand{\smtlaint}{\smttt{\laint}}
\newcommand{\smtbv}{\smttt{\bv}}
\newcommand{\smtmem}{\smttt{\mem}}


\newcommand{\genmodels}[1]{\models_{#1}}
\newcommand{\Tmodels}{\models_{\T}}
\newcommand{\laratmodels}{\models_{\larat}}
\newcommand{\laintmodels}{\models_{\laint}}
\newcommand{\lamodels}{\models_{\la}}
\newcommand{\dlmodels}{\models_{\dl}}
\newcommand{\dlintmodels}{\models_{\dlint}}
\newcommand{\dlratmodels}{\models_{\dlrat}}
\newcommand{\pmodels}{\models_p}

%% T-solvers
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\TsolverGen}[1]{\ensuremath{{#1}\textit{-solver}}\xspace}
\newcommand{\TsolversGen}[1]{\ensuremath{{#1}\textit{-solvers}}\xspace}
\newcommand{\Tsolver}{\TsolverGen{\T}}
\newcommand{\Tsolvers}{\TsolversGen{\T}}
\newcommand{\Psolver}{\TsolverGen{\mathsf{Bool}}}
\newcommand{\TTsolver}[1]{\TsolverGen{\ensuremath{#1}}}
\newcommand{\Tonesolver}{\TsolverGen{\ensuremath{\Tone}}}
\newcommand{\Ttwosolver}{\TsolverGen{\ensuremath{\Ttwo}}}
\newcommand{\Tonetwosolver}{\TsolverGen{\ensuremath{\Tone\cup \Ttwo}}}
\newcommand{\Tisolver}{\TsolverGen{\ensuremath{\Ti}}}
\newcommand{\Tisolvers}{\TsolversGen{\ensuremath{\Ti}}}
\newcommand{\TdeduceGen}[1]{\ensuremath{{#1}\textit{-deduce}}\xspace}
\newcommand{\Tonededuce}{\TdeduceGen{\ensuremath{\Tone}}}
\newcommand{\Ttwodeduce}{\TdeduceGen{\ensuremath{\Ttwo}}}

\newcommand{\Tlemma}{\T-lemma\xspace}
\newcommand{\Tlemmas}{\T-lemmas\xspace}
\newcommand{\Tilemma}{\Ti-lemma\xspace}
\newcommand{\Tilemmas}{\Ti-lemmas\xspace}

\newcommand{\laratsolver}{\larat-\ensuremath{\mathsf{Solver}}}
\newcommand{\laratsolvers}{\larat-\ensuremath{\mathsf{Solvers}}}
\newcommand{\laintsolver}{\laint-\ensuremath{\mathsf{Solver}}}
\newcommand{\laintsolvers}{\laint-\ensuremath{\mathsf{Solvers}}}
\newcommand{\lasolver}{\la-\ensuremath{\mathsf{Solver}}}
\newcommand{\lasolvers}{\la-\ensuremath{\mathsf{Solvers}}}

%% SMT TOOLS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%


\newcommand{\argolib}{\textsc{ArgoLib}\xspace}
\newcommand{\barcelogic}{\textsc{Barcelogic}\xspace}
\newcommand{\blast}{\textsc{Blast}\xspace}
\newcommand{\clp}{\textsc{clp-prover}\xspace}
\newcommand{\csisat}{\textsc{CSIsat}\xspace}
\newcommand{\cvcthree}{\textsc{CVC3}\xspace}
\newcommand{\foci}{\textsc{Foci}\xspace}
\newcommand{\haRVey}{\textsc{haRVey}\xspace}
\newcommand{\intjain}{\textsc{INT2}\xspace}
\newcommand{\lifter}{\textsc{Lifter}\xspace}
\newcommand{\mathsat}{\textsc{MathSAT}\xspace}
\newcommand{\verifun} {\textsc{Verifun}\xspace}
\newcommand{\yices}{\textsc{Yices}\xspace}
\newcommand{\zapato}  {\textsc{Zapato}\xspace}
\newcommand{\zap}{\textsc{Zap}\xspace}
\newcommand{\zthree}{\textsc{Z3}\xspace}

\newcommand{\microformal}{\textsc{MicroFormal}\xspace}

\newcommand{\mathsatfour}{\textsc{MathSAT4}\xspace}
\newcommand{\mathsatfive}{\textsc{MathSAT5}\xspace}
\newcommand{\mathsatfivePrep}{\textsc{MathSAT5}$_{\textsc{preprocessing}}$\xspace}
\newcommand{\mathsatfiveCleaneling}{\textsc{MathSAT5}$_{\cleaneling}$\xspace}
\newcommand{\mathsatfiveMinisat}{\textsc{MathSAT5}$_{\minisat}$\xspace}

%% THEORY COMBINATION
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\myeij}{\ensuremath{e_{ij}}\xspace}
\newcommand{\myeijs}{\ensuremath{e_{ij}}s\xspace}
\newcommand{\mynegeij}{\ensuremath{\neg e_{ij}}\xspace}
\newcommand{\eij}{\ensuremath{v_i=v_j}\xspace}
\newcommand{\eik}{\ensuremath{v_i=v_k}\xspace}
\newcommand{\ejk}{\ensuremath{v_j=v_k}\xspace}
\newcommand{\diseij}{\ensuremath{\vee(\eij)}\xspace}

\newcommand{\NO}{\ensuremath{\mathsf{no}(T_1,T_2)}\xspace}
\newcommand{\Bool}{\ensuremath{\mathsf{Bool}}\xspace}
\newcommand{\BoolGen}[1]{\ensuremath{\mathsf{Bool+}{#1}}\xspace}
\newcommand{\BoolT}{\BoolGen{T}}
\newcommand{\BoolTonetwo}{\BoolGen{T_1+T_2}}
\newcommand{\BoolTi}{\BoolGen{{T_i}}}
\newcommand{\BoolNO}{\BoolGen{\NO}}
\newcommand{\DelBoolNO}{\ensuremath{{\mathsf{Bool+}}T_1{\mathsf{+}}T_2}\xspace}
 
\newcommand{\TsatisfiableGen}[1]{\ensuremath{{#1}\textit{-satisfiable}}\xspace}
\newcommand{\TsatGen}[1]{\ensuremath{{#1}\textit{-sat}}\xspace}
\newcommand{\TunsatGen}[1]{\ensuremath{{#1}\textit{-unsat}}\xspace}
\newcommand{\Tonesat}{\TsatGen{\ensuremath{T_1}}}
\newcommand{\Ttwosat}{\TsatGen{\ensuremath{T_2}}}
\newcommand{\Toneunsat}{\TunsatGen{\ensuremath{T_1}}}
\newcommand{\Ttwounsat}{\TunsatGen{\ensuremath{T_2}}}
\newcommand{\Tsatisfiable}{\TsatisfiableGen{T}}
\newcommand{\Psatisfiable}{\TsatisfiableGen{\mathsf{Bool}}}
\newcommand{\Tonesatisfiable}{\TsatisfiableGen{\ensuremath{T_1}}}
\newcommand{\Ttwosatisfiable}{\TsatisfiableGen{\ensuremath{T_2}}}
\newcommand{\Tisatisfiable}{\TsatisfiableGen{\ensuremath{T_i}}}
 
%%%%%%%%%% RS_MACROS_SPECIFIC %%%%%%%%%%

\renewcommand{\RSTODO}[1]{\noindent{\textcolor{blue}{{\fbox{RS TODO:} #1}}}}
\newcommand{\APTODO}[1]{\noindent{\textcolor{green}{{\fbox{AP TODO:} #1}}}}
\newcommand{\PMTODO}[1]{\noindent{\textcolor{red}{{\fbox{PM TODO:} #1}}}}
\renewcommand{\TODO}[1]{\noindent{\textcolor{darkviolet}{{\fbox{TODO:} #1}}}}


\newcommand{\WMIDecompose}[2]{\ensuremath{{\sf WMIDecompose}(#1,#2)}\xspace}

 % \def\checkmark{\textcolor{darkgreen}{\tikz\fill[scale=0.4](0,.35) -- (.25,0) -- (1,.7) -- (.25,.15) -- cycle;}}

\renewcommand{\Bool}{\ensuremath{\mathbb{B}}\xspace}

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% integrals
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

\newcommand{\myint}[3]{\ensuremath{\int_{#1}^{}\! \mathrm{d}#2 \,#3}\xspace}
%% reintrodotto perche' faceva casino
\renewcommand{\myint}[3]{\ensuremath{\int_{#1}^{}#3 \ \mathrm{d}#2 }\xspace}
\newcommand{\allx}{\ensuremath{\mathbf{x}}\xspace}
\newcommand{\ally}{\ensuremath{\mathbf{y}}\xspace}
\newcommand{\allz}{\ensuremath{\mathbf{z}}\xspace}
\newcommand{\allA}{\ensuremath{\mathbf{A}}\xspace}
\newcommand{\allB}{\ensuremath{\mathbf{B}}\xspace}

\newcommand{\allAstar}{\ensuremath{\mathbf{A}^*}\xspace}

\newcommand{\allomega}{\ensuremath{\mathbf{\Omega}}\xspace}
\newcommand{\allpsi}{\ensuremath{\mathbf{\Psi}}\xspace}

\newcommand{\vi}{\ensuremath{\varphi}}

\newcommand{\viof}[2]{\ensuremath{\vi[#1,#2]}\xspace}
\newcommand{\vix}{\ensuremath{\vi[\allx]}\xspace}
\newcommand{\mux}{\ensuremath{\mu[\allx]}\xspace}
%\renewcommand{\mux}{\ensuremath{\mu}\xspace}
\newcommand{\muix}{\ensuremath{\mu_i[\allx]}\xspace}
\renewcommand{\muix}{\ensuremath{\mu_i[\allx]}\xspace}

\newcommand{\vixa}{\ensuremath{\vi(\allx,\allA)}\xspace}
\newcommand{\muxa}{\ensuremath{\mu(\allx,\allA)}\xspace}
%\renewcommand{\muxa}{\ensuremath{\mu}\xspace}
\newcommand{\muixa}{\ensuremath{\mu_i(\allx,\allA)}\xspace}
\renewcommand{\muixa}{\ensuremath{\mu_i(\allx,\allA)}\xspace}

\newcommand{\mua}{\ensuremath{\mu^{\Bool}}\xspace}
\renewcommand{\mua}{\ensuremath{\mu^{\allA}}\xspace}
\renewcommand{\mularat}{\ensuremath{\mu^{\larat}}\xspace}
\newcommand{\muj}{\ensuremath{\mu_{j}}\xspace}
\newcommand{\muja}{\ensuremath{\mu_{j}^{\Bool}}\xspace}
\renewcommand{\muja}{\ensuremath{\mu_{j}^{\allA}}\xspace}
\newcommand{\mujlarat}{\ensuremath{\mu_{j}^{\larat}}\xspace}
\newcommand{\muonea}{\ensuremath{\mu_{1}^{\Bool}}\xspace}
\renewcommand{\muonea}{\ensuremath{\mu_{1}^{\allA}}\xspace}
\newcommand{\muastar}{\ensuremath{\mu^{\allAstar}}\xspace}
\newcommand{\MUASTAR}{{\mathcal M}^{\allAstar}}

\renewcommand{\mub}{\ensuremath{\mu^{\allB}}\xspace}
\newcommand{\mupsi}{\ensuremath{\mu^{\conditionset}}\xspace}

\newcommand{\viprime}{\ensuremath{\vi'}\xspace}
\newcommand{\visecond}{\ensuremath{\vi''}\xspace}

\newcommand{\vistar}{\ensuremath{\vi^{*}}\xspace}
\newcommand{\vistarstar}{\ensuremath{\vi^{**}}\xspace}
\newcommand{\vistarof}[2]{\ensuremath{\vi^{*}(#1,#2)}\xspace}

\newcommand{\vimuagen}[2]{\ensuremath{#1_{|#2}}\xspace}
\renewcommand{\vimuagen}[2]{\ensuremath{#1_{[#2]}}\xspace}
%\newcommand{\vimua}{\ensuremath{\vi_{|\mua}}\xspace}
\newcommand{\vimua}{\vimuagen{\vi}{\mua}}
\newcommand{\viprimemua}{\vimuagen{\viprime}{\mua}}
%\newcommand{\vionemua}{\ensuremath{\vi_{1|\mua}}\xspace}
% \newcommand{\vionemua}{\vimuagen{\vi}{1|\mua}}
% \renewcommand{\vionemua}{\vi{1[\mua]}}
%\newcommand{\vitwomua}{\ensuremath{\vi_{2|\mua}}\xspace}
% \newcommand{\vitwomua}{\vimuagen{\vi}{2|\mua}}
% \renewcommand{\vitwomua}{\vi_{2[\mua]}}
%\newcommand{\vipsimua}{\ensuremath{(\vi\wedge\psi)_{|\mua}}\xspace}
\newcommand{\vipsimua}{\vimuagen{(\vi\wedge\psi)}{\mua}}
%\newcommand{\vinotpsimua}{\ensuremath{(\vi\wedge\neg\psi)_{|\mua}}\xspace}
\newcommand{\vinotpsimua}{\vimuagen{(\vi\wedge\neg\psi)}{\mua}}
%\newcommand{\vimuapsimua}{\ensuremath{\vi_{|\mua}\wedge\psi_{|\mua}}\xspace}
\newcommand{\vimuapsimua}{\vimuagen{\vi}{\mua}\wedge\vimuagen{\psi}{\mua}}
%\newcommand{\vimuanotpsimua}{\ensuremath{\vi_{|\mua}\wedge\neg\psi_{|\mua}}\xspace}
\newcommand{\vimuanotpsimua}{\vimuagen{\vi}{\mua}\wedge\vimuagen{\neg\psi}{\mua}}

\newcommand{\vistarmuastar}{\vimuagen{\vistar}{\muastar}}
\newcommand{\vistarstarmuastar}{\vimuagen{\vistarstar}{\muastar}}
\newcommand{\vistarstarmua}{\vimuagen{\vistarstar}{\mua}}

\newcommand{\w}{\ensuremath{w}\xspace}
\newcommand{\wof}[2]{\ensuremath{w(#1,#2)}\xspace}
\newcommand{\wxa}{\wof{\allx}{\allA}}
\newcommand{\wmuagen}[1]{\ensuremath{w_{|#1}}\xspace}
\renewcommand{\wmuagen}[1]{\ensuremath{w_{[#1]}}\xspace}
%\newcommand{\wmua}{\ensuremath{\w_{|\mua}}\xspace}
\newcommand{\wmua}{\wmuagen{\mua}}
\newcommand{\wmuamuaprime}{\wmuagen{\mua\vee\mua{}'}}

\newcommand{\wprime}{\ensuremath{w'}\xspace}
\newcommand{\wprimeof}[2]{\ensuremath{w'(#1,#2)}\xspace}
\newcommand{\wprimexa}{\wprimeof{\allx}{\allA}}
\newcommand{\wprimemuagen}[1]{\ensuremath{w'_{|#1}}\xspace}
\renewcommand{\wprimemuagen}[1]{\ensuremath{w'_{[#1]}}\xspace}

\newcommand{\wstar}{\ensuremath{w^{*}}\xspace}
\newcommand{\wstarof}[2]{\ensuremath{w^{*}(#1,#2)}\xspace}
\newcommand{\wstarxa}{\wstarof{\allx}{\allA}}
\newcommand{\wstarmuagen}[1]{\ensuremath{w^{*}_{|#1}}\xspace}
\renewcommand{\wstarmuagen}[1]{\ensuremath{w^{*}_{[#1]}}\xspace}
\newcommand{\wstarmuastar}{\wstarmuagen{\muastar}}

\newcommand{\wmuapsi}{\ensuremath{\wmuagen{\mua\mupsi}}}
\renewcommand{\wmuapsi}{\ensuremath{f_{\mua\mupsi}}}
\newcommand{\wmuapsis}{\ensuremath{\wmuagen{\mua\mupsi}}}
\newcommand{\wmuapsigen}[1]{\ensuremath{f_{#1}}}

% \renewcommand{\mujlarat}{\ensuremath{\mu_{j}^{\mathbb{R}}}\xspace}
% \renewcommand{\mularat}{\ensuremath{\mu^{\mathbb{R}}}\xspace}

\newcommand{\vimix}{\ensuremath{\vi^{mix}}\xspace}
\newcommand{\vimixp}{\ensuremath{\vi^{mix(p)}}\xspace}

% \newcommand{\wof}[1]{\ensuremath{w_{#1}}\xspace}
% \newcommand{\wx}{\ensuremath{w(\allx)}\xspace}
% \newcommand{\wy}{\ensuremath{w(\ally)}\xspace}
% \newcommand{\wxy}{\ensuremath{w(\allx,\ally)}\xspace}
% \newcommand{\wmu}{\ensuremath{\wof{\mu}}}
% \newcommand{\wmui}{\ensuremath{\wof{\mu_i}}\xspace}
% \newcommand{\wmux}{\ensuremath{\wof{\mu}(\allx)}}
% \newcommand{\wmuxa}{\ensuremath{\wof{\mu}(\allx,\allA)}}
% \newcommand{\wmuixa}{\ensuremath{\wof{\mu_i}(\allx,\allA)}}
% \newcommand{\wmuix}{\ensuremath{\wof{\mu_i}(\allx)}\xspace}


\newcommand{\wnb}{\ensuremath{w}\xspace}
\newcommand{\wnbof}[1]{\ensuremath{w(#1)}\xspace}


\newcommand{\WMIgen}[4]{\ensuremath{{\sf WMI}(#1,#2|#3,#4)}\xspace}
\newcommand{\WMIviwxa}{\WMIgen{\vi}{\w}{\allx}{\allA}}
\newcommand{\WMINBgen}[3]{\ensuremath{{\sf WMI_{nb}}(#1,#2|#3)}\xspace}
\newcommand{\WMIresgen}[4]{\ensuremath{{\sf WMI_{res}}(#1,#2|#3,#4)}\xspace}
\newcommand{\WMINBname}{\ensuremath{{\sf WMI_{nb}}}\xspace}
\newcommand{\WMINBviwx}{\WMINBgen{\vi}{\w}{\allx}}

\newcommand{\WMI}{\ensuremath{{\sf WMI}}\xspace}
\newcommand{\WMIold}{\ensuremath{{\sf WMI_{old}}}\xspace}
\newcommand{\WMC}{\ensuremath{{\sf WMC}}\xspace}
% \newcommand{\WMIx}{\ensuremath{{\sf WMI}_{nb}[\vi,\w]}\xspace}
% \newcommand{\WMIxa}{\ensuremath{{\sf WMI}_{wb}[\vi,\w]}\xspace}
% \newcommand{\WMIxe}{\ensuremath{{\sf WMI}_{eb}[\vi,\w]}\xspace}
% \newcommand{\WMIstar}{\ensuremath{{\sf WMI}_{*}[\vi,\w]}\xspace}
% \newcommand{\WMIxagen}[2]{\ensuremath{{\sf WMI}_{wb}[#1,#2]}\xspace}
% \newcommand{\WMIxegen}[2]{\ensuremath{{\sf WMI}_{eb}[#1,#2]}\xspace}
% \newcommand{\WMIstargen}[2]{\ensuremath{{\sf WMI}_{*}[#1,#2]}\xspace}

\newcommand{\mult}[1]{\ensuremath{m_{\mu_{#1}^{\larat}}}\xspace}

\newcommand{\supportof}[1]{\ensuremath{{\sf support}(#1)}\xspace}
\newcommand{\supportw}{\supportof{\w}\xspace}

\newcommand{\predabs}[3]{\ensuremath{{\sf PredAbs}(#1,#2,#3)}\xspace}
\renewcommand{\predabs}[3]{\ensuremath{{\sf PredAbs}_{[#1,#2]}(#3)}\xspace}
\newcommand{\predabsg}[2]{\ensuremath{{\sf PredAbs}(#1,#2)}\xspace}
\renewcommand{\predabsg}[2]{\ensuremath{{\sf PredAbs}_{[#1]}(#2)}\xspace}
\newcommand{\predabsname}{\ensuremath{{\sf PredAbs}}\xspace}

\renewcommand{\pmodels}{\models_{\Bool}}
\newcommand{\laratequiv}{\ensuremath{\Leftrightarrow_{\larat}}}
\newcommand{\boolequiv}{\ensuremath{\Leftrightarrow_{\Bool}}}
\newcommand{\starequiv}{\ensuremath{\Leftrightarrow_{*}}}
\newcommand{\laratimpl}{\ensuremath{\Rightarrow_{\larat}}}
\newcommand{\boolimpl}{\ensuremath{\Rightarrow_{\Bool}}}
\newcommand{\starimpl}{\ensuremath{\Rightarrow_{*}}}

\newcommand{\TA}[1]{\ensuremath{\calt\hspace{-.1cm}\cala(#1)}\xspace}
\newcommand{\TTA}[1]{\ensuremath{\calt\hspace{-.1cm}\calt\hspace{-.1cm}\cala(#1)}\xspace}
\newcommand{\TAb}[1]{\ensuremath{\calt\hspace{-.1cm}\cala^\mathbb{B}(#1)}\xspace}
\newcommand{\TTAb}[1]{\ensuremath{\calt\hspace{-.1cm}\calt\hspace{-.1cm}\cala^\mathbb{B}(#1)}\xspace}
\newcommand{\TTAe}{\ensuremath{\calt\hspace{-.1cm}\calt\hspace{-.1cm}\cala}}

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% example
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\newcommand{\LOC}{\ensuremath{\sf{LOC}}\xspace}

\newcommand{\ta}{\ensuremath{\sf{t}}\xspace}
\newcommand{\ti}[1]{\ensuremath{\sf{t}^{(#1)}}\xspace}
\newcommand{\tn}[1]{\ti{n}}

\newcommand{\loc}{\ensuremath{\underline{\sf{loc}}}\xspace}
\newcommand{\loci}[1]{\ensuremath{\loc^{(#1)}}\xspace}
\newcommand{\locn}{\loci{n}}

\newcommand{\dist}[2]{\ensuremath{\sf{x}_{#1#2}}\xspace}
%% ELIMINATA LA DIPENDENZA DA i e j
\renewcommand{\dist}{\ensuremath{\sf{x}}\xspace}
\newcommand{\distn}[3]{\ensuremath{\sf{x}_{#1#2}^{(#3)}}\xspace}
%% ELIMINATA LA DIPENDENZA DA i e j
\renewcommand{\distn}[1]{\ensuremath{\sf{x}^{(#1)}}\xspace}


\newcommand{\interval}[3]{\ensuremath{I_{#1#2#3}}\xspace}
\newcommand{\intervalijk}{\interval{i}{j}{k}}

\newcommand{\distr}[3]{\ensuremath{\Psi_{#1#2#3}}\xspace}
\newcommand{\distrijk}{\distr{i}{j}{k}}

\newcommand{\support}[3]{\ensuremath{R_{#1#2#3}}\xspace}
\newcommand{\supportijk}{\support{i}{j}{k}}

\newcommand{\init}{\ensuremath{{\sf Init}}}
\newcommand{\trans}{\ensuremath{{\sf Trans}}}
\newcommand{\prop}{\ensuremath{{\sf Prop}}}

\newcommand{\TransN}{\ensuremath{{\sf Trans^{N}}}}
\newcommand{\EncN}{\ensuremath{{\sf Enc^N}}}

 
\newcommand{\conditionset}{\ensuremath{\mathbf{\Psi}}}
\newcommand{\supportwff}{\ensuremath{\chi}}


\newcommand{\FI}{\ensuremath{{\sf FI}^{\larat}}\xspace}
\newcommand{\FIUC}{\ensuremath{{\sf FIUC}^{\larat}}\xspace}
\newcommand{\FIP}{\ensuremath{{\sf P}^{\larat}}\xspace}

%%% SHORTCUTS
\newcommand{\openshortcut}{\llbracket}
\newcommand{\closeshortcut}{\rrbracket}
% \renewcommand{\openshortcut}{\langle}
% \renewcommand{\closeshortcut}{\rangle}
\newcommand{\shortcut}[1]{\ensuremath{\openshortcut #1\closeshortcut\xspace}}
\newcommand{\inside}[2]{\shortcut{#1\!\in#2{}}}

\newcommand{\tit}[2]{\shortcut{{\sf If}\ #1\ {\sf Then}\ #2{}}}
\renewcommand{\tite}[3]{\shortcut{{\sf If}\ #1\ {\sf Then}\ #2\ {\sf Else}\ #3{}}}
\newcommand{\titearray}[3]
{\!\!\left \openshortcut \begin{array}{ll}
\!{\sf If}\! &\! #1 \\
\!{\sf Then}\!&\! #2 \\
\!{\sf Else}\!&\! #3 \\
\end{array} \right \closeshortcut\!\! 
}
\newcommand{\wencxya}{\ensuremath{\shortcut{y=\w}(\allx\cup\ally,\allA)}}
\newcommand{\wenc}{\ensuremath{\shortcut{y=\w}}}
\newcommand{\eufwencxya}{\ensuremath{\shortcut{y=\w}_\euf(\allx\cup\ally,\allA)}}
\newcommand{\eufwenc}{\ensuremath{\shortcut{y=\w}_\euf}}
\newcommand{\skwenc}{\ensuremath{\shortcut{\w}_\sk}}
\newcommand{\skwencwone}{\ensuremath{\shortcut{\w_1}_\sk}}
\newcommand{\skwencwtwo}{\ensuremath{\shortcut{\w_2}_\sk}}
\newcommand{\skwencwi}{\ensuremath{\shortcut{\w_i}_\sk}}
\newcommand{\vistarmua}{\vimuagen{\vi^{*}}{\mua}}
\newcommand{\wmuastar}{\wmuagen{\mua*}}

\newcommand{\case}[1]{\shortcut{{\sf Case}\ #1{}}}
\newcommand{\bigcase}[1]{\ensuremath{\left \openshortcut{\sf Case}\ #1
\right \closeshortcut}}
\newcommand{\bigcasearray}[1]{\ensuremath{\left\openshortcut%
\begin{array}{l}{\sf Case}\\ #1 \end{array}\right \closeshortcut}}

\newcommand{\oneof}[1]{\shortcut{{\sf OneOf} #1{}}}


\newcommand{\unmezzo}{\frac{1}{2}}
\renewcommand{\unmezzo}{0.5}
\newcommand{\uno}{1}
\newcommand{\tremezzi}{\frac{3}{2}}
\renewcommand{\tremezzi}{1.5}
\newcommand{\due}{2}

\newcommand{\tdep}{\ensuremath{t_{{\sf dep}}}}
\newcommand{\tarr}{\ensuremath{t_{{\sf arr}}}}

\newcommand{\sot}[1]{{\underline{#1}}}

\newcommand{\bnfsep}{\ \ |\ \ }

\newcommand{\nextlocation}{{\sf next}}


%%%%%%%%%%%%%% TODOS, NOTES, ETC
\renewcommand{\TODO}[1]{\todo[inline,color=green!40]{{\small{#1}}}}
\newcommand{\MARGTODO}[1]{\todo[color=green!40]{{\small{#1}}}}
\newcommand{\NOTE}[1]{\todo[inline,color=orange!40]{{\small{#1}}}}
%\renewcommand{\RSTODO}[1]{\todo[size=\tiny,color=green!40]{{\small{RS: #1}}}}
\newcommand{\GSTODO}[1]{\noindent{\textcolor{darkviolet}{{\fbox{GS TODO:} #1}}}}


\newcommand{\und}[1]{\underline{#1}}

\newcommand{\skeleton}[1]{\ensuremath{{\sf sk}(#1)}}
\newcommand{\skw}[1]{\skeleton{\w}}

\newcommand{\newvistar}{\ensuremath{\vi^{**}}\xspace}
\newcommand{\newvistarof}[2]{\ensuremath{\newvistar(#1,#2)}\xspace}
\newcommand{\newvistarmu}{\vimuagen{\newvistar}{\mu}}

%%% USE OF F
\newcommand{\myf}[1]{f_{#1}}
\newcommand{\myeuf}[1]{f_{#1}}
\renewcommand{\myeuf}[1]{f_{#1}(\allx)}

\renewcommand{\myf}[1]
{\ifthenelse%
 {\equal{#1}{11}}{x_1^2x_2}%
 {\ifthenelse%
  {\equal{#1}{12}}{x_1^3x_2}
  {\ifthenelse%
   {\equal{#1}{21}}{x_1x_2^2}
   {\ifthenelse%
    {\equal{#1}{22}}{x_1x_2^3}
    {\ifthenelse%
     {\equal{#1}{3}}{2x_1x_2}
     {3x_1x_2}
}}}}}

%%%%%%%%%% RS_MACROS_COLORS %%%%%%%%%%

\newcommand{\blue}[1]{\textcolor{blue}{#1}}
\newcommand{\darkblue}[1]{\textcolor{blue}{#1}}
\newcommand{\lightblue}[1]{\textcolor{lightblue4}{#1}}
\newcommand{\red}[1]{\textcolor{red}{#1}}
\newcommand{\green}[1]{\textcolor{darkgreen}{#1}}
\newcommand{\lightgreen}[1]{\textcolor{palegreen1}{#1}}
\newcommand{\violet}[1]{\textcolor{violet}{#1}}
\newcommand{\darkviolet}[1]{\textcolor{darkviolet}{#1}}
\newcommand{\darkgrey}[1]{\textcolor{darkgrey}{#1}}
\newcommand{\palegrey}[1]{\textcolor{lightgrey}{#1}}
\newcommand{\gray}[1]{\textcolor{gray}{#1}}
\newcommand{\white}[1]{\textcolor{white}{#1}}
\newcommand{\black}[1]{\textcolor{black}{#1}}
\newcommand{\orange}[1]{\textcolor{orange}{#1}}
\newcommand{\darkorange}[1]{\textcolor{darkorange3}{#1}}

\newcommand{\convert}{{\sf Convert}}
\newcommand{\convertsk}{{\sf Convert}$_{\mathcal{S}\mathcal{K}}$}
\newcommand{\term}{{\sf term}}
\renewcommand{\term}{{\sf w}}
\newcommand{\defs}{{\sf defs}}
\newcommand{\newvars}{\ally}
%\newcommand{\newvars}{{\sf newvars}}
\newcommand{\conds}{{\sf conds}}

% \newcommand<>{\blue}{\color#1{blue}}
% \newcommand<>{\darkblue}{\color#1{blue}}
% \newcommand<>{\lightblue}{\color#1{lightblue4}}
% \newcommand<>{\red}{\color#1{red}}
% \newcommand<>{\green}{\color#1{darkgreen}}
% \newcommand<>{\lightgreen}{\color#1{palegreen1}}
% \newcommand<>{\violet}{\color#1{violet}}
% \newcommand<>{\darkviolet}{\color#1{darkviolet}}
% \newcommand<>{\darkgrey}{\color#1{darkgrey}}
% \newcommand<>{\palegrey}{\color#1{lightgrey}}
% \newcommand<>{\gray}{\color#1{gray}}
% \newcommand<>{\white}{\color#1{white}}
% \newcommand<>{\black}{\color#1{black}}
% \newcommand<>{\orange}{\color#1{orange}}
% \newcommand<>{\darkorange}{\color#1{darkorange3}}

\newcommand{\AP}[1]{\noindent{\textcolor{green}{{AP: #1}}}}
\newcommand{\APCHANGE}[1]{\textcolor{brown}{#1}}
\newcommand{\PMCHANGE}[1]{\textcolor{olive}{#1}}
\newenvironment{apchange}{\color{brown}}{\normalcolor}

\newcommand{\wmipa}{\textsc{WMI-PA}\xspace}
\newcommand{\wmipaeuf}{\textsc{SA-WMI-PA}\xspace}
\newcommand{\wmiall}{\textsc{WMI-AllSMT}\xspace}
\newcommand{\wmibc}{\textsc{WMI-BC}\xspace}
\newcommand{\latteintegrale}{\textsc{LattE Integrale}\xspace}

\newcommand{\sympy}{\textsc{SymPy}\xspace}
\newcommand{\praise}{\textsc{PRAiSE}\xspace}
\newcommand{\xadd}{\textsc{SVE-XADD}\xspace}

\newcommand{\MU}{{\mathcal M}}
\newcommand{\MUA}{{\mathcal M}^{\allA}}
\newcommand{\MULARAT}{{\mathcal M}^{\larat}}

\def \calL{{\cal L}}
\def \calI{{\cal I}}

\newcommand{\location}[2]{\ensuremath{\openshortcut loc_{#1} = #2 \closeshortcut}}
\renewcommand{\location}[2]{\ensuremath{A_{#1,#2}}}

\newcommand{\lcurrent}{\ensuremath{l_{\sf curr}}}
\newcommand{\ltarget}{\ensuremath{l_{\sf target}}}
\newcommand{\Lreach}{\ensuremath{\calL_{\sf reach}}}
\newcommand{\ldep}{\ensuremath{l_{\sf dep}}}

\newcommand{\viquery}{\ensuremath{\vi_{{\sf query}}}}
\newcommand{\rngAtom}{\ensuremath{A^{\Bool/\mathbb{R}}}\xspace}
\newcommand{\rngAtomB}{\ensuremath{A^{\Bool}}\xspace}
\newcommand{\rngAtomR}{\ensuremath{A^{\mathbb{R}}}\xspace}
\newcommand{\rngTreeB}[1]{{\sf r}_\vi(#1)}
\newcommand{\rngTreeR}[1]{{\sf r}_w(#1)}


\title{SMT-based Weighted Model Integration with Structure Awareness (Supplementary material)}

% The standard author block has changed for UAI 2022 to provide
% more space for long author lists and allow for complex affiliations
%
% All author information is authomatically removed by the class for the
% anonymous submission version of your paper, so you can already add your
% information below.
%
% Add authors
\author[1]{\href{mailto:<giuseppe.spallitta@unitn.it>?Subject=WA-WMIPA}{Giuseppe Spallitta}{}}
\author[1]{Gabriele Masina}
\author[2]{Paolo Morettin}
\author[1]{Andrea Passerini}
\author[1]{Roberto Sebastiani}
% Add affiliations after the authors
\affil[1]{%
    University of Trento
}
\affil[2]{%
    KU Leuven
}
  
  \begin{document}
\maketitle


%\renewcommand{\conds}{{\allpsi}}

\section*{\eufwenc{} definition}

Algorithm~\ref{algo:convert} is such that,
given a \FIUC{} weight function \w{} on conditions
$\allpsi$, \convert{}($\w$,$\emptyset{}$) returns 
  \tuple{\w',\defs,\newvars} s.t. 
$\eufwenc{}\defas(y=\w')\wedge\bigwedge_{\vi_i\in\defs}\vi_i$, on
variables $\allx\cup\ally,\allA$.

\begin{algorithm}[h]
  \caption{
    \convert{}($\term$, $\conds{}$)\\
    returns \tuple{\w',\defs,\newvars} \\
    \w': the term \w{} is rewritten into\\
    \conds{}: the current partial assignment to conditions \allpsi, \\representing
    the set of conditions which $\w$ depends on\\
    \defs{}: a set of definitions in the form $y_i=\w_i$ needed to
    rewrite \w{} into \w{}'\\
    \ally{}: newly-introduced variables labeling if-then-else terms\\
  % \convert{}($\term$, $\conds{}$) returns
  % \tuple{\term',\defs,\newvars} s.t.\\
  % $(\conds \imp \exists y. y=\term)
  % \Longleftrightarrow
  % \exists \newvars.(\defs \wedge (\conds \imp \exists y. y=\term'))$\\
  $f^g$: uninterpreted function naming the
  function/operator $g$
%  \TODO{riscrivere come case-of...?}
%  \TODO{mettere \defs{} come variabile globale/static?}
%  \TODO{RS: togliere mutex?}
}
\begin{algorithmic}[1]
%  \IF{(\{$\term$ contains no conditions\})}
  \IF{(\{$\term$ constant or variable\})}
  \STATE {\bf return} \tuple{\term,\emptyset{},\emptyset{}}
  \ENDIF
  %
  \IF{($\term==(\term_1 \bowtie \term_2)$, $\bowtie\ \in\set{+,-,\cdot,/}$)}
  % \STATE $\tuple{\term_1',\defs_1}=\convert{}(\term_1,\conds{})$
  % \STATE $\tuple{\term_2',\defs_2}=\convert{}(\term_2,\conds{})$
  \STATE $\tuple{\term_i',\defs_i,\newvars_i}=\convert{}(\term_i,\conds{})$, $i\in{\{1,2\}}$
  \STATE {\bf return} \tuple{f^{\bowtie}(\term_1',\term_2'),\defs_1\cup \defs_2,\newvars_1\cup \newvars_2}
  \ENDIF
  %
  \IF{($\term==g(\term_1,...,\term_k)$, $g$ unconditioned)}
  \STATE $\tuple{\term_i',\defs_i,\newvars_i}=\convert{}(\term_i,\conds{})$, $i\in{1,...,k}$
  \STATE {\bf return} \tuple{f^g(\term_1',...,\term_k'),\cup_{i=1}^k \defs_i,\cup_{i=1}^k \newvars_i}
  \ENDIF
  %
  \IF{($\term==({\sf If}\ \psi\ {\sf Then}\ \term_{1}\ {\sf Else}\ {\term_{2}})$)}
  \STATE $\tuple{\term_1',\defs_1,\newvars_1}=\convert{}(\term_1,\conds{}\cup\set{\pos\psi})$
  \STATE
  $\tuple{\term_2',\defs_2,\newvars_2}=\convert{}(\term_2,\conds{}\cup\set{\neg\psi})$
  \STATE {\bf let} $y$ be a fresh variable
  \STATE $\defs=\defs_1\cup\defs_2\ \cup$ %\Comment{y fresh}
  \STATE \ \ \ \ $(\bigvee_{\psi_i\in\conds}\neg\psi_i\vee \neg \psi\vee (y=\term_1')\ \cup$
  \STATE \ \ \ \ $(\bigvee_{\psi_i\in\conds}\neg\psi_i\vee\pos \psi\vee (y=\term_2')\ \cup$
  \STATE \ \ \ \ $(\bigvee_{\psi_i\in\conds}\neg\psi_i\vee\neg(y=\term_1')\vee\neg(y=\term_2'))$
\STATE $\newvars = \newvars_1\cup\newvars_2\cup\set{y}$ 
  \STATE {\bf return} \tuple{y,\defs,\newvars}
  \ENDIF
  %  
\end{algorithmic}
\label{algo:convert}
%\TODO{RS: Check: nella riga 2 \emptyset{} e' corretto? }

\end{algorithm}

\begin{table}[tbh!]
    \centering
    \begin{tabular}{|l|c|c|c|c|}
\hline
Dataset & $|\allA|$ & $|\allx|$ & \# Train & \# Valid\\
\hline
balance-scale & 3 & 4 & 1875 & 205 \\
iris & 3 & 4 & 450 & 50 \\
cars & 33 & 7 & 2115 & 234 \\
diabetes & 1 & 8 & 4149 & 459 \\
breast-cancer & 12 & 4 & 1650 & 180 \\
glass2 & 1 & 9 & 970 & 100 \\
glass & 7 & 9 & 1280 & 140 \\
breast & 1 & 10 & 4521 & 495 \\
solar & 25 & 3 & 2522 & 273 \\
cleve & 17 & 6 & 2492 & 266 \\
hepatitis & 14 & 6 & 940 & 100 \\
heart & 3 & 11 & 2268 & 252 \\
australian & 34 & 6 & 6210 & 690 \\
crx & 38 & 6 & 6688 & 736 \\
german & 41 & 10 & 12600 & 1386 \\
german-org & 13 & 12 & 15000 & 1650 \\
auto & 56 & 16 & 2522 & 260 \\
anneal-U & 74 & 9 & 21021 & 2301 \\

\hline
\end{tabular}
\caption{UCI datasets considered in our experiments. We report the number of Boolean and continuous variables, training and validation data size.}
    \label{tab:datasets}
\end{table}


\end{document}