Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta
DLSS 4.5 introduce Dynamic Multi Frame Generation e MFG 6X, permettendo fino a cinque frame generati per ogni frame renderizzato. I test su Cyberpunk 2077 e 007 First Light mostrano forti incrementi di FPS e riduzione della latenza su RTX 5090 Laptop. Migliorano fluidità, stabilità e qualità visiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-07-2010, 08:11   #1
swarzy85
Senior Member
 
L'Avatar di swarzy85
 
Iscritto dal: Feb 2003
Città: Milano
Messaggi: 7013
[c] come allocare un vettore o una matrice di grandi dimensioni?

Ciao a tutti,

ho un problema con l'allocazione di una matrice a 4 dimensioni che mi serve per contenere informazioni rilevanti in campo bioinformatico.
La prima versione "ridotta" del programma che sto sviluppando opera su una matrice iniziale di dimensioni 100x1000.
La matrice a 4 dimensioni che deve derivarne deve essere di dimensione 100x100x100x27.

Se provo ad allocarla dinamicamente, mi viene restituito un errore di "stack overflow". Se, invece, provo ad allocarla con la malloc, son costretto poi a scorrerla in modo "ordinato" visto che devo implementare una lista.
Ne deriva che, così facendo, non potrei effettuare un accesso puntuale al dato.
Cosa mi consigliate di fare?

Avevo anche pensato di creare un file e scrivere in modo ordinato gli elementi per poi leggerli o modificarli specificando degli offset.

Che ne pensate? Staticamente, ovviamente, non esiste un modo per allocare una matrice di queste dimensioni, no?

Grazie anticipatamente
Alberto
__________________
Presidente comitato mondiale Anti-Troll
La gloria la si deve acquistare, l'onore invece basta non perderlo. (Schopenhauer)
swarzy85 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 11:30   #2
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
Quote:
Originariamente inviato da swarzy85 Guarda i messaggi
Se provo ad allocarla dinamicamente, mi viene restituito un errore di "stack overflow". Se, invece, provo ad allocarla con la malloc, son costretto poi a scorrerla in modo "ordinato" visto che devo implementare una lista.
cosa intendi per allocazione dinamica? Perchè malloc() è una delle funzioni per l'allocazione dinamica...

comunque hai provato a modificare la dimensione dello stack con le syscall? Io stò dando per scontato che sei su linux....
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 12:44   #3
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
probabilmente è troppo grande per lo stack, ma non ho capito il problema della matrice allocata nello heap

come stai allocando la matrice dinamicamente?
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 15:12   #4
swarzy85
Senior Member
 
L'Avatar di swarzy85
 
Iscritto dal: Feb 2003
Città: Milano
Messaggi: 7013
Quote:
Originariamente inviato da Teo@Unix Guarda i messaggi
cosa intendi per allocazione dinamica? Perchè malloc() è una delle funzioni per l'allocazione dinamica...

comunque hai provato a modificare la dimensione dello stack con le syscall? Io stò dando per scontato che sei su linux....
Sono sotto Windows Vista (da stasera sarò su Seven)...sotto Linux non avrei lo stesso problema? Potrei provare con Ubuntu...

Comunque se dichiaro in maniera statica la matrice con:

Quote:
prob_tre_geni [N_PROBES][N_PROBES][N_PROBES][QUARTA_DIM]
dove:
Quote:
#define N_PROBES 100
#define N_IBRID 1000
#define N_DISCR 3
#define TERZA_DIM 9
#define QUARTA_DIM 27
Mi da errore nello stack di sistema a runtime.

Se invece effettuo una dichiarazione di questo tipo:

Quote:
struct matrice_quattro
{
int elemento;
struct matrice_quattro *next;
};
struct matrice_quattro *prob_tre_geni;
E successivamente alloco dinamicamente la matrice con:

Quote:
prob_tre_geni = (struct matrice_quattro*) malloc (sizeof (struct matrice_quattro));

/* Inizializzazione vettore probabilità tre geni */
for (i = 0; i < N_PROBES*N_PROBES*N_PROBES*QUARTA_DIM; i++)
{
prob_tre_geni->elemento = 0;
prob_tre_geni->next = malloc (sizeof (struct matrice_quattro));
}
La matrice viene allocata ma così è un gran casino perchè mi scordo un accesso puntuale ad un dato.

Chiedo lumi

Grazie mille


P.S. non saprei come accrescere la dimensione dello stack...in teoria una matrice di circa 27.000.000 di interi non dovrebbe avere una dimensione spropositata e invece a runtime mi occupa circa 2.2GB
__________________
Presidente comitato mondiale Anti-Troll
La gloria la si deve acquistare, l'onore invece basta non perderlo. (Schopenhauer)

Ultima modifica di swarzy85 : 26-07-2010 alle 15:15.
swarzy85 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 15:25   #5
Isildur84
Member
 
Iscritto dal: Jan 2005
Città: Torino
Messaggi: 144
Hai provato l'allocazione dinamica del vettore?

Codice:
 int * matrice = malloc(sizeof(int) * NVALORI);
Questo ovviamente per ogni dimensione della matrice.

Ovviamente "matrice" non dovrebbe essere un int * ma un int **** (almeno così mi sembra).
Isildur84 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 16:06   #6
swarzy85
Senior Member
 
L'Avatar di swarzy85
 
Iscritto dal: Feb 2003
Città: Milano
Messaggi: 7013
Ma la matrice così comunque la alloca...il problema è che poi non potrei accedere in maniera puntuale ai singoli campi, no?
Sbaglio qualcosa nelle mie considerazioni?
__________________
Presidente comitato mondiale Anti-Troll
La gloria la si deve acquistare, l'onore invece basta non perderlo. (Schopenhauer)
swarzy85 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 16:36   #7
Isildur84
Member
 
Iscritto dal: Jan 2005
Città: Torino
Messaggi: 144
Se tu la allochi nel modo che ti ho consigliato io (hai bisogno di 3 cicli for), l'accesso è puntuale, in quanto puntatori e vettori in C sono "intercambiabili".
Il tuo metodo della lista invece non permette l'accesso puntuale.
Isildur84 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2010, 18:19   #8
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Quote:
Originariamente inviato da swarzy85 Guarda i messaggi
Ma la matrice così comunque la alloca...il problema è che poi non potrei accedere in maniera puntuale ai singoli campi, no?
Sbaglio qualcosa nelle mie considerazioni?
per poter scrivere, ad esempio, matrix[0][2][99][13]

devi usare un void****

ad esempio:

Codice:
    int ****matrix = malloc(sizeof(int***) * 100);
    int i;
    for (i = 0; i < 100; i++) {
        int j;
        matrix[i] = malloc(sizeof(int**) * 100);
        for (j = 0; j < 100; j++) {
            int k;
            matrix[i][j] = malloc(sizeof(int*) * 100);
            for (k = 0; k < 100; k++)
                matrix[i][j][k] = malloc(sizeof(int) * 27);
        }
    }
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 27-07-2010, 00:36   #9
DoubleAJ
Senior Member
 
Iscritto dal: Nov 2004
Messaggi: 326
Quote:
Originariamente inviato da swarzy85 Guarda i messaggi
in teoria una matrice di circa 27.000.000 di interi non dovrebbe avere una dimensione spropositata e invece a runtime mi occupa circa 2.2GB
Se al posto di una lista ti allochi una matrice inoltre ti risparmi esattamente la metà dello spazio in memoria, visto che non hai bisogno di un puntatore per ogni elemento.
__________________
The problem with Troubleshooting is that often trouble shoots back...
DoubleAJ è offline   Rispondi citando il messaggio o parte di esso
Old 27-07-2010, 02:30   #10
malocchio
Senior Member
 
L'Avatar di malocchio
 
Iscritto dal: Feb 2007
Città: Verona
Messaggi: 1060
Lascia stare le liste.

Attento che stai dichiarando la tua "matrice" all'interno di un metodo e di conseguenza essa viene temporaneamente allocata sullo stack (BRUTTA cosa).

Se la matrice deve avere visibilità globale, sposta la sua dichiarazione fuori dal metodo. In quel modo avrai uno spazio di memoria allocato staticamente all'avvio dell'eseguibile.
__________________
malocchio è offline   Rispondi citando il messaggio o parte di esso
Old 27-07-2010, 10:07   #11
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
Se la matrice ha dimensione prefissata io cercherei una soluzione un po' più bruta, ma funzionale:

int * matrix = (int *)malloc(N_PROBES * N_PROBES * N_PROBES * QUARTA_DIM * sizeof(int));

Poi provvederei a mettere a disposizione una macro per l'accesso alla matrice:

#define matrix_elem(a, b, c, d) (matrix[a*N_PROBES + b*N_PROBES + c*N_PROBS + d])

In alternativa potresti usare un setter ed un getter con un bound check:

Codice:
inline int get_elem(matrix m, int a, int b, int c, int d)
{
   #ifdef _DEBUG
   check_bound(a,b,c,d);
   #endif
   return matrix[a*N_PROBES + b*N_PROBES + c*N_PROBS + d];
}

inline int set_elem(matrix m, int a, int b, int c, int d, int value)
{
   #ifdef _DEBUG
   check_bound(a,b,c,d);
   #endif
   matrix[a*N_PROBES + b*N_PROBES + c*N_PROBS + d] = value;
}
In un codice che lavora su 4 indici di una matrice è secondo me di fondamentale importanza avere un controllo sugli indici.
Il controllo sugli indici volendo si potrebbe effettuare anche nella macro
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-07-2010, 10:09   #12
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 malocchio Guarda i messaggi
Se la matrice deve avere visibilità globale, sposta la sua dichiarazione fuori dal metodo. In quel modo avrai uno spazio di memoria allocato staticamente all'avvio dell'eseguibile.
Cioè consigli di allocare una variabile globale ?
Se la alloca dinamicamente è solo il puntatore che risiede nello stack.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 28-07-2010, 00:57   #13
malocchio
Senior Member
 
L'Avatar di malocchio
 
Iscritto dal: Feb 2007
Città: Verona
Messaggi: 1060
Quote:
Originariamente inviato da cionci Guarda i messaggi
Cioè consigli di allocare una variabile globale ?
Se la alloca dinamicamente è solo il puntatore che risiede nello stack.
Sì, l'allocazione dinamica è la cosa più indicata, ma a voler essere non troppo pignoli e per aggirare la "complessità" di una allocazione dinamica (con puntatori, inizializzazioni, ecc.) io ho proposto l'all. statica, che di per sé è abbastanza semplice, no?

edit: ah, la tua soluzione non mi dispiacerebbe affatto
__________________

Ultima modifica di malocchio : 28-07-2010 alle 01:00.
malocchio è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Vivo Watch GT 2 arriva in Italia: uno sm...
Resident Evil Veronica copia Resident Ev...
Lo smartphone di Trump Mobile è d...
The Social Reckoning, la storia di Faceb...
FASTCloud Open Source: un cloud sovrano ...
AMD non lascia spazio a Intel: la top 15...
iPhone 17 torna protagonista su Amazon: ...
PowerToys si aggiorna alla versione 0.10...
La nuova Audi Q7 proietta le frecce sull...
Framework blocca tutto: Laptop 13 Pro no...
SSD, Biwin investe oltre metà del...
Samsung Trend Radar 2026: smartphone e s...
Enel entra nella telefonia mobile: il vi...
Arriva il menu contestuale aggiornato di...
GM punta sulle batterie al sodio per lo ...
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: 05:14.


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