|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.ObjectGramaticas.TablaCYK
Gramaticas.TablaScanCYK
public class TablaScanCYK
Field Summary |
---|
Fields inherited from class Gramaticas.TablaCYK |
---|
cad, gram, tabla, tam |
Constructor Summary | |
---|---|
TablaScanCYK(Cadena cadena,
GIC gramatica)
El constructor crea la tabla de analisis de tamanho |cadena|*|cadena| y
almacena la cadena y la gramatica a emplear |
Method Summary | |
---|---|
void |
add(int i,
int j,
Simbolo s)
Inserta/anhade un simbolo a la tabla en las coordenadas dadas. |
void |
calcular_Ni1(int i)
Calcula la celda N(i,1) de la tabla de analisis: i.e. para cada i=1..N ,
sea N(i,1)={A / A->w(i,1) } |
void |
calcular_Nij(int i,
int j)
Calcula la celda N(i,j) de la tabla de analisis: i.e. para k=1..j-1 ,
anhadir a N(i,j) todos los no terminales A para los cuales A->BC
es una regla de P, con B perteneciente a N(i,k) y C
perteneciente a N(i+k,j-k) |
private java.lang.String |
celda2String(java.util.LinkedHashSet celda,
int longcelda)
Devuelve una representacion en formato string del contenido de una unica celda de la tabla de analisis |
boolean |
contiene_S_N1n()
Comprueba si el axioma S esta o no en el top de la tabla (i.e. si la cadena pertenece o no al lenguaje) |
java.lang.String |
toString()
|
Methods inherited from class Gramaticas.TablaCYK |
---|
getCelda, getTam, getTerminal, hLine, terminal2String |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Constructor Detail |
---|
public TablaScanCYK(Cadena cadena, GIC gramatica)
|cadena|*|cadena|
y
almacena la cadena y la gramatica a emplear
cadena
- Cadena a analizargramatica
- Gramatica a emplear en el analisisMethod Detail |
---|
public void add(int i, int j, Simbolo s)
1..N
pero los indices de la tabla son 0..N-1
,
hemos creado este metodo auxiliar para evitar confusiones con las coordenadas.
i
- Coordenada XX'
de la tablaj
- Coordenada YY'
de la tablas
- Simbolo a insertar en es posicionprivate java.lang.String celda2String(java.util.LinkedHashSet celda, int longcelda)
celda
- Contenido de la celda de la tabla de analisislongcelda
- Longitud total deseada del string de salida (se rellenara con blanks)
public java.lang.String toString()
toString
in class TablaCYK
public void calcular_Ni1(int i)
i=1..N
,
sea N(i,1)={A / A->w(i,1) }
calcular_Ni1
in class TablaCYK
i
- Coordenada XX'
de la celda a procesarpublic void calcular_Nij(int i, int j)
k=1..j-1
,
anhadir a N(i,j) todos los no terminales A para los cuales A->BC
es una regla de P, con B perteneciente a N(i,k) y C
perteneciente a N(i+k,j-k)
calcular_Nij
in class TablaCYK
i
- Coordenada XX'
de la celda a procesarj
- Coordenada YY'
de la celda a procesarpublic boolean contiene_S_N1n()
contiene_S_N1n
in class TablaCYK
true/false
segun este o no
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |