Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-01-2005, 18:40   #1
Killian
Senior Member
 
L'Avatar di Killian
 
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.
Killian è offline   Rispondi citando il messaggio o parte di esso
Old 25-01-2005, 19:40   #2
end.is.forever
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.
end.is.forever è offline   Rispondi citando il messaggio o parte di esso
Old 26-01-2005, 01:34   #3
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
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....
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 26-01-2005, 21:34   #4
Killian
Senior Member
 
L'Avatar di Killian
 
Iscritto dal: Sep 2002
Città: centro Italia
Messaggi: 1189
Quote:
Originariamente inviato da ^TiGeRShArK^
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....
no, non è quello che cerco.


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.
Killian è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2005, 11:37   #5
lombardp
Senior Member
 
L'Avatar di lombardp
 
Iscritto dal: Jun 2002
Città: Firenze
Messaggi: 630
Re: automi a stati finiti

Quote:
Originariamente inviato da Killian
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.
Quando la scala di integrazione era bassa, in hardware automi a stati finiti di una certa complessità era realizzati con memorie PROM. In cui l'indirizzo era la combinazione dello stato corrente e degli ingressi all'automa, il dato in uscita alla PROM era lo stato futuro e le uscite dell'automa.

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
lombardp è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2005, 20:12   #6
Killian
Senior Member
 
L'Avatar di Killian
 
Iscritto dal: Sep 2002
Città: centro Italia
Messaggi: 1189
Re: Re: automi a stati finiti

Quote:
Originariamente inviato da lombardp
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...
ho deciso invece di numerare le transizioni, in pratica creo una struttura con 4 attributi, un numero che identifica una transizione in modo univoco, 2 campi per identificare rispettivamente lo stato di partenza e quello di arrivo della transizione e un valore booleano per sapere se lo stato è marcato, poi una variabile a parte che identifica l'ultima transizione effettuata, utile per sapere in che stato mi trovo. Per convenzione la transizione 0 identificherà lo stato iniziale e non avrà alcuno stato 'sorgente'.

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.
Killian è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2005, 09:00   #7
atidem
Senior Member
 
L'Avatar di atidem
 
Iscritto dal: Oct 2004
Messaggi: 752
Ti consiglio questa lettura.
atidem è offline   Rispondi citando il messaggio o parte di esso
Old 03-02-2005, 21:19   #8
Omni
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)
Omni è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Cavi sottomarini come sensori: la Finlan...
Exodus è il nuovo Mass Effect? Il...
Lockdown Mode cambia il volto di ChatGPT...
Guild Wars 3 è ufficiale: ArenaNe...
I giocatori voltano le spalle a Linux? L...
Instagram Plus arriva in Italia: cosa in...
XBOX: la nuova CEO non ha ancora le idee...
Intel non ha intenzione di abbandonare i...
La AI Mode sarà attiva di default...
Marvel's Wolverine non sarà un op...
Star Wars Zero Company esce ad agosto: n...
Bonus Decoder: fino al 70% di sconto con...
Virtua Fighter è tornato e non &e...
Il ritorno di Fumito Ueda, autore di Sha...
Cooler Master svela GPU Shield, la nuova...
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: 20:32.


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