sissipula
13-06-2009, 12:16
Per migliorare le prestazioni di una libreria java mono-thread per il cal-
colo numerico si e deciso di migrare ad una piattaforma multiprocesso-
re dotata di N CPU e di riscrivere in versione multi-thread un metodo
BinaryTreeSum.computeSum(Node root) molto oneroso. Tale metodo permet-
te di calcolare la somma dei valori contenuti nei nodi di un albero binario
di enormi dimensioni.
Per fare ciò ho creato un numero di thread visitatori dell'ordine del numero delle CPU disponibili e lascio insistere i singoli thread su un buffer di dimensione illimitata condiviso inizialmente contenente il solo nodo radice. I visitatori estraggono ripetutamente e concorrentemente un nodo dalla testa del buffer ed inseriscono in coda gli eventuali figli, dopo aver opportunamente considerato nel computo complessivo il valore del nodo fino al verificarsi di una opportuna condizione che però non riesco a trovare potreste darmi un suggerimento?? Quando faccio terminare tutto ciò?? Non posso utilizzare la sola condizione di buffer vuoto!!:mc:
colo numerico si e deciso di migrare ad una piattaforma multiprocesso-
re dotata di N CPU e di riscrivere in versione multi-thread un metodo
BinaryTreeSum.computeSum(Node root) molto oneroso. Tale metodo permet-
te di calcolare la somma dei valori contenuti nei nodi di un albero binario
di enormi dimensioni.
Per fare ciò ho creato un numero di thread visitatori dell'ordine del numero delle CPU disponibili e lascio insistere i singoli thread su un buffer di dimensione illimitata condiviso inizialmente contenente il solo nodo radice. I visitatori estraggono ripetutamente e concorrentemente un nodo dalla testa del buffer ed inseriscono in coda gli eventuali figli, dopo aver opportunamente considerato nel computo complessivo il valore del nodo fino al verificarsi di una opportuna condizione che però non riesco a trovare potreste darmi un suggerimento?? Quando faccio terminare tutto ciò?? Non posso utilizzare la sola condizione di buffer vuoto!!:mc: