Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Acer TravelMate P4 14: tanta sostanza per l'utente aziendale
Acer TravelMate P4 14: tanta sostanza per l'utente aziendale
Forte di soluzioni tecniche specifiche, il notebook Acer TravelMate P4 14 abbina dimensioni compatte e buona robustezza per rispondere alle necessità specifiche degli utenti aziendali. La piattaforma AMD Ryzen 7 Pro assicura prestazioni elevate con i tipici ambiti di produttività personale e sul lavoro, mantenendo un'elevata autonomia.
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque
Dal salotto al giardino, il nuovo proiettore laser di Hisense promette esperienze cinematografiche in qualsiasi contesto: qualità d’immagine, semplicità d’uso, versatilità e prezzo competitivo il suo poker d'assi
Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe
Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe
La flessibilità di configurazione è il punto di forza di questo 2-in-1, che ripropone in un form factor alternativo tutta la tipica qualità dei prodotti Lenovo della famiglia ThinkPad. Qualità costruttiva ai vertici, ottima dotazione hardware ma costo che si presenta molto elevato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-06-2007, 19:21   #1
kingbro
Junior Member
 
Iscritto dal: May 2006
Messaggi: 6
[C] Principio di località

Salve, ho un problema per un esercizio di un esame , volevo sapere se qualcuno sapeva discutere la (buona o cattiva) località spaziale e temporale esibita dal seguente frammento di programma C, distinguendo fra località spaziale istruzioni, temporale istruzioni, spaziale dati e temporale dati:

int main() {
int a[1000] = {…};
int b[1000][1000] = {…};
int c[1000];
int i,j;
for (i = 0; i < 1000; i++) {
c[i] = 0;
for (j = 0; j < 1000; j++) {
c[i] = c[i] + a[i] * b[j][j];
}
}
}
kingbro è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2007, 19:25   #2
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12103
Codice:
int main() {
    int a[1000] = {…};
    int b[1000][1000] = {…};
    int c[1000];
    int i,j;
    for (i = 0; i < 1000; i++) {
        c[i] = 0;
        for (j = 0; j < 1000; j++) {
            c[i] = c[i] + a[i] * b[j][j];
        }
    }
}
ora quantomeno è un pò + leggibile
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2007, 21:05   #3
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
b è una matrice da 1000x1000, cioè un milione di elementi, di cui però ne usi solamente 1000 (quelli della diagonale); io a sto punto avrei fatto un array da 1000x1
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2007, 23:53   #4
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Non conosco la località delle istruzioni per cui dico la mia solo relativamente ai dati.

Quei cicli sfruttano la località temporale per c e a

Se scambiassimo il ciclo interno col ciclo esterno:

Codice:
for(int j = 0; j < 1000; j++) {
    for(int i = 0; i < 1000; i++) {
        c[i] = 0;
        c[i] = c[i] + a[i] * b[j][j];
    }
}
sfrutteremmo la località spaziale per c ed a e la località temporale per b. Se la cache non fosse in grado di tenere in memoria i 2000 + 1 elementi, potremmo computare su una frazione di 1000 per i usando un fattore di blocco:

Codice:
for(int j = 0; j < 1000; j++) {
    for(int ii = 0; ii < 1000; ii += B) {
        for(int i = ii; i < min(ii + B, 1000); i++) {
            c[i] = 0;
            c[i] = c[i] + a[i] * b[j][j];
        }
    }
}
Questo riduce il numero di cache miss di un fattore B ma, ripeto, bisogna avere un'idea di quanto grande sia la cache per sapere se sia utile o inutile.

Per le istruzioni non saprei che dire. E tieni conto che anche quello che ho detto va preso coi molloni.
__________________
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
 Rispondi


Acer TravelMate P4 14: tanta sostanza per l'utente aziendale Acer TravelMate P4 14: tanta sostanza per l'uten...
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque Hisense M2 Pro: dove lo metti, sta. Mini proiett...
Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il c...
Intervista a Stop Killing Games: distruggere videogiochi è come bruciare la musica di Mozart Intervista a Stop Killing Games: distruggere vid...
Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione Samsung Galaxy S25 Edge: il top di gamma ultraso...
Appuntamenti su Roblox: la controversa v...
L’AI Meteo di Google sbarca silenziosame...
Palo Alto Networks sarebbe in procinto d...
Motorola Moto G15 a soli 110€: 8/256GB d...
Hexagon strizza l'occhio ai sim racer e ...
Sennheiser HD 660S2 in offerta: le cuffi...
Broadcom impedirebbe di scaricare le pat...
Amazfit GTR 3 crolla a 69€: ma è solo l’...
Wyoming, un datacenter AI potrebbe consu...
Ancora più giù i prezzi de...
TIM aumenta i prezzi delle offerte mobil...
Apple aggiorna tutto: iOS 18.6, macOS Se...
YouTube saprà quanti anni hai, an...
Meta AI su WhatsApp: l'Antitrust apre un...
Tantissima sostanza, batteria da 7000mAh...
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: 12:37.


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