Changeset 164 for liacs/SCA2010/BDD


Ignore:
Timestamp:
Jul 27, 2010, 10:04:48 AM (14 years ago)
Author:
Rick van der Zwet
Message:

First block of corrections

File:
1 edited

Legend:

Unmodified
Added
Removed
  • liacs/SCA2010/BDD/report.tex

    r139 r164  
    3030\section{Inleiding}
    3131De hierin besproken inhoud is een samenvatting gemaakt van pagina 86--88 en de
    32 daarin genoemde opgave 60 en 63 uit het college boek~\cite{DK2009} na
     32daarin genoemde opgave 60 en 63 uit het college boek~\cite{DK2009} naar
    3333aanleiding van het vak Seminar Combinatorial Algorithms 2010~\cite{SCA2010}.
    3434\begin{figure}[htbp]
     35\label{voorbeeldSamenvoegen}
    3536\begin{tikzpicture}[on grid]
    3637\tikzstyle{true}=[]
     
    157158\end{tikzpicture}
    158159\caption{Voorbeeld: twee \emph{BDD}s die samengesmolten worden door gebruik te
    159 maken van formule~\ref{melt-eq}. Let wel op dat dit voorbeeld geen ontbrekende
    160 laag van nodes heeft, waardoor nodes van alle niveaus beschikbaar zijn. Op het
    161 moment dat de $\diamond$ ingevuld gaat worden is het ook zaak om de bladeren
    162 (zie vergelijking~\ref{bladeren}) te vereenvoudigen} \end{figure}
     160maken van formule~\ref{melt-eq}. Let er wel op dat dit voorbeeld geen
     161ontbrekende laag van knopen heeft, waardoor knopen van alle niveaus beschikbaar
     162zijn. Op het moment dat de $\diamond$ ingevuld gaat worden is het ook zaak om
     163de bladeren (zie vergelijking~\ref{bladeren}) te vereenvoudigen} \end{figure}
    163164
    164165\section{Introductie BDD}
    165 Synthese van een Binary Decision Diagram \emph{BDD} is het belangrijke
    166 \emph{BDD} algoritme~\cite[pg 86]{DK2009}. Welke in essentie een \emph{BDD}
    167 functie,$f$, pakt en deze combineert met een andere \emph{BDD} functie,$g$,
    168 zodanig dat er een nieuwe \emph{BDD} ontstaat voor de nieuwe functie.
    169 Bijvoorbeeld $f \wedge g$ of $f \oplus g$.
     166Synthese van een Binary Decision Diagram \emph{BDD} is een belangrijk
     167\emph{BDD} algoritme~\cite[p.~86]{DK2009}. Het neemt in essentie een \emph{BDD}
     168functie $f$ en combineert deze met een andere \emph{BDD} functie $g$
     169zodanig dat er een nieuwe \emph{BDD} ontstaat voor een nieuwe functie,
     170bijvoorbeeld $f \wedge g$ of $f \oplus g$.
    170171De reden dat dit zo belangrijk is komt met het feit dat het combineren van
    171 \emph{BDD}s aan de basis staat aan het uitdrukken van complexe systemen dmv van
    172 gecombineerde simpele functies. In sectie~\ref{werking} zal deze techniek
    173 uitgelegd worden, het zogenoemde \emph{smelten} (\emph{melding}) welke in
    174 sectie~\ref{voorbeeld} dit toegepast zal worden in een concreet voorbeelden.
     172\emph{BDD}s aan de basis staat van het uitdrukken van complexe systemen door
     173middel van gecombineerde simpele functies. In Hoofdstuk~\ref{werking} zal deze
     174techniek uitgelegd worden, het zogenoemde \emph{smelten} (\emph{melding}) dat
     175in Hoofdstuk~\ref{voorbeeld} toegepast zal worden in een concreet voorbeelden.
    175176
    176177\section{Samenvoegen van \emph{BDD}}
    177178\label{werking}
    178 De term voor het samenvoegen \emph{BDD} structuren zullen we smelten
    179 (\emph{melding}) noemen. Er werkt volgens de volgende principes.  Men neme
    180 $\alpha = (v,l,h)"$ en $\alpha' = (v',l',h')$. De $\alpha \diamond \alpha'$, de
    181 "\emph{emulsie}" (\emph{meld}) van $\alpha$ en $\alpha'$, is dan als volgt
    182 gedefinieerd als $\alpha$ ad $\alpha'$ niet beiden bladeren (\emph{sinks}) zijn:
     179De term voor het samenvoegen van \emph{BDD} structuren zullen we smelten
     180(\emph{melding}) noemen. Het werkt volgens de volgende principes.  Men neme
     181twee knopen $\alpha = (v,l,h)$ en $\alpha' = (v',l',h')$. De knoop $\alpha
     182\diamond \alpha'$, de ``\emph{emulsie}'' (\emph{meld}) van $\alpha$ en
     183$\alpha'$, is dan als volgt gedefinieerd als $\alpha$ en $\alpha'$ niet beiden
     184bladeren (\emph{sinks}) zijn:
    183185\begin{equation}
    184186\label{melt-eq}
    185187\alpha \diamond \alpha' = \left\{
    186188\begin{array}{l l}
    187 (v, l \diamond l'), h \diamond h'), & \mathrm{als~} v = v'; \\
    188 (v, l \diamond \alpha'), h \diamond \alpha'), & \mathrm{als~} v < v'; \\
    189 (v, \alpha \diamond l'), \alpha \diamond h'), & \mathrm{als~} v > v'. \\
     189(v, l \diamond l', h \diamond h'), & \mathrm{als~} v = v'; \\
     190(v, l \diamond \alpha', h \diamond \alpha'), & \mathrm{als~} v < v'; \\
     191(v, \alpha \diamond l', \alpha \diamond h'), & \mathrm{als~} v > v'. \\
    190192\end{array} \right.
    191193\end{equation}
    192194
    193 De oplettende lezer (voor de rest, voorbeeld figuur~\ref{voorbeeldSamenvoegen}) zal
    194 zien dat je door het samenvoegen van de bladeren er in plaats van de twee bladeren
     195De oplettende lezer zal zien dan als je Formule~\ref{melt-eq} toepast op de
     196bladeren er door samenvoegen van de bladeren ---zie bijvoorbeeld
     197Figuur~\ref{voorbeeldSamenvoegen}--- in plaats van de twee bladeren
    195198$\top$ en $\bot$, er nu vier bladeren mogelijk zijn:
    196199\begin{equation}
     
    200203\end{array}
    201204\end{equation}
    202 Om er weer een 'valide' \emph{BDD} van te maken zullen deze bladeren vervangen
    203 worden door het uitgerekende blad. Als bijvoorbeeld de $\diamond$ operatie een
    204 $EN$ operatie was, wordt de blad-rij in~\ref{bladeren} vervangen door de rij
    205 $\bot, \bot, \bot, \top$. Nu is het zaak de \emph{BDD} te vereenvoudigen, om zo
    206 duplicaat bladeren te snoeien (\emph{pruning}).
    207 
    208 De kracht van deze aanpak zit hem in de zogenoemde generieke $\diamond$
     205Om er weer een ``valide'' \emph{BDD} van te maken zullen deze bladeren vervangen
     206worden door het uitgerekende blad. Door bijvoorbeeld voor de $\diamond$ operatie een
     207\emph{EN} operatie te nemen, wordt de blad-rij in~\ref{bladeren} vervangen door de rij
     208$\bot, \bot, \bot, \top$. Nu is het zaak het \emph{BDD} te vereenvoudigen, om zo
     209duplicaat-bladeren te snoeien (\emph{pruning}).
     210
     211De kracht van deze aanpak zit hem in de generieke $\diamond$
    209212operatie. Het maakt niet uit welke booleaanse operatie er gebruikt wordt aan
    210 het eind van de rit. De gegeneerde gesmolten \emph{BDD} is geldig voor allen.
     213het eind van de rit. De gegeneerde gesmolten \emph{BDD} is geldig voor alle.
    211214
    212215Kijkend naar de limieten moet geoordeeld worden kan hetzelfde altijd bereikt
     
    304307
    305308\begin{thebibliography}{}
    306 \bibitem[DK2009]{DK2009} D.E. Knuth. Fascicle 1. \texttt{Bitwise Tricks \&
    307 Techniques; Binary Decision Diagrams}, volume 4 of \texttt{The Art of Computer
    308 Programming}. Pearson Education, first edition, March 2009.
    309 \bibitem[DK2009-Fas0]{DK2009-0} D.E. Knuth. Fascicle 0. \texttt{Bitwise Tricks \&
    310 Techniques; Binary Decision Diagrams}, volume 4 of \texttt{The Art of Computer
    311 Programming}. Pearson Education, first edition, March 2009.
     309\bibitem[DK2009]{DK2009} D.E. Knuth. Bitwise Tricks \& Techniques; Binary
     310Decision Diagrams, volume 4, Fascicle 1, of The Art of Computer Programming.
     311Pearson Education, first edition, 2009.
     312\bibitem[DK2009-Fas0]{DK2009-0} D.E. Knuth. Bitwise Tricks \& Techniques;
     313Binary Decision Diagrams, volume 4, Fascicle 0, of The Art of Computer
     314Programming. Pearson Education, first edition, 2009.
    312315\bibitem[SCA2010]{SCA2010} Lecture Seminar Combinatorial Algorithms,
    313 \url{http://www.liacs.nl/~kosters/semcom/}, dr. W.A. (Walter) Kosters, LIACS,
    314 Spring 2010
     316\url{http://www.liacs.nl/~kosters/semcom/}, W.A. (Walter) Kosters, LIACS,
     317Spring 2010.
    315318
    316319\end{thebibliography}
Note: See TracChangeset for help on using the changeset viewer.