Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-11-2010, 08: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, 09: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, 10: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 10:29.
Dani88 è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2010, 11: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, 11: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, 11: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


NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
Intel 18A-P è già in fase ...
Logitech G305 Lightspeed e G316 X 98: 8....
Qualcomm Snapdragon Reality Elite uffici...
Snapdragon START: arriva la piattaforma ...
Kioxia Exceria G3: il modella da 4 TB &e...
Gemini 3.5 Flash delude nei test Android...
DREAME X50 Ultra Complete a 749€ per il ...
Prezzi console handheld alle stelle: la ...
Toyota presenta il primo pickup elettric...
Prime Day anticipato, tutti gli smartpho...
Dyson V10 Konical: il primo aspirapolver...
FSR 4.1 su Radeon 6000, AMD spiega perch...
Hisense svela la gamma TV 2026: RGB Mini...
Narwal lancia gli sconti Prime Day 2026:...
SpaceX ha comprato Cursor: accordo da 60...
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: 03:33.


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