Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
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


Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
Qual è lo smartphone Android pi&u...
Il camion elettrico Semi è davver...
Instagram limita gli hashtag a tre per p...
Le migliori offerte Amazon del momento: ...
RTI e Medusa denunciano Perplexity AI: p...
Avviatori, compressori e accessori auto:...
Samsung Galaxy S26: un leak anticipa le ...
Windows 11, KB5070311 sistema e rompe la...
DJI Mini 3 con controller DJI RC al prez...
Horses riceve il ban anche da Epic: rifi...
Motore elettrico a flusso assiale di Yas...
India, la retromarcia dopo le polemiche:...
La Germania accende il suo colosso eolic...
Mega Risparmi Amazon Haul: fino al 60% s...
Samsung ha dominato il mercato degli sma...
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: 13:20.


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