Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-01-2010, 15:35   #1
Rulez
Junior Member
 
Iscritto dal: Apr 2003
Messaggi: 22
[c]semplice timer - clock() ritorna sempre 0

Ciao a tutti
Avevo bisogno per un programmino di fare un semplice bechmark che si basa sul tempo di esecuzione di un pezzo di codice.. il più semplice possibile.

In rete ho trovato questo codice:
Codice:
/*
 * A timer in C
 * author: Danny Battison
 * contact: [email protected]
 */

#include <time.h>
#include <stdio.h>

clock_t BeginTimer()
{
    //timer declaration
    clock_t Begin; //initialize Begin

    Begin = clock() * CLK_TCK; //start the timer

    return Begin;
}
clock_t EndTimer(clock_t begin)
{
    clock_t End;
    End = clock() * CLK_TCK;   //stop the timer
    return End;
}

int main ()
{
    double begin = BeginTimer();
    printf ("Timer set to: %.2f\n", begin); // print the initialised timer (0)

    // process to be timed goes here
    printf ("Enter something to stop the timer: ");
    char input;
    scanf ("%c", &input);

    // variable declarations used for time calculation
    float elapTicks;
    float elapMilli, elapSeconds, elapMinutes;

    // variable definitions on to calculate time taken
    elapTicks = EndTimer(begin);    // stop the timer, and calculete the time taken
    elapMilli = elapTicks/1000;     // milliseconds from Begin to End
    elapSeconds = elapMilli/1000;   // seconds from Begin to End
    elapMinutes = elapSeconds/60;   // minutes from Begin to End

    printf ("Milliseconds passed: %.2f\n", elapMilli);
    printf ("Seconds passed: %.2f\n", elapSeconds);
    printf ("Minutes passed: %.2f", elapMinutes);

    // hold the window open
    char dummy;
    scanf ("%c", &dummy);
    return 0;
}
Lo compilo una prima volta sotto ubuntu9.10 con l'ultima versione di gcc e mi dice che CLK_TCK non è dichiarato. Ok, cerco online la nuova "variabile" e fixo cambiandolo in CLOCK_PER_SEC. Lo ricompilo poi con successo!
Lancio il programma (sempre da riga di comando) ed il risultato è:
Codice:
Enter something to stop the timer: 
Milliseconds passed: 0.00
Seconds passed: 0.00
Minutes passed: 0.00
Il bello arriva quando lo eseguono altri miei amici sulle proprie macchine (di cui uno col mio stesso os) con però un risultato positivo! Cioè funzionava..
Guardando il codice è facile capire che la funzione "clock()" mi ritorna sempre 0 (in quanto anche con un define della costante "moltiplicatore" il risultato è sempre il medesimo :|

Perchè solo a me questo programmino non va?

Ps. il programma è eseguito su un portatile ASUS F3S che ha un multicore intel. Però non penso sia dovuto al processore il problema in quanto anche gli altri miei amici (che hanno testato il programma con successo) hanno pure loro il core 2 duo della intel


Rulez è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2010, 16:58   #2
Rulez
Junior Member
 
Iscritto dal: Apr 2003
Messaggi: 22
up..
Rulez è offline   Rispondi citando il messaggio o parte di esso
Old 13-01-2010, 23:05   #3
doshu
Junior Member
 
Iscritto dal: Jan 2010
Messaggi: 6
quanto codice per niente...se vuoi sapere quanto ci mette ad eseguire del codice basta che fai cosi:

int inizio=clock();

//codice da eseguire

int fine=clock();

int tempo_trascorso=fine-inizio; //tempo in millisecondi
doshu è offline   Rispondi citando il messaggio o parte di esso
Old 14-01-2010, 11:19   #4
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
si, infatti quelle due funzioni BeginTimer ed EndTimer sono ridicole...
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 09:11   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da fero86 Guarda i messaggi
si, infatti quelle due funzioni BeginTimer ed EndTimer sono ridicole...
Quote:
Originariamente inviato da doshu Guarda i messaggi
quanto codice per niente...se vuoi sapere quanto ci mette ad eseguire del codice basta che fai cosi:

int inizio=clock();

//codice da eseguire

int fine=clock();

int tempo_trascorso=fine-inizio; //tempo in millisecondi
Allora sbagliate entrambi, chi vi ha detto che clock() ritorni millisecondi ?
Non c'è assolutamente una convenzione, la convenzione c'è solo nei sistemi POSIX compliant in cui clock() ritorna milionesimi di secondo.
Tra l'altro è anche sbagliato il tipo di dati utilizzato nel codice che ho quotato.
Il modo corretto per usare clock è il seguente (è standard C99 e C89):

clock_t begin, end.
double elapsed_seconds;

begin = clock();

//codice da eseguire

end = clock();

elapsed_seconds = (double)(end - begin) / CLOCKS_PER_SEC; //tempo in secondi
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 14:03   #6
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Quote:
Originariamente inviato da cionci Guarda i messaggi
Non c'è assolutamente una convenzione, la convenzione c'è solo nei sistemi POSIX compliant in cui clock() ritorna milionesimi di secondo.
All'università sui sistemi Solaris tornava i cicli di clock. Non dovrebbe essere POSIX compliant?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 15:22   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
All'università sui sistemi Solaris tornava i cicli di clock. Non dovrebbe essere POSIX compliant?
Boh, non lo so, comunque da quello che ho trovato in giro sembra che ognuno poi faccia un po' come gli pare.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 15:34   #8
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Quote:
Originariamente inviato da cionci Guarda i messaggi
Boh, non lo so, comunque da quello che ho trovato in giro sembra che ognuno poi faccia un po' come gli pare.
Ah ok Peccato però, sarebbe meglio seguire uno standard unico
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 15:50   #9
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Ah ok Peccato però, sarebbe meglio seguire uno standard unico
Tanto c'è la costante che ti aiuta
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-01-2010, 16:06   #10
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Ah, quindi nel caso clock torni il tempo in milionesimi di secondo CLOCKS_PER_SEC sarà un milione. Grazie per le delucidazioni
wingman87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Bastano 200 auto elettriche per cambiare...
Tesla rimette le batterie 4680 nella Mod...
Un mostro capace di raffreddare 2000 W d...
Smartphone Android in super offerta: da ...
Addio ISEE fai-da-te e carta d'identit&a...
L'IA spinge le aziende a ripensare le po...
Robot aspirapolvere top e low cost: le 7...
Ubisoft: i sindacati chiamano allo sciop...
Google Pixel 10 Pro in offerta: display ...
Ford aggiorna Explorer e Capri: arriva l...
Microsoft prepara un cambio strutturale ...
Case PC in offerta: flusso d'aria ottimi...
Kingdom Come: Deliverance, dopo il succe...
Xiaomi domina tra le auto importate dall...
Upgrade PC a prezzo ridotto: Amazon scon...
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: 13:13.


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