Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-01-2007, 03:14   #1
Xidius
Senior Member
 
Iscritto dal: Apr 2004
Messaggi: 3484
[Java] Java e grammatiche...

Salve ragazzi, il mio problema ha a che fare col riconoscimento delle grammatiche, cioè di queste cose qui: http://it.wikipedia.org/wiki/Grammatica_regolare

La mia idea è quella di riuscire a far riconoscere alla macchina delle espressioni del tipo:

S -> A
A -> b | c ( | sta per oppure )

e di farci con esse metodi di sostituzione ( si parte dalla S e si deve arrivare a delle lettere piccole in questo caso b o c )
Il mio problema è proprio quello di fare tutto ciò col Java...
Il dubbio mio principale è: come fare a fargli capire che "A" è diverso da "a". ( domanda lecita dato che devo lavorare con caratteri piccoli e grandi ).
Sinceramente nn so dove cominciare; nn so se devo rappresentare tutto con le stringhe, cercando una mezza specie di classificazione per fargli capire che le stringhe a sinistra hanno delle funzioni e quelle a destra altre... nn so come fargli capire il termine "->"...
Insomma ho i soliti dubbi di chi come me parte da zero...
Potreste darmi una mano? Grazie
__________________
Ho trattato nel mercatino con tante persone....
Ovviamente tutte soddisfatte!
Xidius è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2007, 10:19   #2
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Tempo fa ho fatto una piccola classe che rappresenta una grammatica,
con relativo calcolo degli insiemi nullable, first, follow.
Se vuoi nel pomeriggio te lo posto.
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2007, 10:59   #3
Xidius
Senior Member
 
Iscritto dal: Apr 2004
Messaggi: 3484
magari, ti ringrazio

ho letto sulla documentazione java2 questo http://java.sun.com/j2se/1.5.0/docs/...x/Pattern.html

Potrebbe essermi utile?
__________________
Ho trattato nel mercatino con tante persone....
Ovviamente tutte soddisfatte!
Xidius è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2007, 12:03   #4
Angus
Senior Member
 
L'Avatar di Angus
 
Iscritto dal: Dec 2001
Città: Milano
Messaggi: 545
Se non devi necessariamente fare tutto da solo ma puoi utilizzare delle librerie ti consiglio di partire dai seguenti link:

JFlex
CUP
javaCC
__________________
Angus the Hunter @ Realm of magic | Angus Young @ Batracer
°SetiEmperor°| Ninja Technologies
{ qualunque cosa sia, è veloce e fa male (cit.) }
Angus è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2007, 13:54   #5
pisto
 
Messaggi: n/a
Quote:
Originariamente inviato da Xidius
magari, ti ringrazio

ho letto sulla documentazione java2 questo http://java.sun.com/j2se/1.5.0/docs/...x/Pattern.html

Potrebbe essermi utile?
penso proprio di sì, che mi risulti è il package fatto apposta per ottenere informazioni da un stringa
  Rispondi citando il messaggio o parte di esso
Old 10-01-2007, 18:01   #6
Xidius
Senior Member
 
Iscritto dal: Apr 2004
Messaggi: 3484
Putroppo devo fare da solo, senza l'ausilio di qualche strumento esterno...
nn so se mi conviene usare array multidimensionali o vettori per memorizzare queste stringhe....

comunque quel package potrebbe fare al caso mio; vorrei quindi memorizzare queste "stringhe" in una struttura per poi farci degli opportuni controlli e sostituzioni...
l'idea è questa:

S->ABB
AB->bc
B->b
A->a

ad esempio, concettualmente potrei sostituire AB con bc e B con b, cosi da avere bcb
oppure le due B con le due b piccole e la A con la a, cosi da avere abb

nn so se mettere tutto in un array multidimensionale dove in prima colonna metto S, AB, B, A e nelle righe metto ABB, bc, b, a; poi scannerizzo la prima parte delle righe successive a S, cioè, AB, B, A e vedo se ognuna appartiene al lato destro di S ( ad esempio trovo che AB è contenuto in ABB ), se lo trovo sostituisco fino a farmi venire alla fine di tutto una stringa di caratteri piccoli ( quindi ad ogni passo dovrò fare una specie di controllo carattere ).

Su per giu l'idea è questa, solo che la pratica.....
__________________
Ho trattato nel mercatino con tante persone....
Ovviamente tutte soddisfatte!
Xidius è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2007, 18:48   #7
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Cioe' vuoi generare stringhe a caso?

Comunque ti posto il mio codice di un po' di tempo fa,
senza calcolo degli insiemi, tanto non ti interessa.

Prima di tutto ho fatto una classe che rappresenta una produzione NT -> T:

Codice:
class Prod
{
    private char left;
    private String right;

    public Prod(char l, String r)
    {
        left = l;
        right = r;
    }

    public char getLeft()
    {
        return left;
    }

    public String getRight()
    {
        return right;
    }

    public String toString()
    {
        return "" + left + " -> " + right;
    }
}
Come vedi il non terminale a sinistra è rappresentato da un carattere,
tu in una ne metti due, mi suona strano...

Poi la classe che rappresenta la grammatica:

Codice:
public class Gram
{
    private Set<Character> terminali, nonTerminali;
    private Prod[] produzioni;
    private char simboloIniziale;

    public Gram(char simboloIniziale, Prod... produzioni) // varargs
    {
        this.simboloIniziale = simboloIniziale;

        terminali = new HashSet<Character>();
        nonTerminali = new HashSet<Character>();

        this.produzioni = produzioni;

        for(Prod p : produzioni)
            nonTerminali.add(p.getLeft());

        for(Prod p : produzioni) {
            String r = p.getRight();

            for(int c = 0; c<r.length(); c++)
                if( !nonTerminali.contains(r.charAt(c)) )
                    terminali.add(r.charAt(c));
        }
    }

    /* stampa la produzioni */
    public String toString()
    {
	String pr = "";
	for(Prod p : produzioni)
	    pr = pr + "\t" + p + "\n";

	return pr;
    }
La prima grammatica che hai scritto la costruisci con:
Gram gr = new Gram( 'S', // simbolo iniziale
new Prod( 'S', "A" ), // "S -> A"
new Prod( 'A', "b" ), // "A -> b"
new Prod( 'A', "c" ) // "A -> c"
);
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2007, 19:59   #8
Xidius
Senior Member
 
Iscritto dal: Apr 2004
Messaggi: 3484
Quote:
tu in una ne metti due, mi suona strano...
le grammatiche di tipo 0 e di tipo 1, a sinistra possono avere anche piu caratteri, le grammatiche di tipo 2 e di tipo 3, a sinistra hanno solo un carattere

detto ciò, devo supporre che a sinistra ci stiano anche più di un carattere, appartenenti all'unione dell'alfabeto sia terminale che non ( quindi possono esserci sia maiuscole che minuscole ).

per curiosità, hai fatto anche tu degli studi/progetti su queste cose?
__________________
Ho trattato nel mercatino con tante persone....
Ovviamente tutte soddisfatte!
Xidius è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2007, 08:56   #9
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
avevo realizzato un generatore di stringhe terminali a partire da una grammatica letta da un file, ma dovrei cercare il codice... in ogni caso il fulcro della questione e' che una produzione e' rappresentata da un oggetto con 2 campi: il membro di sinistra e quello di destra. Mi pare che in java 'A' sia sempre diverso da 'a' quindi non dovresti aver problemi. Per la generazione avevo usato derivazioni leftmost...
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2007, 10:04   #10
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Quel programmino lo avevo fatto per Compilatori, ma usavamo
anche javacup, jlex (mi sembra si chiamassero cosi') e altri.

Se devi gestire piu' caratteri a sinistra usa comunque una classe
con campi tipo stringhe o array, non ti consiglio di "impelagarti" con array multidimensionali.
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2007, 17:57   #11
Xidius
Senior Member
 
Iscritto dal: Apr 2004
Messaggi: 3484
Quote:
Originariamente inviato da lovaz
Quel programmino lo avevo fatto per Compilatori, ma usavamo
anche javacup, jlex (mi sembra si chiamassero cosi') e altri.

Se devi gestire piu' caratteri a sinistra usa comunque una classe
con campi tipo stringhe o array, non ti consiglio di "impelagarti" con array multidimensionali.
jlex l'ho sentito... però questo lavoro purtroppo devo farlo tutto a mano e senza strumenti esterni
Inoltre mi hanno chiesto pure di usare ricorsione e backtracking, il che, aggrava ancora di piu le cose... comunque, certo, potrei creare proprio classi con all'interno array di stringhe del tipo ['S->A','A->b', 'AA'], anche se il problema è fargli capire la stringa AA e fargli capire la sostituzione di stringhe, quando le scannerizza...
Percaso potresti postare il codice di quel programma, magari potrebbe servirmi come esempio per avere una qualche idea...
__________________
Ho trattato nel mercatino con tante persone....
Ovviamente tutte soddisfatte!
Xidius è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2007, 09:50   #12
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
Eccolo qua; non e' niente di speciale comunque, rispetto a quello che
ho postato aggiunge solo il calcolo degli insiemi.
Carica la grammatica da file di testo - vedi commento in testa al main.
Allegati
File Type: gz Gram.java.gz (2.6 KB, 5 visite)
lovaz è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Xbox: Phil Spencer lascia dopo 38 anni, ...
Cuffie e sostanze chimiche: uno studio e...
Terremoto sui dazi USA: la Corte Suprema...
Arianespace potrebbe lanciare il primo r...
Google Pixel 10a disponibile al prezzo m...
Microsoft Copilot nei guai: email riserv...
AOC a 399€ su Amazon: QD-OLED 240 Hz e 0...
La Cina ha recuperato dal mare il primo ...
Boeing CST-100 Starliner: la NASA rende ...
hiop e TaDa uniscono le forze per trasfo...
Thermal Grizzly mostra il Ryzen 7 9850X3...
AMD Ryzen 'Olympic Ridge' Zen 6 per desk...
Donald Trump renderà pubbliche in...
Prezzo mai visto da mesi: ECOVACS DEEBOT...
Non solo S26, Samsung sta per lanciare a...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 08:36.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v