Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo
HP OMEN MAX 16-ak0001nl combina RTX 5080 Laptop e Ryzen AI 9 HX 375 in un desktop replacement potente e ben raffreddato, con display 240 Hz e dotazione completa. Autonomia limitata e calibrazione non perfetta frenano l'entusiasmo, ma a 2.609 euro è tra le proposte più interessanti della categoria.
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-05-2016, 20:45   #1
Titti92
Member
 
Iscritto dal: Aug 2013
Messaggi: 68
Prodotto tra interi a 64bit

Sto utilizzando Assembly MIPS, ma la mia è una domanda più che altro di carattere generale. Devo fare il prodotto tra due interi a 64 bit, quindi salvati ciascuno in due registri a 32bit (facciamo per esempio che uno sia in $a0,$a1 e l'altro in $a2,$a3, dove il numero del registro più basso indica che vi è la parte meno significativa del numero). So che per trovare il prodotto devo fare:
Codice:
$v0=LO(a0*a3)
$v1=HI(a0*a2)+LO(a1*a2)+LO(a0*a3)
dove HI e LO sono due registri di appoggio utilizzati dall'istruzione MULT (prodotto tra deu reg. a 32 bit) del Mips, quindi in HI ci va la parte alta del prodotto e in LO la parte bassa. E' giusto quello che ho detto? E se sì, mi potete spiegare perché? Dovrei fare anche il prodotto tra interi a 64 e riportarlo a 128 bito quindi vorrei capire come funziona questo primo prodotto.
Titti92 è offline   Rispondi citando il messaggio o parte di esso
Old 27-05-2016, 15:02   #2
Titti92
Member
 
Iscritto dal: Aug 2013
Messaggi: 68
nessuno?
Titti92 è offline   Rispondi citando il messaggio o parte di esso
Old 27-05-2016, 19:35   #3
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Non conosco adeguatamente l'architettura MIPS, ma probabilmente con questo risolvi: https://bytes.com/topic/c/answers/21...multiplication
__________________
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 29-05-2016, 15:46   #4
Titti92
Member
 
Iscritto dal: Aug 2013
Messaggi: 68
Grazie! Comunque la mia è una domanda un po' generica, non proprio soltanto dell'archtettura MIPS.
Titti92 è offline   Rispondi citando il messaggio o parte di esso
Old 29-05-2016, 19:26   #5
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
OK, allora potresti spiegare prima cosa intendi con questo:

LO(a0*a3)

?

Se LO è un registro che contiene la parte bassa del risultato di una moltiplicazione, non capisco che ruolo abbia nell'espressione che hai usato, visto che a0*a3 dovrebbe rappresentare il prodotto di quei due registri.
__________________
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 15-06-2016, 10:02   #6
Titti92
Member
 
Iscritto dal: Aug 2013
Messaggi: 68
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
OK, allora potresti spiegare prima cosa intendi con questo:

LO(a0*a3)

?

Se LO è un registro che contiene la parte bassa del risultato di una moltiplicazione, non capisco che ruolo abbia nell'espressione che hai usato, visto che a0*a3 dovrebbe rappresentare il prodotto di quei due registri.
L'operazione di moltiplicazione restituisce un numero a 64 bit, diviso su due registri a 32 bit: LO e HI, il primo contiene la parte bassa del risultato e l'altro la parte alta. Con LO(a0*a3) intendevo dire che prendo la parte bassa di quel prodotto.
Titti92 è offline   Rispondi citando il messaggio o parte di esso
Old 15-06-2016, 21:04   #7
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
OK. Allora partiamo dallo pseudocodice di quello che devi eseguire. Ho trovato un post semplice qui che descrive la classica operazione di moltiplicazione a precisione più elevata, sfruttando 4 istruzioni di moltiplicazione a metà precisione:
Codice:
      A2A1
x     B2B1
----------
      B1A1
+   B1A2
+   B2A1
+ B2A2
----------
  C4C3C2C1
Alla fine ho aggiunto degli pseudoregistri anche per i 4 valori a 32-bit che conterranno il valore a 128-bit prodotto dall'operazione, in modo da rendere visivamente dove andranno a finire i risultati parziali.

Supponendo che siano tutti registri a 32-bit, B1A1 lo devi tradurre nell'istruzione MIPS di moltiplicazione 32x32 (senza segno), che produrrà i risultati in LO e HI.

Al primo passo semplicemente li conserverai LO in C1 (che rimarrà tale) e HI in C2, mentre mettera che devono contenere il risultato finale, a 128-bit, dell'operazione di moltiplicazione.

Per il secondo passo ti consiglierei di calcolare B2A2, copiando poi LO in C3 e HI in C4.

A questo punto devi eseguire i due prodotti intermedi, e sommare i risultati a C2 con somma semplice, a C3 con somma con riporto (che può provenire dalla precedente somma), e sommare zero + riporto (che può provenire dalla precedente somma) a C4.

Penso sia tutto. Ovviamente la stessa cosa vale per la moltiplicazione 128x128 -> 256 bit.
__________________
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 20-06-2016, 09:04   #8
Titti92
Member
 
Iscritto dal: Aug 2013
Messaggi: 68
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
OK. Allora partiamo dallo pseudocodice di quello che devi eseguire. Ho trovato un post semplice qui che descrive la classica operazione di moltiplicazione a precisione più elevata, sfruttando 4 istruzioni di moltiplicazione a metà precisione:
Codice:
      A2A1
x     B2B1
----------
      B1A1
+   B1A2
+   B2A1
+ B2A2
----------
  C4C3C2C1
Alla fine ho aggiunto degli pseudoregistri anche per i 4 valori a 32-bit che conterranno il valore a 128-bit prodotto dall'operazione, in modo da rendere visivamente dove andranno a finire i risultati parziali.

Supponendo che siano tutti registri a 32-bit, B1A1 lo devi tradurre nell'istruzione MIPS di moltiplicazione 32x32 (senza segno), che produrrà i risultati in LO e HI.

Al primo passo semplicemente li conserverai LO in C1 (che rimarrà tale) e HI in C2, mentre mettera che devono contenere il risultato finale, a 128-bit, dell'operazione di moltiplicazione.

Per il secondo passo ti consiglierei di calcolare B2A2, copiando poi LO in C3 e HI in C4.

A questo punto devi eseguire i due prodotti intermedi, e sommare i risultati a C2 con somma semplice, a C3 con somma con riporto (che può provenire dalla precedente somma), e sommare zero + riporto (che può provenire dalla precedente somma) a C4.

Penso sia tutto. Ovviamente la stessa cosa vale per la moltiplicazione 128x128 -> 256 bit.
Grazie mille!
Titti92 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Crollo del mercato PC nel 2026: secondo ...
Come dimostrare che gli agenti di IA fan...
Galaxy AI potrebbe creare app funzionant...
Luce solare anche di notte con i satelli...
The Witcher 4 con ambientazioni da urlo ...
007 First Light e Control Resonant avran...
DLSS 4.5 con Dynamic Multi Frame Generat...
Meta acquisisce Moltbook, il social netw...
Red Hat al MWC 2026: attenzione all'IA n...
Amazon espande 'Paga in Contanti': ora d...
Samsung Galaxy S26 Ultra, promosso ma se...
Gemini sempre più integrato in Go...
NVIDIA investe in Thinking Machines Lab:...
NVIDIA prepara NemoClaw, piattaforma ope...
Samsung testa una batteria da 20.000 mAh...
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: 23:42.


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