Ignore:
Timestamp:
Dec 8, 2010, 6:50:15 PM (14 years ago)
Author:
Rick van der Zwet
Message:

Part of 3.22a

Location:
liacs/TPFL2010/assignment1
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • liacs/TPFL2010/assignment1/report.tex

    r244 r245  
    7575$xz \in L, yz \notin L$.
    7676
    77 De taal $M = {0}^* : |M|_0~is~een~priemgetal$  is een ander voorbeeld. Als we
     77De taal $M = \{{0}^* : |M|_0~is~een~priemgetal\}$  is een ander voorbeeld. Als we
    7878kijken naar $aR_{l}b$ kan er altijd een $z$ gevormd worden zodanig dat $az \in
    7979M, bz \notin M$. Bijvoorbeeld $a = 0^3, b =0^5, z = 0^4$. Deze eigenschap wordt
     
    9393Als eerste kan de $F_n$ door een \emph{2DFA} van $O(n)$ toestanden geaccepteerd
    9494worden, welke aan te tonen is door eerst te kijken naar de eigenschappen van
    95 $F_n$ hierbij is de zien dat de $0$-reeks van de lengte $i^k$ zowel voor als na
     95$F_n$ hierbij is de zien dat de $0$-reeks van de lengte $i_k$ zowel voor als na
    9696de $2^k$ moet voorkomen. Waarbij $2^k$ aangeeft, waar deze $0$-reeks gevonden
    97 kan worden e.g. bij welke $i_x$. De \emph{2DFA} moet dus twee dingen doen. Het
     97kan worden bij de plek $k$. De \emph{2DFA} moet dus twee dingen doen. Het
    9898aantal keer nul op twee plekken vergelijken. Waarbij 1 plek vast staat en de
    99 tweede plek variabele wordt gedefinieerd. Dit lijkt mij controleren op twee los
    100 staande feiten. Hiervoor heb ik \underline{geen} antwoord gevonden. Ik kan
    101 enkel wat voor $O(n^2)$ bedenken, welke een idee is in Figuur~\ref{fig:idee}
    102 uitgewerkt is.
     99tweede plek variabele wordt gedefinieerd. De aanpak kan als volgt gezien worden:
     100\begin{verbatim}
     1011. controleren of |1| <= 2de 0-reeks (dmv 'knopen-strook').
     1022. |2| tellen (onthouden dmv 'knopen-strook', dit is `variable' A).
     1033. naar begin lopen.
     1044. A-1 '1' instanties laten passeren.
     1055. |0| tellen (onthouden dmv 'knopen-strook'm dit is `variable' A).
     1066. naar begin 2de 0-reeks lopen.
     1077. 0-reeks vergelijken.
     108\end{verbatim}
     109Voor deze aanpak zijn 3 `knopen-stroken' nodig en 3 transitie-lagen. In totaal
     110dus in ongeveer $O(6n)$ knopen.  Figuur~\ref{fig:2dfa} laat de \emph{2DFA}
     111zien.
    103112
    104113
     
    106115\center
    107116\begin{tikzpicture}
    108 \node[place,pin={[pin edge={style=<-,blue,thick,decorate,decoration={snake, pre length=4pt}}]left:}] (q0) {};
    109 \node[place] (q1) [below=of q0] {};
    110 \node[place] (q2) [below=of q1] {};
    111 \node[place,pin={[pin edge={style=-<,thick,decorate,decoration={snake, pre length=4pt}}]below:}] (q3) [below=of q2] {};
    112 \node[place] (q01) [right=3cm of q1] {};
    113 \node[place] (q02) [right=3cm of q2] {};
     117\node[place,pin={[pin edge={style=<-,blue,thick,decorate,decoration={snake, pre length=4pt}}]left:}] (q00) {};
     118\node[place] (q01) [right=of q00] {};
     119\node[place] (q02) [right=of q01] {};
     120\node[place] (q03) [right=of q02] {};
     121\node[place] (q11) [below=of q01] {};
     122\node[place] (q12) [below=of q02] {};
     123\node[place] (q13) [below=of q03] {};
     124\node[place] (q10) [below=of q00] {};
     125\node[place] (q20) [below=of q10] {};
     126\node[place] (q21) [below=of q11] {};
     127\node[place] (q22) [below=of q12] {};
     128%\node[place] (q2) [below=of q1] {};
     129%\node[place,pin={[pin edge={style=-<,thick,decorate,decoration={snake, pre length=4pt}}]below:}] (q3) [below=of q2] {};
     130%\node[place] (q01) [right=3cm of q1] {};
     131%\node[place] (q02) [right=3cm of q2] {};
    114132\path[->]
    115           (q0) edge [decorate,decoration={snake}] node[left] {goto-2} (q1)
    116           (q1) edge              node[left] {2} (q2)
    117           (q2) edge              node[left] {2} (q3)
    118           (q1) edge [decorate,decoration={snake}] node[above] {0-length-check} (q01)
    119           (q2) edge [decorate,decoration={snake}] node[above] {0-length-check} (q02)
     133%          (q0) edge [decorate,decoration={snake}] node[left] {goto-2} (q00)
     134          (q00) edge               node[above] {3,R} (q01)
     135          (q01) edge               node[above] {1,R} (q02)
     136          (q01) edge [loop above]  node[above] {0,R} (q01)
     137          (q02) edge               node[above] {1,R} (q03)
     138          (q02) edge [loop above]  node[above] {0,R} (q02)
     139          (q03) edge [loop above]  node[above] {0,R} (q03)
     140
     141          (q11) edge               node[above] {0,L} (q10)
     142          (q12) edge [bend left]   node[below] {0,L} (q10)
     143          (q13) edge [bend left]   node[below] {0,L} (q10)
     144
     145          (q01) edge               node {2,R} (q11)
     146          (q02) edge               node {2,R} (q12)
     147          (q03) edge               node {2,R} (q13)
     148          (q13) edge               node[above] {2,R} (q12)
     149          (q12) edge               node[above] {2,R} (q11)
     150
     151          (q10) edge               node {2,L} (q20)
     152          (q20) edge               node[below] {2,L} (q21)
     153          (q21) edge               node[below] {2,L} (q22)
     154
     155
     156%          (q1) edge              node[left] {2} (q2)
     157%          (q2) edge              node[left] {2} (q3)
     158%          (q1) edge [decorate,decoration={snake}] node[above] {0-length-check} (q01)
     159%          (q2) edge [decorate,decoration={snake}] node[above] {0-length-check} (q02)
    120160        ;
    121161\end{tikzpicture}
    122 \caption{Idee voor Opdracht 2.22a}
    123 \label{fig:idee}
     162\caption{Opdracht 2.22a uitgewerkt voor $n = 3$, niet geldige stappen zijn niet genoemd en moet allen naar een 'trap' knoop gestuurd worden}
     163\label{fig:2dfa}
    124164\end{figure}
    125165
Note: See TracChangeset for help on using the changeset viewer.