Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-09-2007, 14:27   #1
Belzer
Senior Member
 
Iscritto dal: Oct 2005
Città: Ragusa
Messaggi: 1954
Iniziare con la programmazione parallela

Salve a tutti, vorrei iniziare con la programmazione parallela. Potete orientarmi su eventuali linguaggi di programmazione che la supportano, librerie, etc... Premesso che vorrei realizzare software di tipo scientifico, se possibile con interfaccia grafica. Vi ringrazio anticipatamente per le vostre risposte.

Conosco e seguenti linguaggi C,C++,Java (base),Python (base).
Belzer è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2007, 14:43   #2
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
se per programmazione parallela intendi programmazione multi-threading allora la Java platform implementa nativamente l'infrastruttura necessaria (classe Thread, interfaccia Runnable, meccanismi di mutua esclusione e sincronizzazione, ecc). C e C++ si appoggiano alle librerie native del sistema operativo ospite.

Se invece intendi avere controllo esplicito su un'architettura multi-cpu gestendo a mano le singole unità di elaborazione e i modelli di condivisione e accesso alla memoria puoi cominciare con le librerie MPI
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2007, 14:48   #3
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
sezione sbagliata, sposto in Programmazione
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 09:22   #4
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da Belzer Guarda i messaggi
Salve a tutti, vorrei iniziare con la programmazione parallela. Potete orientarmi su eventuali linguaggi di programmazione che la supportano, librerie, etc... Premesso che vorrei realizzare software di tipo scientifico, se possibile con interfaccia grafica. Vi ringrazio anticipatamente per le vostre risposte.

Conosco e seguenti linguaggi C,C++,Java (base),Python (base).
Python è multithread ma sfrutta soltanto un core di un sistema multicore.
Quindi dovresti lanciare n istanze della tua applicazione, una per ogni core, ed eventualmente sincronizzarle fra loro.

Ci sono già degli esperimenti di "Parallel Python", ma non sono informato quindi non ti saprei indicare nulla al momento.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 10:19   #5
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Python è multithread ma sfrutta soltanto un core di un sistema multicore.
mmm come mai questa limitazione?
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 10:22   #6
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
mmm come mai questa limitazione?
Ipotizzo da solo: usa forse un multithread cooperativo?
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 10:45   #7
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
cosa intendi per multithread cooperativo?

comunque, ti rispondo per sentito dire perché non sono un programmatore python: mi pare di aver capito che mentre Java mappa un thread in un thread nativo del s.o. ospite, python sviluppa i suoi thread in un unico thread del s.o. sottostante
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 11:28   #8
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
python come Java è un linguaggio interpretato per cui la concorrenza viene gestita ad un livello di astrazione superiore,ma in realta il processo eseguito sulla CPU è sempre uno,come avveniva anche per Java prima che la jvm supportarse le architetture multi-core....e anche su questo diciamo non è chiaro fino a che punto java lavori in multi-thread.
In sostanza se ci sono 3 thread a,b,c sulla cpu andrà un solo processo in esecuzione che di volta in volta mapperà uno dei thread simulando il multithread.
Penso che per threading cooperativo intendesse l' opposto di preemptive.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 11:37   #9
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
No. A tutto.
__________________
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
Old 25-09-2007, 12:04   #10
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
No. A tutto.
a cosa è riferito?
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 12:17   #11
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da nuovoUtente86 Guarda i messaggi
a cosa è riferito?
penso al fatto che la jvm mappa un thread "logico" in un thread nativo del s.o. ospite. non c'entra niente il supporto multi-core che è totalmente demandato al s.o.

quelo che hai detto sui 3 thread su una sola cpu non c'entra niente: è valido per qualsiasi infrastruttura che permetta il multithread: se il processore è uno non ci sono santi: un solo thread verrà eseguito in un istante

Ultima modifica di mad_hhatter : 25-09-2007 alle 12:19.
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 12:26   #12
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Forse mi sono spiegato male:
a livello di jvm viene gestito il multithread(3,10,100 thread),ma il thread in esecuzione sulla cpu è cmq 1.Le ultime implementazioni della jvm però gestiscono il multithread in modo piu reale rispetto alle architetture dual-core.In pratica solitamente i linguaggi interpretati gestiscono il multithread in un livell superiore ma lo nascondono al sistema operativo,mentra ad esempio il c++ utilizza librerie proprie del sistema per il parallelismo.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 12:29   #13
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da nuovoUtente86 Guarda i messaggi
Forse mi sono spiegato male:
a livello di jvm viene gestito il multithread(3,10,100 thread),ma il thread in esecuzione sulla cpu è cmq 1.Le ultime implementazioni della jvm però gestiscono il multithread in modo piu reale rispetto alle architetture dual-core.In pratica solitamente i linguaggi interpretati gestiscono il multithread in un livell superiore ma lo nascondono al sistema operativo,mentra ad esempio il c++ utilizza librerie proprie del sistema per il parallelismo.
assolutamente no: jvm ha sempre mappato i suoi thread in thread nativi del sistema ospite
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 12:39   #14
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da ilsensine Guarda i messaggi
Ipotizzo da solo: usa forse un multithread cooperativo?
Python internamente usa in lock globale per l'accesso ad ogni singolo oggetto. Il che uvol dire che praticamente impossibile sfruttare più core da codice python. L'unica eccezione e' che lo faccia un modulo C, ma sempre nell'ambito di una singola chiamata.
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 12:41   #15
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
ho detto il contrario da qualche parte:
ribadisco il concetto:la jvm gestisce il multithread ma mappa sul sistema operativo il tutto come unico thread ovvero il sistema non conosce nulla circa i termini della gestione della concorrenza,non basabdoti di fatto su librerie di sistema.Ora con i nuovi processori multi-core è cambiato il modo di gestire anche il mapping tra jvm e sistema.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 12:52   #16
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da nuovoUtente86 Guarda i messaggi
ho detto il contrario da qualche parte:
ribadisco il concetto:la jvm gestisce il multithread ma mappa sul sistema operativo il tutto come unico thread ovvero il sistema non conosce nulla circa i termini della gestione della concorrenza,non basabdoti di fatto su librerie di sistema.Ora con i nuovi processori multi-core è cambiato il modo di gestire anche il mapping tra jvm e sistema.
cosa c'entra la gestione della concorrenza? questo è demandato ai meccanismi implementati dalla jvm che eventualmente si appoggia a quelli offerti dal s.o., ma qui stiamo parlando d'altro: un thread java viene mappato su un thread nativo del s.o. (posto che esso supporti il multithreading). se un programma java crea più thread questi vengono mappati su altrettanti thread nativi e sarà il s.o. a schedularli come vuole e ad assegnarli a una certa cpu... la jvm non sa nulla dell'hardware sottostante, altrimenti a che servirebbe la virtual machine?
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 13:01   #17
variabilepippo
Senior Member
 
L'Avatar di variabilepippo
 
Iscritto dal: Mar 2007
Messaggi: 1792
Quote:
la jvm gestisce il multithread ma mappa sul sistema operativo il tutto come unico thread
Non sono un programmatore Java, però sarei interessato ad un riferimento ufficiale che confermi questa affermazione.
variabilepippo è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 13:06   #18
lovaz
Senior Member
 
L'Avatar di lovaz
 
Iscritto dal: Jul 2002
Messaggi: 4334
http://java.sun.com/docs/hotspot/threads/threads.html

Mi sembra di capire: fino a java 1.1 un solo processo, da 1.2 piu' processi.
lovaz è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 13:12   #19
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
cosa c'entra la gestione della concorrenza? questo è demandato ai meccanismi implementati dalla jvm che eventualmente si appoggia a quelli offerti dal s.o., ma qui stiamo parlando d'altro: un thread java viene mappato su un thread nativo del s.o. (posto che esso supporti il multithreading). se un programma java crea più thread questi vengono mappati su altrettanti thread nativi e sarà il s.o. a schedularli come vuole e ad assegnarli a una certa cpu... la jvm non sa nulla dell'hardware sottostante, altrimenti a che servirebbe la virtual machine?
1)lA jvm è un' interfaccia tra la macchina e il programmatore,per cui che non sappia nulla dell' ambiante in cui "vive" non è corretto...LA jvm OPERA una virtualizzazione della macchina e per il concetto stesso di virtualizzazione...posso sostituirmi a qualcosa se so come funziona dovendo da una parte dialogare con qualcuno che parla un lnguaggio e "tradurlo" per un altro che capisce un linguaggio differente.
2)Hai un po di confusione circa la gestione dei thread da parte di java.Ogni thread viene schedulato a livello jvm(almeno nelle prime implementazioni...ora non è esattamente cosi)e poi mappato in un thread di sistema..ma il concetto chiave è che il sistema conosce solo la jvm(come se fosse un programma unico).Ancora piu chiaramente con una jvm non progettata(o meglio programmata per sfruttare il multithread) per architetture multi-core...il parallelismo parmane cmq virtuale come se la macchina avesse un solo processore.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2007, 13:27   #20
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Schedulato a livello JVM, conosce solo la JVM... ma San Giosafatte, ma guardate i sorgenti! Si chiama OPEN jdk perchè è OPEN source.
__________________
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


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
28 astronauti cinesi hanno condotto un'e...
Dal Padiglione Italia al mercato globale...
POCO M8: display AMOLED luminoso, batter...
ECOVACS, tante novità a Las Vegas...
Caso Galaxy Ring difettoso: Samsung chiu...
Targa e assicurazione per monopattini el...
AI Cloud Protect: la soluzione di Check ...
Nuovo spettacolare video del razzo spazi...
Hisense presenta a CES 2026 il display M...
XPeng P7+ è pronta per l'Europa: ...
IKEA nuove lampade Matter annunciate al ...
Il telescopio Hubble potrebbe andare dis...
Hisense introduce RGB MiniLED evo (a qua...
Deumidificatore De'Longhi in offerta su ...
OnePlus 15R: il 'battery phone' pi&ugrav...
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: 20:21.


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