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 05-11-2010, 09:37   #1
Dani88
Senior Member
 
L'Avatar di Dani88
 
Iscritto dal: Aug 2005
Città: Genova
Messaggi: 2285
[generico] Trovare percorso ottimo in una matrice per coprirla tutta

Ciao a tutti
avrei bisogno di alcuni consigli: in pratica io ho una matrice di 0 e 1 ove uno dei due rappresenta la possibilità di passare da quel quadrato, l'altro invece mi dice che non posso passare.
Una cosa del tipo
Codice:
[1] [1] [1] [1] [1] [1]
[1] [0] [0] [0] [0] [1]
[1] [0] [1] [0] [0] [1]
[1] [0] [0] [0] [0] [1]
[1] [0] [0] [0] [0] [1]
[1] [1] [1] [1] [1] [1]
mi delimita un quadrato all'interno cui posso muovermi che presenta un ostacolo nella parte centrale verso SXalto.

Ora io avrei bisogno, partendo da un punto della matrice (per ora non so se fissato o meno) di calcolare il percorso ottimo per attraversare tutta la matrice, ovvero passare su tutte le caselle con gli zeri.
Ci sto pensando da un po di tempo, ma non sono riuscito per ora a tirare fuori nulla di utile...
Riuscite a darmi qualche dritta?
__________________
Lego ™ Fans Club
Dani88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2010, 10:24   #2
:.Blizzard.:
Senior Member
 
L'Avatar di :.Blizzard.:
 
Iscritto dal: Jan 2006
Città: Perugia - San Benedetto del Tronto
Messaggi: 348
Prima di tutto servirebbe ben capire cosa intendi per cammino ottimo.

Ad ogni modo, visto che parliamo di cammini sarebbe utile vedere la tua matrice proprio come un grafo (attenzione, non una matrice di adiacenza!).

Praticamente gli 0 rappresentano nodi. Per ogni nodo controlli i suoi vicini all'interno della matrice. Se il vicino è 0, allora puoi aggiungere un arco che li collega. Così facendo ti crei il grafo connesso.

Dopodiché si tratta appunto di capire cosa intendi tu per cammino ottimo. Perché se per cammino ottimo intendi un cammino hamiltoniano




allora siamo nella classe di problemi NP-completi.

Prova a girare per internet, magari trovi qualcosa a riguardo.


Altrimenti, se non ti interessa di avere come soluzione un'unico cammino ma semplicemente di visitare tutti i vertici (che ti ricordo essere i tuoi 0 della matrice) allora la cosa è molto più semplice e ti basta fare una DFS del grafo:



Con la DFS riesci a vedere anche se ci sono componenti sconnesse, ovvero nel tuo caso se ci sono degli 0 circondati completamente da 1.
:.Blizzard.: è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2010, 11:27   #3
Dani88
Senior Member
 
L'Avatar di Dani88
 
Iscritto dal: Aug 2005
Città: Genova
Messaggi: 2285
ti ringrazio per la dritta del grafo!! non ci avevo proprio pensato....
Dunque provo a definirti meglio il problema: io ho un robot che deve fare auto-learn dell'ambiente dove viene messo e deve coprirlo tutto.
A questo punto ho pensato: la prima volta lo faccio andare a caso e gli faccio costruire una matrice che mi rappresenta l'ambiente (dove ad esempio ogni casella della matrice rappresenta una zona di 10x10cm) e finchè incontra libero segna 0 se incontra un'ostacolo marca 1...
(la cosa è da perfezionare un attimo...anche se inizio a pensare che non sia il metodo più furbo e veloce)
Comunque nell'ipotesi di fare in tal modo, ho pensato una volta costruita la matrice (oppure che gli venga data dall'esterno) il robot dovrebbe coprire tutto l'ambiente andando però non più a caso ma seguendo un percorso che gli permetta di minimizzare gli spostamenti e l'urto con gli ostacoli...quindi non più a caso...
__________________
Lego ™ Fans Club

Ultima modifica di Dani88 : 05-11-2010 alle 11:29.
Dani88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2010, 12:14   #4
:.Blizzard.:
Senior Member
 
L'Avatar di :.Blizzard.:
 
Iscritto dal: Jan 2006
Città: Perugia - San Benedetto del Tronto
Messaggi: 348
Purtroppo intelligenza artificiale ancora mi manca come corso da seguire

Il mio amico che l'ha già seguita invece ha programmato con LabView proprio un robottino. Praticamente per terra aveva messo un telo bianco e con dello scotch nero ha costruito una sorta di percorso. Ogni tanto la strada era sbarrata da scotch rosso che veniva interpretata (tramite i sensori di cui il robottino era dotato) come un ostacolo. Il goal era far sì che il robot raggiungesse un determinato punto indicato con lo scotch verde all'interno di tutto il percorso.

Ad ogni modo, così a senso ti dico che secondo me la soluzione ideale è vedere appunto la tua matrice come un grafo.

Poi tutto dipende da come è fatto l'ambiente. Nel senso se c'è un percorso per terra disegnato in qualche modo oppure se si tratta di un ambiente aperto.

Nel primo caso, ovvero quello in cui lo spazio esplorabile è qualcosa di molto semplice come può essere un percorso segnato con dello scotch, secondo me non serve nemmeno che il robot abbia noto a priori l'ambiente che lo circonda. Questo perché l'esplorazione avrebbe una logica molto a "stack" proprio come nella DFS: se guardi la gif animata si capisce proprio bene, e l'atto di riprendere da un punto per imboccare una nuova strada lo raggiungi semplicemente facendo tornare a ritroso il robot al punto di bivio.

Comunque le mie sono osservazioni da profano, prendile come semplici spunti da cui partire. Considera che la questione è abbastanza complessa da trattare. Se vuoi trovare una soluzione seria ti conviene consultare qualche libro di intelligenza artificiale.
:.Blizzard.: è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2010, 12:35   #5
Dani88
Senior Member
 
L'Avatar di Dani88
 
Iscritto dal: Aug 2005
Città: Genova
Messaggi: 2285
si forse hai ragione...
Lo spazio sarebbe aperto, senza riferimenti (robot che seguono linee o simili ne ho fatto qualcuno, però li è molto più semplice perchè il robot ha riferimenti...).
Le uniche cose che ha come "riferimenti" sono i dati provenienti dai sensori di tocco o di distanza...
Inoltre stavo pensando che implementare un algoritmo del genere che lavori su matrici che sarebbero anche "grosse" (se si considera un ambiente di tipo 4x5m comincia a diventare di 40x50 elementi) su microcontrollore non so quanto possa essere efficiente...
__________________
Lego ™ Fans Club
Dani88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2010, 12:45   #6
:.Blizzard.:
Senior Member
 
L'Avatar di :.Blizzard.:
 
Iscritto dal: Jan 2006
Città: Perugia - San Benedetto del Tronto
Messaggi: 348
Allora visto che deve essere un progetto serio, ti consiglio di armarti di pazienza e di partire da qualche libro di intelligenza artificiale.

In italiano esiste questo:

http://books.google.it/books?id=cNyn...page&q&f=false
:.Blizzard.: è 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...
Rivoluzione Linux fra i gamer: nuovo rec...
OnePlus 15R: in attesa dell'arrivo in It...
BIOS schede madri AMD: AGESA 1.2.8.0 in ...
Questa Smart TV LG 65'' QNED 2025 è un b...
PC Desktop con RTX 4060 a un prezzo supe...
Il nuovo iPhone 17e arriverà a in...
POCO anticipa l'arrivo di un nuovo smart...
Ecco la lista delle migliori 32 offerte ...
Intel cambia strategia: cancellato lo sp...
Uno dei più venduti: Lefant M330 ...
Superluna Fredda 2025: oggi l'ultima Lun...
4 idee regalo in sconto su Amazon da pre...
Netflix vuole Warner Bros Discovery: in ...
Meta 'ruba' un altro big ad Apple: arruo...
2 scope elettriche ai minimi: per spazi ...
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: 09:49.


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