Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
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


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Grazie a VLT è stata misurata dir...
Blue Origin annuncia un aerofreno ripieg...
Blue Origin annuncia una nuova versione ...
LG UltraFine evo 6K: il primo monitor al...
DJI cambia direzione: investe in Elegoo ...
Black Friday Narwal 2025: risparmi da ca...
Phishing evoluto contro Apple ID: caso f...
Prestazioni in discesa nei giochi? NVIDI...
Addio ai banner dei cookie? L'UE spinge ...
Le offerte Black Friday per gli smartpho...
Il controllo qualità degli iPhone...
Qualcomm Snapdragon X Elite vola con il ...
A2RL Season 2: storia, innovazione e sor...
Core Ultra Series 3: Intel conferma l'ev...
Black Friday Amazon: la GeForce RTX 5070...
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: 22:18.


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