source: liacs/SCA2010/BDD/report.tex@ 136

Last change on this file since 136 was 135, checked in by Rick van der Zwet, 14 years ago

Bunch of formula's added

File size: 7.1 KB
Line 
1%
2% $Id: report.tex 571 2008-04-20 17:31:04Z rick $
3%
4
5\documentclass[12pt,a4paper]{article}
6
7\frenchspacing
8\usepackage[english,dutch]{babel}
9\selectlanguage{dutch}
10\usepackage{graphicx}
11\usepackage{url}
12\usepackage{multicol}
13\usepackage{fancybox}
14\usepackage{amssymb,amsmath}
15
16\author{Rick van der Zwet, Universiteit Leiden}
17\title{BDD synthese}
18\author{Rick van der Zwet\\
19 \texttt{<hvdzwet@liacs.nl>}}
20\date{\today}
21
22\begin{document}
23
24\maketitle
25
26\section{Inleiding}
27De hierin besproken inhoud is een samenvatting gemaakt van pagina 86--88 en de
28daarin genoemde opgave 60 en 63 uit het college boek~\cite{DK2009} na
29aanleiding van het vak Seminar Combinatorial Algorithms 2010~\cite{SCA2010}.
30
31
32\section{Introductie BDD}
33Synthese van een Binary Decision Diagram \emph{BDD} is het belangrijke
34\emph{BDD} algoritme~\cite[pp 86]{DK2009}. Welke in essentie een \emph{BDD}
35functie,$f$, pakt en deze combineert met een andere \emph{BDD} functie,$g$,
36zodanig dat er een nieuwe \emph{BDD} ontstaat voor de nieuwe functie.
37Bijvoorbeeld $f \wedge g$ of $f \oplus g$.
38De reden dat dit zo belangrijk is komt met het feit dat het combineren van
39\emph{BDD}s aan de basis staat aan het uitdrukken van complexe systemen dmv van
40gecombineerde simpele functies. In sectie~\ref{werking} zal deze techniek
41uitgelegd worden, het zogenoemde \emph{smelten} (\emph{melding}) welke in
42sectie~\ref{voorbeeld} dit toegepast zal worden in een concreet voorbeelden.
43
44\section{Samenvoegen van \emph{BDD}}
45\label{werking}
46De term voor het samenvoegen \emph{BDD} structuren zullen we smelten
47(\emph{melding}) noemen. Er werkt volgens de volgende principies. Men neme
48$\alpha = (v,l,h)"$ en $\alpha' = (v',l',h')$. De $\alpha \diamond \alpha'$, de
49"\emph{emulsie}" (\emph{meld}) van $\alpha$ en $\alpha'$, is dan als volgt
50gedefineerd als $\alpha$ ad $\alpha'$ niet beiden bladeren (\emph{sinks}) zijn:
51\begin{equation}
52\alpha \diamond \alpha' = \left\{
53\begin{array}{l l}
54(v, l \diamond l'), h \diamond h'), & \mathrm{if~} v = v'; \\
55(v, l \diamond \alpha'), h \diamond \alpha'), & \mathrm{if~} v < v'; \\
56(v, \alpha \diamond l'), \alpha \diamond h'), & \mathrm{if~} v > v'. \\
57\end{array} \right.
58\end{equation}
59
60De oplettende lezer (voor de rest, voorbeeld figuur~\ref{voorbeeldSamenvoegen}) zal
61zien dat je door het samenvoegen van de bladeren er in plaats van de twee bladeren
62$\top$ en $\bot$, er nu vier bladeren mogelijk zijn:
63\begin{equation}
64\label{bladeren}
65\begin{array}{l l l l}
66\bot \diamond \bot, & \bot \diamond \top, & \top \diamond \bot, & \top \diamond \top\\
67\end{array}
68\end{equation}
69Om er weer een 'valide' \emph{BDD} van te maken zullen deze bladeren vervangen
70worden door het uitgerekende blad. Als bijvoorbeeld de $\diamond$ operatie een
71$EN$ operatie was, wordt de bladrij in~\ref{bladeren} vervangen door de rij
72$\bot, \bot, \bot, \top$. Nu is het zaak de \emph{BDD} te vereenvoudigen, om zo
73duplicaat bladeren te snoeien (\emph{pruning}).
74
75De kracht van deze aanpak zit hem in de zogenoemde generieke $\diamond$
76operatie. Het maakt niet uit welke booleaanse operatie er gebruikt wordt aan
77het eind van de rit. De gegeneerde gesmolten \emph{BDD} is geldig voor allen.
78
79Kijkend naar de limieten moet geoordeeld worden kan hetzelfde altijd bereikt
80worden door in het slechte geval de \emph{BDD}s achter elkaar te plakken welke
81dan in dit geval $B(f)B(g)$ knopen oplevert. Voorbeeld~\ref{voorbeeldPlakken}
82is hier een geval van. In het meer algemene geval geldt meestal $B(f) + B(g)$.
83Deze grenzen worden in voorbeeld~\ref{voorbeeldSamenvoegen} aangescherpt.
84
85Het smelten ligt aan de basis van de daarwerkelijke synthese. Een simpele
86variant kan gemaakt worden met algoritme $R$. Maak eerst een reeks van
87alle knopen $\alpha$ in $B(f)$ en $\alpha'$ in $B(g)$ met knoop $\alpha
88\diamond \alpha'$ in rij $\alpha$ en column $\alpha'$. Vervang de bladeren
89(\ref{bladeren}) door $\bot$ en $\top$. En voor algoritme $R$ uit op $f \diamond
90g$. Op het eerste gezicht lijkt algoritme $R$ er ongeveer $B(f)B(g)$ over te
91doen, maar doordat je onbereikbare knopen niet hoeft te evalueren zal je
92uitkomen op $B(f \diamond g)$.
93
94Deze 'truc' zorgt ervoor dat de tijd binnen de perken blijft, maar er is dan
95nog niets gezegt over de hoeveelheid geheugen er nodig is. Omdat er nu
96$B(f)B(g)$ knopen in geheugen gehouden moet wordt zal dit problemen opleveren
97bij kleine en grotere algoritmen. Om deze ineffientie aan te pakken is
98algoritme $S$ \footnote{Algoritme $S$ wordt niet in deze samenvatting gehandeld
99de vakwebsite~\cite{SCA2010} heeft een verwijzing van de samenvatting van dit
100algoritme} ontworpen.
101
102
103\section{Voorbeelden}
104\label{voorbeeld}
105\subsection{Product groei in synthese van \emph{BDD}}
106\label{voorbeeldSamenvoegen}
107Het volgende voorbeeld is een uitwerking van opgave 60~\cite[pg. 130]{DK2009}
108de offi\"{e}le uitwerking is te vinden op pagina 195~\cite{DK2009}
109
110Neem aan dat $f(x_{1},...,x_{n})$ en $g(x_{1},...,x_{n})$ de respectieve
111\emph{profielen} (\emph{profiles})~\cite[pg 101]{DK2009} $(b_{0},...,b_{n})$ en
112$(b'_{0},...,b_{n})$ hebben. En de respectieve \emph{quasi-profielen}
113(\emph{quasi-profiles})~\cite[pg 103]{DK2009} $(q_{0},...,q_{n})$ en
114$(q'_{0},...,q'_{n})$. Om te laten zijn dat de gesmolten $f \diamond g$ het
115aantal knopen van $B(f \diamond g) \leq
116\sum^{n}_{j=0}(q_{j}b'_{j}+b_{j}q'_{j}-b_{j}b'_{j})$ bevat moet gekeken worden aan het aantal \emph{beads}~\cite[pg 72]{DK2009} dat mogelijkerwijs gemaakt kunnen worden van de functies $f$ en $g$.
117
118Elke bead van de orde $n - j$ van het geoordende paar $(f,g)$ zal binnen de standaard combinatie vallen de $b_{j}b_{j}'$ geordende beats van $(f,g)$. vallen of is er eentje uit een meer speciaal gegenereerde reeks van een (bead,geen-bead) of (geen-bead, bead) $b_{j}(q_{j}' - b_{j}') + (q_{j} - b{j})b_{j}'$. Zie hierbij dat van een functie het $B(quasi-profiel) \geq B(profiel)$. En dat alle in het profiel altijd in het quasi-profiel zit. Er dus de geen-bead kan beschrijven als de rest van de quasi-profiel minus profiel.
119
120Dit bij elkaar optellen levert op $b_{j}b_{j}' + b_{j}(q_{j}' - b_{j}') + (q_{j} - b{j})b_{j}'$. Vereenvoudigen en de sommering is oefening voor de lezer.
121
122\subsection{Som groei in synthese van \emph{BDD}}
123\label{voorbeeldPlakken}
124Het volgende voorbeeld is een uitwerking van opgave 63~\cite[pg. 131]{DK2009}
125de offi\"{e}le uitwerking is te vinden op pagina 195~\cite{DK2009}
126
127Laat $f(x_{1},...,x_{n}) = M_{m}(x_{1} \oplus x_{2},x_{3} \oplus
128x_{4},...,x_{2m-1} \oplus x_{2m};x_{2m+1},...,x_{n})$ en $g(x_{1},...,x_{n}) =
129M_{m}(x_{2} \oplus x_{3},...,x_{2m-2} \oplus x_{2m-1},x_{2m};\overline
130x_{2m+1},...,\overline x_{n})$ waar $n = 2m + 2^{m}$.
131
132Dan is $B(f) = 2^{m+2}-1 \approx 4n$, $B(g) = 2^{m+1}-2^{m} \approx 3n$ en $B(g
133\hat f) = 2^{m+1}+2^{m-1}-1 \approx 2n^{2}$. Om aan deze 'magische' reeksen te
134komen is het belangrijk eerst naar de profielen te kijken.
135
136
137
138
139
140\begin{thebibliography}{}
141\bibitem[DK2009]{DK2009} D.E. Knuth. Fascicle 1. \texttt{Bitwise Tricks \&
142Techniques; Binary Decision Diagrams}, volume 4 of \texttt{The Art of Computer
143Programming}. Pearson Education, first edition, March 2009.
144\bibitem[SCA2010]{SCA2010} Lecture Seminar Combinatorial Algorithms,
145\url{http://www.liacs.nl/~kosters/semcom/}, dr. W.A. (Walter) Kosters, LIACS,
146Spring 2010
147
148\end{thebibliography}
149\end{document}
Note: See TracBrowser for help on using the repository browser.