Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-01-2006, 12:25   #1
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
[TASK 9.1.2] Pair Programming : Ufo13 vs Bonfo

Bene...inziamo questo nuovo task!

9.1.2:
Ogni volta che entrambe le gemme di una gemspair si sono fermate grid deve controllare se ci sono dei bauli presenti all'Interno della griglia. Per ognuno di questi bauli deve controllare se esistono gemme o agglomerati dello stesso colore con almeno un lato a contatto col baule. Se ve ne sono allora queste gemme e agglomerati devono essere cancellate dalla griglia. Se queste gemme sono a loro volta a contatto con altre gemme dello stesso colore allora devono essere cancellate anche queste.
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 12:45   #2
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Premesso che i test alla fine saranno sicuramente di +...

Test List:
- Gemma + Baule adiacenti e "droppati" dello stesso tipo si cancellano.
- Gemma + Baule adiacenti, uno dei due non droppato, stesso tipo non si cancellano.
- Gemma + Baule adiacenti non dello stesso tipo non si cancellano.
- 2 Gemme + Baule adiacente solo ad una delle due, stesso tipo, si cancellano tutti.
- 2 Bauli dello stesso tipo adiacenti si cancellano a vicenda.
- 2 Bauli dello stesso tipo droppati ed adiacenti + una gemma adiacente ad uno dei due. Tutto viene cancellato.
- BigGem + Baule, stesso tipo, vengono cancellati.
- La cancellazione avviene solo quando entrambe le gemme in una gemspair sono cadute.

hmmmm mi pare bastino
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 13:00   #3
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Primo test per Bonfo:

Codice:
package it.diamonds.tests;

import it.diamonds.Grid;
import it.diamonds.engine.mocks.MockTimer;
import it.diamonds.gems.Gem;
import it.diamonds.gems.GemType;
import junit.framework.TestCase;
import static it.diamonds.gems.GemType.*;

public class TestGemsCrushing extends TestCase
{
    private Grid grid;
    private MockTimer timer;
    
    
    public void testGemsAndChestCrushing()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 3);
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 3);
        
        grid.updateCrushes();
        
        assertEquals("grid must be empty", 0, grid.getNumberOfGems());
    }
    
    private void insertAndUpdate(Gem gem, int row, int column)
    {
        grid.insertGem(row, column, gem); 
        grid.update(timer, gem); 
    }
    
    private Gem createGem(GemType gemType)
    {
        return Gem.create(gemType, 3500);
    }
}
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 13:22   #4
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Ecco risolto:
Codice:
    public void updateCrushes()
    {
        removeGemFromGrid(getGemAt(13,3));
        removeGemFromGrid(getGemAt(13,2));   
    }
metodo aggiunto in Grid.

GREEN
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 13:33   #5
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Testiamo ora due coppie di diverso tipo:

Codice:
    public void testMoreGemsAndChestCrushing()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 3);
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 2);
        insertAndUpdate(createGem(EMERALD), 13, 5);
        insertAndUpdate(createGem(EMERALD_CHEST), 13, 6);
        
        grid.updateCrushes();
        
        assertEquals("grid must be empty", 0, grid.getNumberOfGems());
    }
A te...
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 13:49   #6
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Build Verde:

Codice:
    public void updateCrushes()
    {
        for(Gem gemsRow[] : grid)
        {
            for(Gem gem : gemsRow)
            {
                if (gem == null)
                {
                    continue;
                }
                
                removeGemFromGrid(gem);
            }
        }
    }
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 13:54   #7
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Nuovo test per Bonfo:

Codice:
    public void testNotCrushingOnDifferentType()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 3);
        insertAndUpdate(createGem(EMERALD_CHEST), 13, 2);
        
        insertAndUpdate(createGem(DIAMOND), 13, 5);
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 6);
        
        grid.updateCrushes();
        
        assertEquals("grid must contain two gems", 2, grid.getNumberOfGems());
    }
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 14:32   #8
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Per soddisfare il test è necessario riuscire a valutare quando un CHEST e un GEM sono dello stesso tipo base.

Dobbiamo aggiungere un metodo per fare questo controllo.

Ecco i test per questo metodo:
Codice:
    public void testGemAndChestTypeEquals()
    { 
        assertSame("The type must be the same type (DIAMOND)",DIAMOND.getBaseType(),DIAMOND_CHEST.getBaseType());
        assertSame("The type must be the same type (EMERALD)",EMERALD.getBaseType(),EMERALD_CHEST.getBaseType());
        assertSame("The type must be the same type (RUBY)",RUBY.getBaseType(),RUBY_CHEST.getBaseType());
        assertSame("The type must be the same type (SAPPHIRE)",SAPPHIRE.getBaseType(),SAPPHIRE_CHEST.getBaseType());
        assertSame("The type must be the same type (TOPAZ)",TOPAZ.getBaseType(),TOPAZ_CHEST.getBaseType());
    }
    
    public void testGemAndChestTypeNotEquals()
    { 
        assertNotSame("The type must be different",DIAMOND.getBaseType(),EMERALD_CHEST.getBaseType());
    }
Vai Ufo ...
__________________
Software engineer
Bonfo's Blog

Ultima modifica di Bonfo : 27-01-2006 alle 14:34.
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 14:42   #9
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Codice:
    private static final HashMap<GemType, GemType> chestsBaseTypes = new HashMap<GemType, GemType>();
    
    static
    {
        chestsBaseTypes.put(EMERALD_CHEST, EMERALD);
        chestsBaseTypes.put(RUBY_CHEST, RUBY);
        chestsBaseTypes.put(SAPPHIRE_CHEST, SAPPHIRE);
        chestsBaseTypes.put(TOPAZ_CHEST, TOPAZ);
        chestsBaseTypes.put(DIAMOND_CHEST, DIAMOND);
    }

   public GemType getBaseType()
    {
        if (!chest)
        {
            return this;
        }
        
        return chestsBaseTypes.get(this);
    }
Ecco fatto, build verde, puoi continuare
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 15:26   #10
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Ok...ora possiamo finire col test di prima.

Modificato updateCrushes():
Codice:
public void updateCrushes()
    {
        for(Gem gemsRow[] : grid)
        {
            for(Gem gem : gemsRow)
            {
                if (gem == null)
                {
                    continue;
                }
                
                Gem nearGem=getGemAt(gem.getCellRow(), gem.getCellColumn() + 1);
                
                if( nearGem!= null)
                {
                    GemType firstGemType = gem.getType().getBaseType();
                    GemType secondGemType = nearGem.getType().getBaseType();
                    if(firstGemType == secondGemType)
                    {
                        removeGemFromGrid(gem);
                        removeGemFromGrid(nearGem);
                        
                    }
                }
            }
        }
Ora viene controllata la corenza di tipo tra due gemme adiacenti

GREEN

fra un po' il prossimo test...
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 15:27   #11
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
E questo?

Codice:
    public void testVerticalGemsAndChestCrushing()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 2);
        insertAndUpdate(createGem(DIAMOND_CHEST), 12, 2);
        
        grid.updateCrushes();
        
        assertEquals("grid must be empty", 0, grid.getNumberOfGems());
    }
a te...
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 15:47   #12
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Bene...per risolvere questo è stato aggiunto un metodo privato

Codice:
    private boolean removeIfCorrectType(Gem gem,GemType gemType)
    {
        if( gem != null)
        {
            GemType thisGemType = gem.getType().getBaseType();
            
            if(thisGemType == gemType)
            { 
                removeGemFromGrid(gem);
                return true;
            }
        }
        
        return false;
    }
...altrimenti la complessità ciclotomatica era troppo alta.

Poi è stato così modificato il codice di updateCrushes()

Codice:
    public void updateCrushes()
    {
        for(Gem gemsRow[] : grid)
        {
            for(Gem gem : gemsRow)
            {
                boolean toCancel = false;
                
                if (gem == null)
                {
                    continue;
                }
                
                GemType thisGemType = gem.getType().getBaseType();
                
                Gem rightGem = getGemAt(gem.getCellRow(), gem.getCellColumn() + 1);
                Gem upperGem = getGemAt(gem.getCellRow() - 1, gem.getCellColumn());
                
                toCancel = removeIfCorrectType(upperGem,thisGemType) || removeIfCorrectType(rightGem,thisGemType);
                
                if(toCancel)
                {
                    removeGemFromGrid(gem);
                }
            }
        }     
    }

GREEN
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 15:53   #13
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Nuovo test...

Codice:
    public void testTwoDiamondsNotCrushing()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 2);
        insertAndUpdate(createGem(DIAMOND), 13, 3);
        
        grid.updateCrushes();
        
        assertEquals("grid must contain two gems", 2, grid.getNumberOfGems());
    }
...buon divertimento
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 16:22   #14
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Codice:
    private boolean tryCrush(Gem gem, Gem otherGem)
    {
        if (otherGem == null)
        {
            return false;
        }
            
        if (gem.getType().getBaseType() != otherGem.getType().getBaseType())
        { 
            return false;
        }
        
        if (!gem.getType().isChest() ^ otherGem.getType().isChest())
        {
            return false;
        }
        
        removeGemFromGrid(gem);
        
        return true;
    }
Build verde, preparo nuovo test
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 16:27   #15
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Codice:
    public void testTwoChestsCrushing()
    {
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 2);
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 3);
        
        grid.updateCrushes();
        
        assertEquals("grid must be empty", 0, grid.getNumberOfGems());
    }
A te
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 16:36   #16
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Fantastico risolto con 3 caratteri ....

Codice:
    private boolean tryCrush(Gem gem, Gem otherGem)
    {
        if (otherGem == null)
        {
            return false;
        }
            
        if (gem.getType().getBaseType() != otherGem.getType().getBaseType())
        { 
            return false;
        }
        
        if (!gem.getType().isChest() && !otherGem.getType().isChest())
        {
            return false;
        }
        
        removeGemFromGrid(gem);
        
        return true;
    }

GREEN
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 16:41   #17
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Nuovo test...iniziamoo con le "catene":

Codice:
    public void testTwoDiamondsAndChestCrushing()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 2);
        insertAndUpdate(createGem(DIAMOND), 13, 3);
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 4);
        
        grid.updateCrushes();
        
        assertEquals("grid must be empty", 0, grid.getNumberOfGems());
    }
avanti
__________________
Software engineer
Bonfo's Blog
Bonfo è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 17:59   #18
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Accidenti! 5 righe di test mi han fatto sbattere un poco

Codice:
    public void updateCrushes()
    {
        for(Gem gemsRow[] : grid)
        {
            for(Gem gem : gemsRow)
            {
                if (gem == null)
                {
                    continue;
                }

                ArrayList<Gem> crushedGems = new ArrayList<Gem>();
                
                detectCrushes(gem, crushedGems);
                
                while(!crushedGems.isEmpty())
                {
                    Gem crushedGem = crushedGems.get(0);
                    removeGemFromGrid(crushedGem);
                    crushedGems.remove(crushedGem);
                }
            }
        }     
    }


    private void detectCrushes(Gem gem, ArrayList<Gem> crushedGems)
    {
        Gem rightGem = getGemAt(gem.getCellRow(), gem.getCellColumn() + 1);
        Gem leftGem = getGemAt(gem.getCellRow(), gem.getCellColumn() - 1);
        Gem upGem = getGemAt(gem.getCellRow() - 1, gem.getCellColumn());
        Gem downGem = null;
        
        if(gem.getCellRow() < rows-1)
        {
            downGem = getGemAt(gem.getCellRow() + 1, gem.getCellColumn());
        }

        tryCrush(gem, rightGem, crushedGems);
        tryCrush(gem, upGem, crushedGems);
        tryCrush(gem, leftGem, crushedGems);
        tryCrush(gem, downGem, crushedGems);
    }
    
    
    private void tryCrush(Gem gem, Gem otherGem, ArrayList<Gem> crushedGems)
    {
        if (otherGem == null)
        {
            return;
        }
            
        if (gem.getType().getBaseType() != otherGem.getType().getBaseType())
        { 
            return;
        }
        
        if (!gem.getType().isChest() && !otherGem.getType().isChest() && crushedGems.isEmpty())
        {
            return;
        }
        
        if (crushedGems.contains(otherGem))
        {
            return;
        }
        
        crushedGems.add(otherGem);
        detectCrushes(otherGem, crushedGems);
    }
Build verde!
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 18:05   #19
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Codice:
    public void testCrushOnLeftBound()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 0);
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 1);
        
        try
        {
            grid.updateCrushes();
        }
        catch(ArrayIndexOutOfBoundsException exc)
        {
            fail("ArrayIndexOutOfBoundsException thrown");
        }
    }
Tutto tuo
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2006, 18:13   #20
Bonfo
Senior Member
 
L'Avatar di Bonfo
 
Iscritto dal: Nov 2005
Città: Bologna
Messaggi: 1303
Ecco la soluzione:
Codice:
private void detectCrushes(Gem gem, ArrayList<Gem> crushedGems)
    {
        Gem rightGem = getGemAt(gem.getCellRow(), gem.getCellColumn() + 1);
        Gem leftGem=null;
        Gem upGem = getGemAt(gem.getCellRow() - 1, gem.getCellColumn());
        Gem downGem = null;
        
        if(gem.getCellRow() < rows-1)
        {
            downGem = getGemAt(gem.getCellRow() + 1, gem.getCellColumn());
        }
        
        if(gem.getCellColumn() > 1)
        {
            leftGem = getGemAt(gem.getCellRow(), gem.getCellColumn() - 1);
        }

        tryCrush(gem, rightGem, crushedGems);
        tryCrush(gem, upGem, crushedGems);
        tryCrush(gem, leftGem, crushedGems);
        tryCrush(gem, downGem, crushedGems);
    }
GREEN

Ed ecco il prossimo test:
Codice:
    public void testCrushOnRightBound()
    {
        insertAndUpdate(createGem(DIAMOND), 13, 6);
        insertAndUpdate(createGem(DIAMOND_CHEST), 13, 7);
        
        try
        {
            grid.updateCrushes();
        }
        catch(ArrayIndexOutOfBoundsException exc)
        {
            fail("ArrayIndexOutOfBoundsException thrown");
        }
    }
__________________
Software engineer
Bonfo's Blog

Ultima modifica di Bonfo : 27-01-2006 alle 18:15.
Bonfo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
Samsung Galaxy S26, ormai è tutto...
Smartphone sempre più cari: super...
L'ultima puntata di Falsissimo rimossa d...
NASA Perseverance ha utilizzato percorsi...
Blue Origin sospende per almeno due anni...
Stampanti, Los Angeles verso il divieto ...
Roscosmos Amur: il razzo spaziale riutil...
Robot aspirapolvere per tutte le tasche:...
Accedere alle mail di un lavoratore lice...
Amazon Haul scatenato: migliaia di prodo...
Amazon Seconda Mano rilancia: sconto ext...
Super prezzo Amazon per ECOVACS DEEBOT T...
NVIDIA Shield TV: dieci anni di aggiorna...
Le 10 offerte migliori su Amazon oggi, c...
Autostrade che 'pensano': l'AI arriva su...
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: 14:27.


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