Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
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


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Nuove informazioni sul fallimento del la...
SpaceX: completato parte dell'assemblagg...
Landspace si prepara al secondo lancio d...
Tutti gli sconti Apple su Amazon: tornan...
Altro che entry-level: due smartwatch Am...
Roscosmos ha posticipato (ancora) il lan...
Isar Aerospace si prepara al secondo lan...
Tory Bruno è entrato in Blue Orig...
Fujifilm lancia la cartuccia per archivi...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
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: 22:04.


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