Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-02-2009, 12:45   #1
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
[C] Ingrandimento immagine, dove si blocca il programma??

Ciao a tutti
sto cercando di fare un programma che,da linea di comando riceve il nome di un immagine, e un numero intero N, e ne ingrandisce le dimensioni di N volte. Fin qui il programma funziona, ma adesso devo aggiungere un pezzo in modo tale da ridurre la quadrettatura, facendo una media per ogni pixel dei pixel adiancenti.
Questo è il programma che ho scritto:
Codice:
#include<stdio.h>
#include<stdlib.h>

#include"bmp.h"

void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N);
void  riduci_quadrettatura(BITMAP bmpout,int N);
double  calcola_media(BITMAP bmpout,int i,int j,int N,char colore);


int main(int argc, char *argv[])
{   BITMAP bmpin,bmpout;
    FILE *fpin,*fpout;
    int N;

    if (argc != 3)
    {   printf("Scrivere su linea di comando:
                nome immagine ingresso
                numero intero che rappresenta l'ingrandimento");
        exit (EXIT_FAILURE);
    }

    if((fpin=fopen(argv[1],"rb"))==NULL)
    {   printf("Errore apertura file ingresso");
        exit (EXIT_FAILURE);
    }

    if((fpout=fopen("ingrandita.bmp","wb"))==NULL)
    {   printf("Errore apertura file d'uscita");
        exit (EXIT_FAILURE);
    }
    bmpin=ReadBitmap(fpin);
    fclose(fpin);
    bmpout=CreateEmptyBitmap(bmpin.height*atoi(argv[2]),bmpin.width*atoi(argv[2]));

    
    ingrandisci(bmpout,bmpin,atoi(argv[2]));

    printf("Sono qui");
    riduci_quadrettatura(bmpout,atoi(argv[2]));
    
    WriteBitmap(bmpout,fpout);
    fclose(fpout);

    ReleaseBitmapData(&bmpin);
    ReleaseBitmapData(&bmpout);


    return EXIT_SUCCESS;

}


void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N)
{   int i,j,c=0,k,I,J;
    
  
    
    for(i=0; i<bmpin.height; i++)
    {   for(j=0; j<bmpin.width; j++)
        {  
           for(k=i*N; k<=i*N+N-1; k++)
           {             
               for(c=j*N; c<=j*N+N-1; c++)
               {   PIXEL(bmpout,k,c)=PIXEL(bmpin,i,j);
                   
               } 

            } 

         }
         
     } 
    
    return;

}


void  riduci_quadrettatura(BITMAP bmpout,int N)
{   int i,j;
    
    
    for(i=1; i<bmpout.height-1; i++)
    {   
        for(j=1; j<bmpout.width-1; j++)
        {    PIXEL(bmpout,i,j).red=calcola_media(bmpout,i,j,N,'r');
             PIXEL(bmpout,i,j).green=calcola_media(bmpout,i,j,N,'g');
             PIXEL(bmpout,i,j).blue=calcola_media(bmpout,i,j,N,'b');

        }
    } 

    return;
}

double calcola_media(BITMAP bmpout,int i,int j,int N,char colore)
{   double somma_rosso=0,somma_verde=0, somma_blu=0;
    int c,k;
    
    for(c=i; c<=i*N+N-1; i++)
    {
        for( k=j; k<= j*N+N-1; j++)
        {
            somma_rosso+=PIXEL(bmpout,c,k).red;
            somma_verde+=PIXEL(bmpout,c,k).green;
            somma_blu+=PIXEL(bmpout,c,k).blue;
        }
    }

    if (colore == 'r')
            return    (double)somma_rosso/(N*N);

    if (colore == 'g')
            return    (double)somma_verde/(N*N);

    if (colore == 'b')
            return    (double)somma_blu/(N*N);

    
}
Non riesco a capire perchè il programma entri in un ciclo infinito
Allora, se io tolgo tutta la parte della quadrettatura il programma funziona, se io invece l'aggiungo, non mi scrive neanche quel "Sono qui" nel main, un printf che ho aggiunto per cercare di vedere dove il programma si bloccava. Ma come fa a non arrivare a quel punto se la funzione ingrandisci funziona??
Grazie a tutti
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 12:52   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
for( k=j; k<= j*N+N-1; j++)

Non sarebbe meglio k++?
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 12:53   #3
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
si si già modificato era la versione vecchia questa, anche il c sopra
non va comunque
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 13:08   #4
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
Inoltre come è possibile che una parte una funzione venga correttamente completata, e dopo, con l'aggiunta di un altro pezzo di programma, che non la utilizza, non arriva allo stesso punto di prima???
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 19:57   #5
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
Aiuto nessuno???
Non riesco proprio a capire dove sbaglio
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 20:18   #6
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Se non posti anche bmp.h difficilmente qualcuno avrà voglia di guardare del codice non eseguibile. ^^
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 20:26   #7
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
si allora qui:
http://web.diegm.uniud.it/pierluca/p...magini/bmplib/
ci sono le librerie fatte dal mio professore.
Però non riesco a capire perchè se tolgo la parte di riduci_quadrettatura il programma funziona correttamente, mentre se aggiungo, non stampa a video il printf Sono qui, che sta immediatamente dopo alla funzione ingrandisci
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2009, 00:56   #8
eliano
Senior Member
 
L'Avatar di eliano
 
Iscritto dal: Mar 2002
Città: Capua (CE)
Messaggi: 317
Quote:
Originariamente inviato da MinaVagante Guarda i messaggi
Ciao a tutti
sto cercando di fare un programma che,da linea di comando riceve il nome di un immagine, e un numero intero N, e ne ingrandisce le dimensioni di N volte. Fin qui il programma funziona, ma adesso devo aggiungere un pezzo in modo tale da ridurre la quadrettatura, facendo una media per ogni pixel dei pixel adiancenti.
Questo è il programma che ho scritto:
Codice:
#include<stdio.h>
#include<stdlib.h>

#include"bmp.h"

void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N);
void  riduci_quadrettatura(BITMAP bmpout,int N);
double  calcola_media(BITMAP bmpout,int i,int j,int N,char colore);


int main(int argc, char *argv[])
{   BITMAP bmpin,bmpout;
    FILE *fpin,*fpout;
    int N;

    if (argc != 3)
    {   printf("Scrivere su linea di comando:
                nome immagine ingresso
                numero intero che rappresenta l'ingrandimento");
        exit (EXIT_FAILURE);
    }

    if((fpin=fopen(argv[1],"rb"))==NULL)
    {   printf("Errore apertura file ingresso");
        exit (EXIT_FAILURE);
    }

    if((fpout=fopen("ingrandita.bmp","wb"))==NULL)
    {   printf("Errore apertura file d'uscita");
        exit (EXIT_FAILURE);
    }
    bmpin=ReadBitmap(fpin);
    fclose(fpin);
    bmpout=CreateEmptyBitmap(bmpin.height*atoi(argv[2]),bmpin.width*atoi(argv[2]));

    
    ingrandisci(bmpout,bmpin,atoi(argv[2]));

    printf("Sono qui");
    riduci_quadrettatura(bmpout,atoi(argv[2]));
    
    WriteBitmap(bmpout,fpout);
    fclose(fpout);

    ReleaseBitmapData(&bmpin);
    ReleaseBitmapData(&bmpout);


    return EXIT_SUCCESS;

}


void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N)
{   int i,j,c=0,k,I,J;
    
  
    
    for(i=0; i<bmpin.height; i++)
    {   for(j=0; j<bmpin.width; j++)
        {  
           for(k=i*N; k<=i*N+N-1; k++)
           {             
               for(c=j*N; c<=j*N+N-1; c++)
               {   PIXEL(bmpout,k,c)=PIXEL(bmpin,i,j);
                   
               } 

            } 

         }
         
     } 
    
    return;

}


void  riduci_quadrettatura(BITMAP bmpout,int N)
{   int i,j;
    
    
    for(i=1; i<bmpout.height-1; i++)
    {   
        for(j=1; j<bmpout.width-1; j++)
        {    PIXEL(bmpout,i,j)->red=calcola_media(bmpout,i,j,N,'r');
             PIXEL(bmpout,i,j)->green=calcola_media(bmpout,i,j,N,'g');
             PIXEL(bmpout,i,j)->blue=calcola_media(bmpout,i,j,N,'b');

        }
    } 

    return;
}

double calcola_media(BITMAP bmpout,int i,int j,int N,char colore)
{   double somma_rosso=0,somma_verde=0, somma_blu=0;
    int c,k;
    
    for(c=i; c<=i*N+N-1; i++)
    {
        for( k=j; k<= j*N+N-1; j++)
        {
            somma_rosso+=PIXEL(bmpout,c,k).red;
            somma_verde+=PIXEL(bmpout,c,k).green;
            somma_blu+=PIXEL(bmpout,c,k).blue;
        }
    }

    if (colore == 'r')
            return    (double)somma_rosso/(N*N);

    if (colore == 'g')
            return    (double)somma_verde/(N*N);

    if (colore == 'b')
            return    (double)somma_blu/(N*N);

    
}
Non riesco a capire perchè il programma entri in un ciclo infinito
Allora, se io tolgo tutta la parte della quadrettatura il programma funziona, se io invece l'aggiungo, non mi scrive neanche quel "Sono qui" nel main, un printf che ho aggiunto per cercare di vedere dove il programma si bloccava. Ma come fa a non arrivare a quel punto se la funzione ingrandisci funziona??
Grazie a tutti
E' possibile che mi sbagli, data l'ora tarda, ma credo che per accedere alle tre componenti diel colore tu debba usare l'indirezione: infatti la dichiarazione di BITMAP è
Codice:
typedef struct tagBITMAP
{
   dword width;
   dword height;
   COLORTRIPLE *pixel;
   FILEHEADER fileheader;
   BMPHEADER bmpheader;
} BITMAP;
__________________
Se pensi di sapere, sappi che non sai di non saperlo!
Le mie statistiche - "real man uses Duron!"
Ho fatto affari con: schumyFast, navale, The_Nameless_One, Sonic80, diamante.picci, Downset88, ilviandante, tecno789
eliano è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2009, 07:57   #9
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
Intendi che non devo scrivere:
PIXEL(bmpout,i,j).red=PIXEL(bmpin,i,j).red
ad esempio???
Perchè ho fatto altri programmi in cui assegnavo il valore per ciascun colore e tutto funziona, come questo ad esempio in cui dovevo modificare la luminosità:
Codice:
#include<stdio.h>
#include<stdlib.h>

#include "bmp.h"

BITMAP modifica_luminosita(BITMAP bmpin,float k);


int main(int argc, char *argv[])
{   float k;
    BITMAP bmpin,bmpout;
    FILE *fpin,*fpout;

    if(argc != 3)
    {   printf("Scrivere sulla linea di comando:
                nome file ingresso
                numeroreale (fattore di cambiamento luminosti…)");
        exit (EXIT_FAILURE);
    }

    if((fpin=fopen(argv[1],"rb"))==NULL)
    {   printf("Errore apertura file d'ingresso.");
        exit (EXIT_FAILURE);
    }

    if((fpout=fopen("Luminosit…_modificata.bmp","wb"))==NULL)
    {   printf("Errore nell'apertura file d'uscita");
        exit (EXIT_FAILURE);
    }

    k=atof(argv[2]);
    bmpin=ReadBitmap(fpin);

    bmpout=modifica_luminosita(bmpin,k);

    WriteBitmap(bmpout,fpout);

    ReleaseBitmapData(&bmpin);
    ReleaseBitmapData(&bmpout);

    fclose(fpin);
    fclose(fpout);

    return EXIT_SUCCESS;

}


BITMAP modifica_luminosita(BITMAP bmpin,float k)
{   int i,j;
    BITMAP bmpout;
    COLORTRIPLE white={255,255,255};

    bmpout=CreateEmptyBitmap(bmpin.height,bmpin.width);

    for(i=0; i<bmpin.height; i++)
    {   for(j=0; j<bmpin.width; j++)
        {  if ( (PIXEL(bmpout,i,j).red=PIXEL(bmpin,i,j).red * k/100 > 255)||
                (PIXEL(bmpout,i,j).green=PIXEL(bmpin,i,j).green * k/100 >255)||
                (PIXEL(bmpout,i,j).blue=PIXEL(bmpin,i,j).blue * k/100 > 255))
           {   PIXEL(bmpout,i,j)=white;
           }
           else
           {   PIXEL(bmpout,i,j).red=PIXEL(bmpin,i,j).red *k/100;
               PIXEL(bmpout,i,j).green=PIXEL(bmpin,i,j).green * k/100;
               PIXEL(bmpout,i,j).blue=PIXEL(bmpin,i,j).blue * k/100;
           }
        }
    }
    return bmpout;

}
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2009, 10:39   #10
eliano
Senior Member
 
L'Avatar di eliano
 
Iscritto dal: Mar 2002
Città: Capua (CE)
Messaggi: 317
Oops!

Scusami, errore mio: avevo interpretato male la struttura.
__________________
Se pensi di sapere, sappi che non sai di non saperlo!
Le mie statistiche - "real man uses Duron!"
Ho fatto affari con: schumyFast, navale, The_Nameless_One, Sonic80, diamante.picci, Downset88, ilviandante, tecno789
eliano è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Netflix, batosta in Italia: aumenti ille...
UFO e complotti: chi si cela dietro la n...
Batterie EV difficili da riciclare: il p...
Non vuoi targare il monopattino? Engwe h...
Oracle AI World Tour Milano: dall'IA age...
Gli astronauti di Artemis II hanno avuto...
Quando arriverà iOS 26.5? Il debu...
AI Agent Traps: il paper DeepMind che ca...
Addio licenza proprietaria: Gemma 4 pass...
LG OLED in offerta su Amazon: quattro TV...
Amazon punta a Globalstar per sfidare St...
Successo immediato per The Super Mario G...
Raspberry Pi alza ancora i prezzi: Pi 5 ...
Solo 9 esemplari al mondo: ecco l'iPhone...
Hisense QLED 4K da 98 e 85 pollici: i pr...
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: 11:31.


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