|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Sep 2002
Città: centro Italia
Messaggi: 1189
|
automi a stati finiti
avrei la necessità (in Java) di creare un modello di automa a stati finiti, solo che ho un problema: quale è il modo migliore per rappresentarli?
Premetto che per ora mi serviranno metodi per sapere lo stato iniziale, lo stato corrente e l'elenco degli stati raggiungibili con lo stato corrente "in una mossa". Non chiedo delle righe di codice, solo sapere come poterli miplementare e se ci sono librerie utili allo scopo. Grazie. PS: ho fatto una ricerca sul forum con le parole chiave "automi" "stati" "finiti" ma non ho trovato niente di utile. |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Jul 2004
Messaggi: 1578
|
Non penso che esistano librerie apposta, io a prima vista realizzerei una classe stato che mantiene in una hasmap indicizzata per l'oggetto di input che porta ad una certa transizione, con valori gli stati a cui ogni transizione porta.
L'automa molto semplicemente avrebbe un campo statico che contiene lo stato iniziale, e gli eventuali metodi a cui passare gli input che richiamano lo stato attuale per sapere uscita e stato futuro. |
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
|
nel JADE dei telecom italia labs c'è la possibiltà di creare agenti intelligenti ke abbiano un comportamento di tipo automa a stati finiti...
non so se ti serve....
__________________
|
|
|
|
|
|
#4 | |
|
Senior Member
Iscritto dal: Sep 2002
Città: centro Italia
Messaggi: 1189
|
Quote:
Diciamo che a parte librerie predefinite preferirei non usare altro. Per ora punto ad una struttura che contenga le transizioni e per ogni transizione una stringa per riconoscerla, lo stato da cui parte e lo stato a cui porta. |
|
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Jun 2002
Città: Firenze
Messaggi: 630
|
Re: automi a stati finiti
Quote:
Quindi, tornando al tuo caso: per implementare l'automa ti basta di fatto una tabella opportunamente organizzata. Per esempio se numeri gli stati, lo stato corrente ti indicherà la riga di questa tabella, riga nella quale avrai memorizzato lo stato futuro ed eventuali al tre uscite. Se la variazione dello stato dipende anche da variabili esterne (ingressi), occorre "combinare" lo stato corrente e questi ingressi in modo da identificare una ed una sola riga della tabella. (Combinare si intende numericamente o con IF) Così è come lo farei io se dovessi divertirmi a realizzarlo...
__________________
---> Lombardp CSS Certified Expert (Master Level) at Experts-Exchange Proud user of LITHIUM forum : CPU technology Webmaster of SEVEN-SEGMENTS : Elettronica per modellismo |
|
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Sep 2002
Città: centro Italia
Messaggi: 1189
|
Re: Re: automi a stati finiti
Quote:
Dopotutto a me basta implementare pochi e semplici metodi, un metodo che mi permette di sapere se un certo stato (passato per parametro) è immediatamente raggiungibile con una sola transizione dallo stato corrente, un metodo che mi permette di sapere lo stato iniziale (praticamente un caso particolare del metodo precedente) e un metodo che mi restituisca l'elenco degli stati raggiungibili dalla posizione corrente con una sola transizione. Probabilmente nella struttura gli stati li rappresenterò con delle stringhe, perchè comunque se li rappresentassi con numeri dovrei tenere in memoria una tabella che mi permetta di associare ad ogni stato un nome non numerico. Se avete altre opinioni su come rappresentare lo stato sarò felice di ascoltarvi, ma senza scrivere linee di codice, voglio farmelo da solo. Per i metodi non mi servono aiuti, so già come implementarli se utilizzerò la struttura che ho descritto sopra. |
|
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Oct 2001
Città: Latina (LT)
Messaggi: 413
|
io ti consiglio qeusta lettura invece. http://www.dis.uniroma1.it/~terpa/sw/public_html
__________________
Ho concluso positivamente affari con alechino,pub111,rsd_oilpoint,Maninabox Solo due cose sono infinite, l'universo e la stupidità umana, e non sono sicuro della prima. (A.Einstein) |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 06:24.



















