Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-06-2006, 12:36   #1
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
[Assembly] Listato che non da risultati

Questo è il programma, la maschera è in C ma l'algoritmo è tutto in assembly.
Dovrebbe secondo il mio ragionamento calcolare la distanza tra il punto Point e gli altri punti contenuti in PointSet e darmi in output l'indice dell'elemento di PoinSet più vicino a Point.

l'algoritmo che ho pensato è semplicissimo ed è questo:

1) metto prima in ax e bx le coordinate x di Point e di un elemento PointSet poi le coordinate y
2) eseguo le operazioni matematiche per calcolare la distanza e metto il risultato in DX
3) confronto DX con il vecchio DX che conteneva la distanza tra il punto e l'elemento precedente di PointSet, se il vecchio DX è più grande lo sostituisco con il nuovo in modo da avere in DX sempre la distanza minore
4) aggiorno l'indice se ho sostituito DX altrimenti lo lascio invariato (come indice uso ECX che incremento per scorrere PointSet e che salvo nello stack all'inizio del ciclo)
5) ripeto il ciclo fino a n che è il numero di elementi di PointSet e poi esco


Codice:
#include<stdio.h>

void main()
{	
	unsigned int Point = (5<<16 | 3); //il punto
	unsigned int PointSet[] = {(10<<16) |3, (4<<16) |2, (5<<16) |20 }; //insieme
	unsigned int n = sizeof(PointSet)/sizeof(PointSet[0]); //numero punti dell'insieme
	unsigned int index; //risultatoindice del punto più vicino a Point

	
	_asm{
		//Azzero i registri utilizzati nel programma
		XOR EAX,EAX
		XOR EBX,EBX
		XOR ECX,ECX
		XOR EDX,EDX
						
		XOR ESI,ESI
		XOR EDI,EDI

Ciclo:		
		PUSH ECX

		MOV CX, DX
		// metto in AX la coordinata x di Point
		MOV AX,[WORD PTR Point+2]
		// metto in BX la coordinata x dell'elemento PointSet a cui sono arrivato
		MOV BX,[WORD PTR PointSet+ECX+2]
		
		//operazioni matematiche sui registri per fare sqrt ((x2-x1)^ + (y2-y1)^2)
		SUB BX, AX //in bx ho x2-x1
		IMUL BX, BX //in bx ho (x2-x1)^2
		MOV DX, BX //in dx ho (x2-x1)^2
		MOV AX,[WORD PTR Point]
		MOV BX,[WORD PTR PointSet+ECX]
		SUB BX, AX //in bx ho y2-y1
		IMUL BX, BX //in bx ho (y2-y1)^2
		ADD BX, DX //in BX ho (x2-x1)^ + (y2-y1)^2
		MOV DX, BX //in DX ho (x2-x1)^ + (y2-y1)^2

		//mettere qui la radice quadrata di DX
		
		CMP CX, DX
		JG Salva
		
Ritorna:
		POP ECX
		INC ECX
		CMP ECX, n
		JNE Ciclo
		JE Termina

Salva:
		MOV CX, DX
		MOV index, ECX
		JMP Ritorna

Termina:




	}

	//Stampa su video
	printf("Il punto più vicino a: ( %d, %d ) e' |%d, %d| [indice=%d]\n", 
	(short int)(Point&0xFFFF), (short int) (Point>>16),
	(short int)(PointSet[index]&0xFFFF), (short int) (PointSet[index]>>16),
	index
	);
}
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 12:51   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Per fare i calcoli se vuoi puoi usare le istruzioni per le operazioni matematiche in floating-point!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 12:59   #3
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
ma perché l'algoritmo lo fai in assembly? e la maschera che è?
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 13:01   #4
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
Quote:
Originariamente inviato da 71104
ma perché l'algoritmo lo fai in assembly? e la maschera che è?
Lo devo fare per forza in assembly, per maschera intendevo l'intestazione del programma e la struttura che è fatta sotto visual c++.
Non posso cambiare le variabili e posso solo scrivere l'algoritmo in assembly tra le graffe asm.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 13:04   #5
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
Quote:
Originariamente inviato da andbin
Per fare i calcoli se vuoi puoi usare le istruzioni per le operazioni matematiche in floating-point!
Il fatto è che non le conosco, ho cercato di risolvere con le conoscenze che ho, alla fine questo è quello che abbiamo fatto nel corso penso che dovrebbero bastare. Può essere che non funziona perchè sbaglio le operazioni dici?
Io a parte che non so fare la radice quadrata pensavo che le altre operazioni sui registri potessero andare.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 13:19   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da -Ivan-
Il fatto è che non le conosco, ho cercato di risolvere con le conoscenze che ho, alla fine questo è quello che abbiamo fatto nel corso penso che dovrebbero bastare. Può essere che non funziona perchè sbaglio le operazioni dici?
Io a parte che non so fare la radice quadrata pensavo che le altre operazioni sui registri potessero andare.
Sto controllando il tuo sorgente. Per la radice quadrata ... non saprei come farla senza usare le istruzioni FP. Cioè bisogna conoscere l'algoritmo per calcolare la radice quadrata. Che non è sicuramente così banale!

Comunque invece di fare:
Codice:
MOV AX,[WORD PTR Point+2]
MOV BX,[WORD PTR PointSet+ECX+2]
SUB BX, AX
Puoi fare più semplicemente:
Codice:
MOV BX,[WORD PTR PointSet+ECX+2]
SUB BX,[WORD PTR Point+2]
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 13:22   #7
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
Prova a dirmi per esempio una istruzione sui fp che magari le conosco ma sono leso in questo momento e non mi vengono in mente.

edit: ho attuato qualche modifica ai registri, ora ho un risultato non mi si blocca più il programma, l'ultima cosa è che devo fare la radice quadrata di AX e non so come farla, non si fa per caso con lgi shift? Con quali comandi si fa?
Intanto ti ringrazio davvero tanto andbin perchè mi hai dato una grossa mano.

Ultima modifica di -Ivan- : 24-06-2006 alle 13:31.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 13:59   #8
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da -Ivan-
Prova a dirmi per esempio una istruzione sui fp che magari le conosco ma sono leso in questo momento e non mi vengono in mente.
Ecco:
Codice:
finit

fild	[WORD PTR PointSet+ecx+2]     // x2
fisub	[WORD PTR Point+2]            // x2 - x1
fmul	ST(0), ST(0)                  // (x2-x1)^2

....
Quote:
Originariamente inviato da -Ivan-
l'ultima cosa è che devo fare la radice quadrata di AX e non so come farla, non si fa per caso con lgi shift? Con quali comandi si fa?
Non bastano degli shift o una istruzione ma un algoritmo ben preciso!!!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 14:04   #9
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
Porca pupazza io non li ho mai visti questi comandi, la vedo abbastanza male allora anche perchè non ci sono nemmeno sulle dispense.
Non è che magari ho sbagliato a calcolare la distanza tra 2 punti e non è
sqrt((x2-x1)^2+(y2-y1)^2) ma qualcos'altro? Oppure c'è un modo più semplice.
Grazie lo stesso, adesso devo andare a lavorare mi ci metto stanotte semmai.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 14:14   #10
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da -Ivan-
Non è che magari ho sbagliato a calcolare la distanza tra 2 punti e non è
sqrt((x2-x1)^2+(y2-y1)^2) ma qualcos'altro? Oppure c'è un modo più semplice.
Questo non lo so ... non sono un matematico. So che per calcolare la distanza tra 2 punti si usa il ben noto Teorema di Pitagora, che porta alla formula che hai appena detto.


P.S. comunque se non puoi calcolare la radice quadrata, puoi usare anche solo: (x2-x1)^2+(y2-y1)^2. Tanto devi solo fare delle comparazioni per determinare quale tra i punti è più vicino al primo punto!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)

Ultima modifica di andbin : 24-06-2006 alle 14:17.
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2006, 17:13   #11
repne scasb
Bannato
 
Iscritto dal: Feb 2003
Messaggi: 947
A meno di errori grossolani:

Codice:
;	Mode: Assembly x86/16/32
;
;	Input
;
;	word ptr [point] = Coordinate x,y
;	word ptr [point_set] = Array di coordinate x,y
;	word ptr [n_point] = Numero punti
;
;	Output
;
;	word ptr [min_point_set] = Indice distanza minima


        Check_DPoint	proc	far

	pushad
	xor	ecx,ecx
	mov	bx,0FFFFh
loop_check_dpoint:
	mov	ax,word ptr [4*ecx+point_set]
	mov	dx,word ptr [4*ecx+point_set+2h]
	sub	ax,word ptr [point]
	sub	dx,word ptr [point+2h]
	imul	ax,ax
	imul	dx,dx
	add	ax,dx
	cmp	ax,bx
	jnb	no_min_d
	mov	word ptr [min_point_set],cx
	xchg	ax,bx
no_min_d:
	inc	cx
	cmp	cx,word ptr [n_point]
	jne	loop_check_dpoint	
	popad
	ret

	Check_DPoint	endp
repne scasb è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Anthropic ha un'AI che trova falle in Wi...
I 10 migliori sconti Amazon del weekend:...
Con un coupon scendono ancora: le super ...
Minimo storico per Samsung Galaxy S26 Ul...
Si è conclusa la missione lunare ...
EK Waterblock si arrende agli aumenti, i...
Geekbench si aggiorna: tutti i test con ...
Per la prima volta un computer quantisti...
Telecamere Reolink 4K su Amazon: Wi-Fi 6...
Anthropic vuole farsi i chip da sola? Co...
Il fondatore di Framework: il personal c...
JBL Live Flex 3 a 129€ su Amazon: ANC ad...
Come un uomo ha costruito un'azienda da ...
Multe fino a 400 euro anche se hai pagat...
Tapo lancia una valanga di offerte su Am...
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: 10:31.


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