Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Mic Mini 2: audio 48 kHz / 24-bit e protocollo OsmoAudio sotto i 100 Euro
DJI Mic Mini 2: audio 48 kHz / 24-bit e protocollo OsmoAudio sotto i 100 Euro
DJI presenta Mic Mini 2, un sistema microfonico wireless ultra-compatto progettato per democratizzare l'audio di alta qualità nella fascia entry-level. Con un peso di soli 11 grammi per il trasmettitore elimina i fastidi tipici dei modelli più pesanti sui vestiti. Nonostante la miniaturizzazione Mic Mini 2 offre prestazioni tecniche di rilievo: registrazione omnidirezionale a 48 kHz/24-bit, tre preset vocali (Regular, Bright, Rich) e un sistema di cancellazione attiva del rumore a due livelli.
Recensione Moto G77: display AMOLED e buona autonomia per il midrange economico
Recensione Moto G77: display AMOLED e buona autonomia per il midrange economico
Motorola propone in fascia media il nuovo Moto G77 5G, uno smartphone che punta sul display AMOLED da 1.5K a 120Hz, e sulla fotocamera da 108 MP con stabilizzazione ottica per affrontare la fascia media. Il tutto insieme a una batteria da 5200mAh in soli 7,3 millimetri di spessore, con una scocca certificata con standard militari
DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla
DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla
DJI ha appena ufficializzato la serie Lito, la sua nuova gamma di droni entry-level destinata a chi si avvicina per la prima volta alla fotografia aerea. Al centro dell'annuncio ci sono due modelli ben distinti per fascia di prezzo e specifiche tecniche: DJI Lito 1 e DJI Lito X1. Entrambi si collocano sotto la soglia regolamentare dei 249 grammi, che permette di volare con requisiti burocratici più semplici rispetto ai droni più pesanti.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-05-2007, 15:41   #1
autista
Bannato
 
Iscritto dal: Mar 2007
Messaggi: 35
funzione CRONOMETRO in C#

salve ragazzi, devo cronometrare il tempo di esecuzione di questo programma per analizzarne la complessità, solo che con le spiegazioni riguardo la funzione CLOCK_T trovate in rete non ci sono riuscito


Codice:
#include <stdlib.h>
#include <stdio.h>
#include <time.h>

#define MAX 10

clock_t clock(void) {
clock_t start, end;
double millisec;
time_t app;
start = clock();
end = clock();
millisec = (end-start)/(CLOCKS_PER_SEC /(double) 1000.0);
printf(clock());
return clock();
}

/*
 * Legge in input il numero n ed n numeri interi
 * che memorizza nell'array. Restituisce il numero
 * di elementi letti (n).
 */

int leggi_array(int x[]) {
  int i, n;

x[MAX]=rand();

  return(MAX);
}


/*
 * Stampa in output l'array.
 */

void stampa_array(int x[], int n) {
  int i;

  for (i=0; i<n; i++) {
    printf("%d ", x[i]);
  }
  printf("\n");
  return;
}


/*
 * Scambia il contanuto delle due variabili
 * indirizzate dai puntatori x e y.
 */

void scambia(int *x, int *y) {
  int z;

  z = *x;
  *x = *y;
  *y = z;
  return;
}


/*
 * Funzione che implementa l'algoritmo Bubble sort.
 * Riceve come argomento l'array ed il numero di
 * elementi contenuti nell'array. Non restituisce alcun
 * valore, ma modifica il contenuto dell'array, ordinandolo.
 */

void bubble_sort(int x[], int n) {
  int flag=1, k=n-1, i;

  while (flag == 1 && k > 0) {
    flag = 0;
    for (i=0; i<k; i++) {
      if (x[i]>x[i+1]) {
        scambia(&x[i], &x[i+1]);
        flag = 1;
      }
    }
    k = k-1;
  }
  return;
}


/*
 *  Funzione principale
 */

int main(void) {
  int v[MAX], n,m,u;

  n = leggi_array(v);
  stampa_array(v, n);
  printf("premere un tasto per iniziare\n");
  scanf("%d", &m);

  

  bubble_sort(v, n);

  clock_t(bubble_sort);

  printf("ordinamento effettuato\n");
  return(1);
}
autista è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 15:52   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da autista Guarda i messaggi
salve ragazzi, devo cronometrare il tempo di esecuzione di questo programma per analizzarne la complessità, solo che con le spiegazioni riguardo la funzione CLOCK_T trovate in rete non ci sono riuscito
Non è ben chiaro cosa non hai capito ...

Il tipo di dato clock_t e la funzione clock() si usano per esempio così:
Codice:
clock_t start, end;
double duration;

start = clock ();

/*... tue operazioni da cronometrare ...*/

end = clock ();

duration = (double)(end-start) / CLOCKS_PER_SEC;
Dove duration è in secondi.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 16:00   #3
autista
Bannato
 
Iscritto dal: Mar 2007
Messaggi: 35
Quote:
Originariamente inviato da andbin Guarda i messaggi
Non è ben chiaro cosa non hai capito ...

Il tipo di dato clock_t e la funzione clock() si usano per esempio così:
Codice:
clock_t start, end;
double duration;

start = clock ();

/*... tue operazioni da cronometrare ...*/

end = clock ();

duration = (double)(end-start) / CLOCKS_PER_SEC;
Dove duration è in secondi.
allora io devo cronometrare il tempo impiegato per ordinare dal più piccolo al più grande un array col metoto bubble_sort e non ho capito come si usa la funzione clock,
ora è un po' più chiaro con la tua spiegazione, ma poi come faccio a far stampare a video la durata?
autista è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 17:15   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da autista Guarda i messaggi
allora io devo cronometrare il tempo impiegato per ordinare dal più piccolo al più grande un array col metoto bubble_sort e non ho capito come si usa la funzione clock.
C'è poco da capire, la documentazione su Linux dice ad esempio: "The clock() function returns an approximation of processor time used by the program."
Quindi clock() ritorna un valore che è proporzionale al tempo usato dal processo. Se mettessi un clock() all'inizio del programma (all'inizio del main, ad esempio), otterrei 0. Man mano si incrementa.

Quote:
Originariamente inviato da autista Guarda i messaggi
ora è un po' più chiaro con la tua spiegazione, ma poi come faccio a far stampare a video la durata?
Beh, io ho usato un double tanto per fare un esempio. Per stamparlo:

printf ("%.3f secondi\n", duration);
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 19:42   #5
autista
Bannato
 
Iscritto dal: Mar 2007
Messaggi: 35
Quote:
Originariamente inviato da andbin Guarda i messaggi
C'è poco da capire, la documentazione su Linux dice ad esempio: "The clock() function returns an approximation of processor time used by the program."
Quindi clock() ritorna un valore che è proporzionale al tempo usato dal processo. Se mettessi un clock() all'inizio del programma (all'inizio del main, ad esempio), otterrei 0. Man mano si incrementa.

Beh, io ho usato un double tanto per fare un esempio. Per stamparlo:

printf ("%.3f secondi\n", duration);
grazie, sentite per ampliare la dimensione dell' array cosi mi consigliate di usare invece? un long long double?
autista è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 19:56   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da autista Guarda i messaggi
per ampliare la dimensione dell' array cosi mi consigliate di usare invece? un long long double?
long double? Spiega meglio. Intendi dire poter gestire un array espandibile? Devi usare l'allocazione dinamica: malloc/realloc/free.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 20:07   #7
autista
Bannato
 
Iscritto dal: Mar 2007
Messaggi: 35
Quote:
Originariamente inviato da andbin Guarda i messaggi
long double? Spiega meglio. Intendi dire poter gestire un array espandibile? Devi usare l'allocazione dinamica: malloc/realloc/free.
no voglio solo poter inserire più di 100.000 elementi nell' array

se metto int oltre tale numero non me lo gestisce
autista è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 20:14   #8
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da autista Guarda i messaggi
no voglio solo poter inserire più di 100.000 elementi nell' array

se metto int oltre tale numero non me lo gestisce
Dipende da dove dichiari l'array! Se lo dichiari (senza marcarlo 'static') dentro una funzione, allora è allocato sullo stack. Ma attenzione, non è che puoi avere tutto lo spazio che vuoi nello stack! Sui sistemi Windows lo stack per default è limitato a 1 MByte (ma è una impostazione marcata nell'eseguibile dal linker, quindi alterabile).
Quindi fai un po' tu dei conti ....

Altrimenti definisci l'array fuori dalle funzioni oppure dentro una funzione ma marcato 'static'. Insomma... deve avere durata fissa e non automatica.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 20:22   #9
autista
Bannato
 
Iscritto dal: Mar 2007
Messaggi: 35
guarda l' ho impostato all' inizio del programma che ho allegato, però mi sa hai ragione c'è il problema dello stack
autista è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 20:29   #10
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da autista Guarda i messaggi
guarda l' ho impostato all' inizio del programma che ho allegato, però mi sa hai ragione c'è il problema dello stack
Codice:
int main(void) {
  int v[MAX], n,m,u;
È dichiarato dentro il main, quindi è sullo stack.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 20:33   #11
autista
Bannato
 
Iscritto dal: Mar 2007
Messaggi: 35
Quote:
Originariamente inviato da andbin Guarda i messaggi
Codice:
int main(void) {
  int v[MAX], n,m,u;
È dichiarato dentro il main, quindi è sullo stack.
quindi come risolvo?
autista è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2007, 20:54   #12
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da autista Guarda i messaggi
quindi come risolvo?
O lo lasci dove è ma lo dichiari 'static' oppure lo metti fuori dalle funzioni.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Mic Mini 2: audio 48 kHz / 24-bit e protocollo OsmoAudio sotto i 100 Euro DJI Mic Mini 2: audio 48 kHz / 24-bit e protocol...
Recensione Moto G77: display AMOLED e buona autonomia per il midrange economico Recensione Moto G77: display AMOLED e buona auto...
DJI Lito 1 e Lito X1 recensione: i nuovi droni per principianti che non si fanno mancare nulla DJI Lito 1 e Lito X1 recensione: i nuovi droni p...
Sony World Photography Awards 2026: i premiati, anche italiani, il punto sulla fotografia di oggi Sony World Photography Awards 2026: i premiati, ...
Una settimana con Hyundai Ioniq 5 N-Line: diverte e convince Una settimana con Hyundai Ioniq 5 N-Line: divert...
Google prepara il Tensor G6 con una GPU ...
Sempre più vicini a eliminare il ...
Accordo OpenAI-Amazon da 50 miliardi e 2...
Nintendo e Illumination preparano un nuo...
Arlo, nuove offerte sulle telecamere di ...
Google Gemini attiva la Memoria in Itali...
Da VMware a Proxmox, come AXOL ha suppor...
Meta nei guai con l'UE: perché Facebook ...
Blender ha un nuovo sponsor da €240.000 ...
Il Philips Bodygroom Serie 7000 a 64€ (e...
Valanga di novità da Fanatec, anche per ...
'DLSS' e 'Fram Gen' anche per il Samsung...
Claude si integra con Blender e Adobe: n...
Agente AI cancella l'intero database di ...
Il ritorno del Commodore 64: il nuovo C6...
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:02.


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