Professional Documents
Culture Documents
SIMULACIONES 2
Autores: .
Gómez S. Wendy R. .
C.I V 17811339. .
Castañeda G. Jair. .
C.I V 19034798. .
IV Semestre. .
Matemática Discreta. .
Prof.: Ing. Damarys Punguta. .
Especialidad: Informática. .
pdautomaton pila{
states q0,q1,q2,q3,q4,q5;
alphabet a,b,x,$;
stack A,B,x,$;
initial q0;
stackinitial $;
final q5;
transition{
q0,$,($)=q1,(x);
q1,a,(x)=q2,(A,x);
q2,a,(A)=q2,(A,A);
q2,b,(A)=q3,(B,A);
q3,b,(B)=q3,(B,B);
q3,$,(B)=q4,(B);
q4,a,(A)=q4,($);
q4,b,(B)=q4,($);
q4,x,(x)=q5,($);
}
}
print(pila);
gram=PDAtoCFG(pila);
visualrecognize(pila, $ a a b b $ b b a a x);
Producciones
Automáticamente
S -> pi*X0*q0
S -> pi*X0*q1
S -> pi*X0*q2
S -> pi*X0*q3
S -> pi*X0*q4
S -> pi*X0*q5
S -> pi*X0*pi
S -> pi*X0*p
q0*$*q0 -> $
q1*$*q1 -> $
q2*$*q2 -> $
q3*$*q3 -> $
q4*$*q4 -> $
q5*$*q5 -> $
pi*$*pi -> $
p*$*p -> $
Gramatica: pila
Terminales: a, b, x,
S, q0*$*q0, q1*$*q1, q2*$*q2, q3*$*q3, q4*$*q4, q5*$*q5, pi*$*pi, p*$*p, q0*A*q0, q0*A*q1, q0*A*q2, q0*A*q3, q0*A*q4, q0*A*q5,
q0*A*pi, q0*A*p, q0*B*q0, q0*B*q1, q0*B*q2, q0*B*q3, q0*B*q4, q0*B*q5, q0*B*pi, q0*B*p, q0*x*q0, q0*x*q1, q0*x*q2, q0*x*q3,
q0*x*q4, q0*x*q5, q0*x*pi, q0*x*p, q0*$*q1, q0*$*q2, q0*$*q3, q0*$*q4, q0*$*q5, q0*$*pi, q0*$*p, q0*X0*q0, q0*X0*q1, q0*X0*q2,
q0*X0*q3, q0*X0*q4, q0*X0*q5, q0*X0*pi, q0*X0*p, q1*x*q0, q1*x*q1, q1*x*q2, q1*x*q3, q1*x*q4, q1*x*q5, q1*x*pi, q1*x*p,
q2*A*q0, q2*A*q1, q2*A*q2, q2*A*q3, q2*A*q4, q2*A*q5, q2*A*pi, q2*A*p, q3*B*q0, q3*B*q1, q3*B*q2, q3*B*q3, q3*B*q4,
q3*B*q5, q3*B*pi, q3*B*p, q4*A*q0, q4*A*q1, q4*A*q2, q4*A*q3, q4*A*q4, q4*A*q5, q4*A*pi, q4*A*p, q4*B*q0, q4*B*q1, q4*B*q2,
No Terminales:
q4*B*q3, q4*B*q4, q4*B*q5, q4*B*pi, q4*B*p, q4*x*q0, q4*x*q1, q4*x*q2, q4*x*q3, q4*x*q4, q4*x*q5, q4*x*pi, q4*x*p, q5*A*q0,
q5*A*q1, q5*A*q2, q5*A*q3, q5*A*q4, q5*A*q5, q5*A*pi, q5*A*p, q5*B*q0, q5*B*q1, q5*B*q2, q5*B*q3, q5*B*q4, q5*B*q5, q5*B*pi,
q5*B*p, q5*x*q0, q5*x*q1, q5*x*q2, q5*x*q3, q5*x*q4, q5*x*q5, q5*x*pi, q5*x*p, q5*X0*q0, q5*X0*q1, q5*X0*q2, q5*X0*q3,
q5*X0*q4, q5*X0*q5, q5*X0*pi, q5*X0*p, pi*X0*q0, pi*X0*q1, pi*X0*q2, pi*X0*q3, pi*X0*q4, pi*X0*q5, pi*X0*pi, pi*X0*p, p*A*q0,
p*A*q1, p*A*q2, p*A*q3, p*A*q4, p*A*q5, p*A*pi, p*A*p, p*B*q0, p*B*q1, p*B*q2, p*B*q3, p*B*q4, p*B*q5, p*B*pi, p*B*p, p*x*q0,
p*x*q1, p*x*q2, p*x*q3, p*x*q4, p*x*q5, p*x*pi, p*x*p, p*X0*q0, p*X0*q1, p*X0*q2, p*X0*q3, p*X0*q4, p*X0*q5, p*X0*pi, p*X0*p,
Símbolo Inicial: S
Producciones:
S ---> pi*X0*q0
S ---> pi*X0*q1
S ---> pi*X0*q2
S ---> pi*X0*q3
S ---> pi*X0*q4
S ---> pi*X0*q5
S ---> pi*X0*pi
S ---> pi*X0*p
q0*$*q0 ---> $
q1*$*q1 ---> $
q2*$*q2 ---> $
q3*$*q3 ---> $
q4*$*q4 ---> $
q5*$*q5 ---> $
pi*$*pi ---> $
p*$*p ---> $
q0*A*q0 ---> q1*x*q0 q0*A*q0
q0*A*q0 ---> q1*x*q1 q1*A*q0
q0*A*q0 ---> q1*x*q2 q2*A*q0
q0*A*q0 ---> q1*x*q3 q3*A*q0
q0*A*q0 ---> q1*x*q4 q4*A*q0
q0*A*q0 ---> q1*x*q5 q5*A*q0
2) Diseño de un AFND que acepte un lenguaje (a, b) donde contenga la
subcadena (abaaba) en todas sus palabras aceptadas.
automaton AFND{
states q0,q1,q2,q3,q4,q5,q6;
alphabet a,b;
initial q0;
final q6;
transition{
print(AFND);
exp=FAtoRE(AFND);
print (exp);
Expresión Regular: exp
(((a|b|(aa)|(ab)|(aba)|(abb)|(abaa)|(abab)|(abaaa)|(abaab)|(abaaba)|(abaabb))*)aba
aba((a|b|(a((a|b|(aa)|(ab)|(aba)|(abb)|(abaa)|(abab)|(abaaa)|(abaab)|(abaaba)|(aba
abb))*)abaaba)|(b((a|b|(aa)|(ab)|(aba)|(abb)|(abaa)|(abab)|(abaaa)|(abaab)|(abaab
a)|(abaabb))*)abaaba))*))
3) Máquina de Turing (MT) con símbolo de cinta {1,0} que busque en la cinta el patrón {101} y
también donde se encuentre un patrón donde el símbolo final sea diferente a su símbolo
final y se detenga si y solo si se encuentra ese patrón.
=1, 0;
=1, 0;
S=q0;
b=□;
F=q8;
=a, b, c;
=a, b, c;
S=q0;
b=□;
F=q7;
=a, b;
=a, b;
S=q0;
b=□;
F=q3;