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

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

Figuren werkend. Kinder bedijd

File size: 10.7 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\usepackage{subfig}
16\usepackage{tikz}
17\usetikzlibrary{scopes}
18\usetikzlibrary{positioning}
19
20\author{Rick van der Zwet, Universiteit Leiden}
21\title{BDD synthese}
22\author{Rick van der Zwet\\
23 \texttt{<hvdzwet@liacs.nl>}}
24\date{\today}
25
26\begin{document}
27
28\maketitle
29
30\section{Inleiding}
31De hierin besproken inhoud is een samenvatting gemaakt van pagina 86--88 en de
32daarin genoemde opgave 60 en 63 uit het college boek~\cite{DK2009} na
33aanleiding van het vak Seminar Combinatorial Algorithms 2010~\cite{SCA2010}.
34\begin{figure}[htbp]
35\begin{tikzpicture}[on grid]
36\tikzstyle{true}=[]
37\tikzstyle{false}=[dashed]
38\tikzstyle{state}=[circle, draw]
39\tikzstyle{leaf}=[rectangle, draw]
40\begin{scope}[xshift=0cm,node distance=10mm and 10mm]
41\node (1) [state]{1};
42\node (2) [state, below=of 1]{2};
43\node (3) [state, below=of 2]{3};
44\node (4) [state, below=of 3]{4};
45\node (F) [leaf, below left=of 4]{$\bot$};
46\node (T) [leaf, below right=of 4]{$\top$};
47\path[-]
48(1) edge[false] (2)
49(1) edge[true, bend left=45] (3)
50(2) edge[false, bend right=45] (F)
51(2) edge[true] (3)
52(3) edge[false] (4)
53(3) edge[true, bend left=45] (T)
54(4) edge[true] (T)
55(4) edge[false] (F)
56;
57\draw[left, inner sep=6mm]
58(1) node {$\alpha$}
59(2) node {$\beta$}
60(3) node {$\gamma$}
61(4) node {$\delta$}
62;
63\end{scope}
64
65\begin{scope}[xshift=9cm,node distance=10mm and 10mm]
66\node (1) [state]{1};
67\node (2-1) [state, below left=of 1]{2};
68\node (2-2) [state, below right=of 1]{2};
69\node (3) [state, below left=of 2-2]{3};
70\node (4-1) [state, below left=of 3]{4};
71\node (4-2) [state, below right=of 3]{4};
72\node (F) [leaf, below=of 4-1]{$\bot$};
73\node (T) [leaf, below=of 4-2]{$\top$};
74\path[-]
75(1) edge[false] (2-1)
76(1) edge[true] (2-2)
77(2-1) edge[false] (3)
78(2-1) edge[true, bend left=70] (T)
79(2-2) edge[false, bend left=45] (T)
80(2-2) edge[true] (3)
81(3) edge[false] (4-1)
82(3) edge[true] (4-2)
83(4-1) edge[false] (T)
84(4-1) edge[false] (F)
85(4-2) edge[false] (T)
86(4-2) edge[true] (F)
87;
88\draw[left, inner sep=4mm]
89(1) node {$\omega$}
90(2-1) node {$\chi$}
91(2-2) node {$\psi$}
92(3) node {$\varphi$}
93(4-1) node {$\tau$}
94(4-2) node {$\upsilon$}
95;
96\end{scope}
97
98\begin{scope}[xshift=5cm,yshift=-5cm, node distance=15mm and 20mm]
99\node (1) [state]{1};
100\node (2-1) [state, below left=of 1]{2};
101\node (2-2) [state, below right=of 1]{2};
102\node (3-1) [state, below left=of 2-1]{3};
103\node (3-2) [state, below left=of 2-2]{3};
104\node (3-3) [state, below right=of 2-2]{3};
105\node (4-1) [state, below left=of 3-1]{4};
106\node (4-2) [state, below=of 3-1]{4};
107\node (4-3) [state, below left=of 3-2]{4};
108\node (4-4) [state, below left=of 3-3]{4};
109\node (4-5) [state, below right=of 3-3]{4};
110\node (FT) [leaf, below right=of 4-1]{};
111\node (FF) [leaf, below right=of 4-2]{};
112\node (TT) [leaf, below=of 4-4]{};
113\node (TF) [leaf, below=of 4-5]{};
114\path[-]
115(1) edge[false] (2-1)
116(1) edge[true] (2-2)
117(2-1) edge[false] (3-1)
118(2-1) edge[true] (3-2)
119(2-2) edge[false] (3-2)
120(2-2) edge[true] (3-3)
121(3-1) edge[false] (4-1)
122(3-1) edge[true] (4-2)
123(3-2) edge[false] (4-3)
124(3-2) edge[true,bend left=90] (TT)
125(3-3) edge[false] (4-4)
126(3-3) edge[true] (4-5)
127(4-1) edge[false] (FF)
128(4-1) edge[true] (FT)
129(4-2) edge[false] (FT)
130(4-2) edge[true] (FF)
131(4-3) edge[false] (FT)
132(4-3) edge[true] (TT)
133(4-4) edge[false] (FF)
134(4-4) edge[true] (TT)
135(4-5) edge[false] (TT)
136(4-5) edge[true] (TF)
137;
138\draw[left, inner sep=6mm]
139(1) node {$\alpha \diamond \omega$}
140(2-1) node {$\beta \diamond \chi$}
141(2-2) node {$\gamma \diamond \psi$}
142(3-1) node {$\bot \diamond \varphi$}
143(3-2) node {$\gamma \diamond \top$}
144(3-3) node {$\gamma \diamond \varphi$}
145(4-1) node {$\bot \diamond \tau$}
146(4-2) node {$\bot \diamond \upsilon$}
147(4-3) node {$\delta \diamond \top$}
148(4-4) node {$\delta \diamond \tau$}
149(4-5) node {$\top \diamond \upsilon$}
150(FF) node {$\bot \diamond \bot$}
151(FT) node {$\bot \diamond \top$}
152(TF) node {$\top \diamond \bot$}
153(TT) node {$\top \diamond \top$}
154;
155\end{scope}
156
157\end{tikzpicture}
158\caption{Voorbeeld: twee \emph{BDD}s die samengesmolten worden}
159\end{figure}
160
161\section{Introductie BDD}
162Synthese van een Binary Decision Diagram \emph{BDD} is het belangrijke
163\emph{BDD} algoritme~\cite[pp 86]{DK2009}. Welke in essentie een \emph{BDD}
164functie,$f$, pakt en deze combineert met een andere \emph{BDD} functie,$g$,
165zodanig dat er een nieuwe \emph{BDD} ontstaat voor de nieuwe functie.
166Bijvoorbeeld $f \wedge g$ of $f \oplus g$.
167De reden dat dit zo belangrijk is komt met het feit dat het combineren van
168\emph{BDD}s aan de basis staat aan het uitdrukken van complexe systemen dmv van
169gecombineerde simpele functies. In sectie~\ref{werking} zal deze techniek
170uitgelegd worden, het zogenoemde \emph{smelten} (\emph{melding}) welke in
171sectie~\ref{voorbeeld} dit toegepast zal worden in een concreet voorbeelden.
172
173\section{Samenvoegen van \emph{BDD}}
174\label{werking}
175De term voor het samenvoegen \emph{BDD} structuren zullen we smelten
176(\emph{melding}) noemen. Er werkt volgens de volgende principies. Men neme
177$\alpha = (v,l,h)"$ en $\alpha' = (v',l',h')$. De $\alpha \diamond \alpha'$, de
178"\emph{emulsie}" (\emph{meld}) van $\alpha$ en $\alpha'$, is dan als volgt
179gedefineerd als $\alpha$ ad $\alpha'$ niet beiden bladeren (\emph{sinks}) zijn:
180\begin{equation}
181\alpha \diamond \alpha' = \left\{
182\begin{array}{l l}
183(v, l \diamond l'), h \diamond h'), & \mathrm{if~} v = v'; \\
184(v, l \diamond \alpha'), h \diamond \alpha'), & \mathrm{if~} v < v'; \\
185(v, \alpha \diamond l'), \alpha \diamond h'), & \mathrm{if~} v > v'. \\
186\end{array} \right.
187\end{equation}
188
189De oplettende lezer (voor de rest, voorbeeld figuur~\ref{voorbeeldSamenvoegen}) zal
190zien dat je door het samenvoegen van de bladeren er in plaats van de twee bladeren
191$\top$ en $\bot$, er nu vier bladeren mogelijk zijn:
192\begin{equation}
193\label{bladeren}
194\begin{array}{l l l l}
195\bot \diamond \bot, & \bot \diamond \top, & \top \diamond \bot, & \top \diamond \top\\
196\end{array}
197\end{equation}
198Om er weer een 'valide' \emph{BDD} van te maken zullen deze bladeren vervangen
199worden door het uitgerekende blad. Als bijvoorbeeld de $\diamond$ operatie een
200$EN$ operatie was, wordt de bladrij in~\ref{bladeren} vervangen door de rij
201$\bot, \bot, \bot, \top$. Nu is het zaak de \emph{BDD} te vereenvoudigen, om zo
202duplicaat bladeren te snoeien (\emph{pruning}).
203
204De kracht van deze aanpak zit hem in de zogenoemde generieke $\diamond$
205operatie. Het maakt niet uit welke booleaanse operatie er gebruikt wordt aan
206het eind van de rit. De gegeneerde gesmolten \emph{BDD} is geldig voor allen.
207
208Kijkend naar de limieten moet geoordeeld worden kan hetzelfde altijd bereikt
209worden door in het slechte geval de \emph{BDD}s achter elkaar te plakken welke
210dan in dit geval $B(f)B(g)$ knopen oplevert. Voorbeeld~\ref{voorbeeldPlakken}
211is hier een geval van. In het meer algemene geval geldt meestal $B(f) + B(g)$.
212Deze grenzen worden in voorbeeld~\ref{voorbeeldSamenvoegen} aangescherpt.
213
214Het smelten ligt aan de basis van de daarwerkelijke synthese. Een simpele
215variant kan gemaakt worden met algoritme $R$. Maak eerst een reeks van
216alle knopen $\alpha$ in $B(f)$ en $\alpha'$ in $B(g)$ met knoop $\alpha
217\diamond \alpha'$ in rij $\alpha$ en column $\alpha'$. Vervang de bladeren
218(\ref{bladeren}) door $\bot$ en $\top$. En voor algoritme $R$ uit op $f \diamond
219g$. Op het eerste gezicht lijkt algoritme $R$ er ongeveer $B(f)B(g)$ over te
220doen, maar doordat je onbereikbare knopen niet hoeft te evalueren zal je
221uitkomen op $B(f \diamond g)$.
222
223Deze 'truc' zorgt ervoor dat de tijd binnen de perken blijft, maar er is dan
224nog niets gezegt over de hoeveelheid geheugen er nodig is. Omdat er nu
225$B(f)B(g)$ knopen in geheugen gehouden moet wordt zal dit problemen opleveren
226bij kleine en grotere algoritmen. Om deze ineffientie aan te pakken is
227algoritme $S$ \footnote{Algoritme $S$ wordt niet in deze samenvatting gehandeld
228de vakwebsite~\cite{SCA2010} heeft een verwijzing van de samenvatting van dit
229algoritme} ontworpen.
230
231
232\section{Voorbeelden}
233\label{voorbeeld}
234\subsection{Product groei in synthese van \emph{BDD}}
235\label{voorbeeldSamenvoegen}
236Het volgende voorbeeld is een uitwerking van opgave 60~\cite[pg. 130]{DK2009}
237de offi\"{e}le uitwerking is te vinden op pagina 195~\cite{DK2009}
238
239Neem aan dat $f(x_{1},...,x_{n})$ en $g(x_{1},...,x_{n})$ de respectieve
240\emph{profielen} (\emph{profiles})~\cite[pg 101]{DK2009} $(b_{0},...,b_{n})$ en
241$(b'_{0},...,b_{n})$ hebben. En de respectieve \emph{quasi-profielen}
242(\emph{quasi-profiles})~\cite[pg 103]{DK2009} $(q_{0},...,q_{n})$ en
243$(q'_{0},...,q'_{n})$. Om te laten zijn dat de gesmolten $f \diamond g$ het
244aantal knopen van $B(f \diamond g) \leq
245\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$.
246
247Elke 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.
248
249Dit 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.
250
251\subsection{Som groei in synthese van \emph{BDD}}
252\label{voorbeeldPlakken}
253Het volgende voorbeeld is een uitwerking van opgave 63~\cite[pg. 131]{DK2009}
254de offi\"{e}le uitwerking is te vinden op pagina 195~\cite{DK2009}
255
256Laat $f(x_{1},...,x_{n}) = M_{m}(x_{1} \oplus x_{2},x_{3} \oplus
257x_{4},...,x_{2m-1} \oplus x_{2m};x_{2m+1},...,x_{n})$ en $g(x_{1},...,x_{n}) =
258M_{m}(x_{2} \oplus x_{3},...,x_{2m-2} \oplus x_{2m-1},x_{2m};\overline
259x_{2m+1},...,\overline x_{n})$ waar $n = 2m + 2^{m}$.
260
261Dan is $B(f) = 2^{m+2}-1 \approx 4n$, $B(g) = 2^{m+1}-2^{m} \approx 3n$ en $B(g
262\hat f) = 2^{m+1}+2^{m-1}-1 \approx 2n^{2}$. Om aan deze 'magische' reeksen te
263komen is het belangrijk eerst naar de profielen te kijken van $f$ en $g$ om daarna met sommering van deze tot de antwoorden te komen.
264
265
266
267
268
269\begin{thebibliography}{}
270\bibitem[DK2009]{DK2009} D.E. Knuth. Fascicle 1. \texttt{Bitwise Tricks \&
271Techniques; Binary Decision Diagrams}, volume 4 of \texttt{The Art of Computer
272Programming}. Pearson Education, first edition, March 2009.
273\bibitem[SCA2010]{SCA2010} Lecture Seminar Combinatorial Algorithms,
274\url{http://www.liacs.nl/~kosters/semcom/}, dr. W.A. (Walter) Kosters, LIACS,
275Spring 2010
276
277\end{thebibliography}
278\end{document}
Note: See TracBrowser for help on using the repository browser.