Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-05-2011, 21:23   #1
einstein1969
Member
 
Iscritto dal: Apr 2011
Città: Roma
Messaggi: 168
[DOS-BATCH] Matematica su Interi grandi

Salve a tutti,

non so se qui si estende anche all'interprete dos batch (nt/xp).

Devo fare una procedura che ritorna lo spazio libero su disco e poi dividere il risultato per 1024 (o 1024*1024)

Solo che l'interprete arriva a gestire gli interi fino a 32 bit.

Non vorrei usare utility di terze parti se possibile.

Qualcuno mi puo' aiutare a trovare una soluzione?

Grazie
einstein1969 è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2011, 22:51   #2
einstein1969
Member
 
Iscritto dal: Apr 2011
Città: Roma
Messaggi: 168
Ho provato con la divisione e mi sono reso conto che potevo usare una proprietà dei numeri decimali.

Es. 1234567890/123456 = 1234567890/100000 - Errore

Poi ho calcolato l'errore commesso.

Ho visto che N/M si puo' anche scrivere in N/(A+B)

Poi ho posto N/(A+B) = N/A - Errore

da cui Errore = B*N/(A*(A+B))

La cosa poteva andare ma non e' semplice da realizzare.

Ho poi trovato l'algoritmo di Karatsuba che ricorda un po' quello che ho fatto. Ma ce ne sono anche altri... più veloci.

Solo che dovrei fare una moltiplicazione per l'inverso di un numero.

In java l'ho trovato

Qualcuno che mi da una mano a capire il codice in java?

.

Ultima modifica di einstein1969 : 12-05-2011 alle 23:03.
einstein1969 è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2011, 08:36   #3
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
Proviamo.. Hai già il codice?
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2011, 09:27   #4
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 13003
Mmm non so se con VBScript le cose ti vengano più semplici...
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2011, 10:36   #5
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
@einstein1969: ciao, l'algoritmo di Karatsuba, di cui hai postato link a una implementazione in Java, non penso che risolva il tuo problema (o almeno io non ho capito come) dato che la sua utilità è data dal fatto che ha una complessità asintotica migliore di quella dell'algoritmo naive per moltiplicare gli interi, però val la pena usarlo quando gli interi in questione sono davvero molto molto grandi (nel sorgente linkato hanno posto un valore di soglia di 1000 cifre binarie).

In ogni caso resta il problema di rappresentarli questi interi molto grandi, problema che nel codice Java da te linkato viene risolto utilizzando la classe java.math.BigInteger, un tipo che rappresenta interi di grandezza arbitraria.

Io opterei per VBScript, come consigliato da WarDuck!
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2011, 12:40   #6
einstein1969
Member
 
Iscritto dal: Apr 2011
Città: Roma
Messaggi: 168
GRazie ragazzi ,

veramente tutti gentili.

@ndakota
Il codice e' nel mio secondo post, e' in java.

@WarDuck
Grazie del link. Mi sa che dovro' ripiegare al vbscript. Non lo conosco affatto. Sai se e' disponibile su tutte le piattaforme MS windows (da xp in poi) ? Va installato?

@banryu79
Immaginavo che sarebbe stato un bagno di sangue.

Comunque per esempio con il mio metodo sono riuscito a fare una procedura "statica" per la divisione per (1024*1024*1024)
Cioè il passaggio da byte a Giga bytes

es.

Codice:
rem setto il valore grande (circa 2 Tera)
set gb=2100700123456

rem Rimuovo la parte poco significativa (mi servono solo 3 decimali dopo la virgola)
set gb=%gb:~0,-6%

rem applico la formula:N/(A+B)=N/A-[B*N/(A*(A+B))] con A =1,10,100,1000,
rem 10000,100000,etc cosi la divisione e' uno shift decimale che si puo' fare
rem anche senza dividere ma con operazioni su stringhe.

rem Uso la formula per due livelli (dovrebbero bastare per tre decimali dopo 
rem la virgola.

rem primo livello:

rem N/M=2100700123456/(1024*1024*1024)=2100700123456/1073741824=
rem =2100700123456/(1000000000+73741824)=
rem =2100700123456/1000000000-[73741824*2100700123456/(1000000000*(1000000000+73741824))]

rem Per il secondo procedo in modo analogo.

rem dal secondo livello ottengo il numero 31926 che rapprensenta il valore
rem  (piccolo) per realizzare la divisione.

set /a my_gb=gb*1000/1000-(gb*1000/10000-gb*1000/31926) 

echo %my_gb%

rem il valore trovato va bene per qualsiasi valore di gb , rappresenta solo il divisore.
Ho trovato comunque chi ci ha calcolato il PI (pi greco). Forse usando i metodi sopra citati.

Ma a questo punto, se il vbscript soddisfa certi requisiti , userò quello.

Ma mi serve una mano!

Ultima modifica di einstein1969 : 13-05-2011 alle 12:48.
einstein1969 è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2011, 13:53   #7
einstein1969
Member
 
Iscritto dal: Apr 2011
Città: Roma
Messaggi: 168
Praticamente il divisore e' piccolo e la divisione stessa e' semplice shift decimale. Il dividendo forse puo' subire la stessa sorte.

N/(1024*1024*1024)= (a meno di un errore) N-N/10+N/(3*10)-N/(4*100)+N/(2*1000)

e' una successione alternante.

Lo so, sembra arabo...

Ultima modifica di einstein1969 : 13-05-2011 alle 13:57.
einstein1969 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
La NASA avrebbe fermato i lavori sul mod...
Mancano pochi giorni al lancio della mis...
Prime Day in anticipo, giorno 7: tempo d...
Lo smartphone HONOR con batteria da 11.0...
Amazfit Bip 5, Active 3 Premium e Balanc...
Xiaomi potrebbe portare i suoi Pro e Pro...
Crisi delle memorie: CMF annulla il pros...
La PS6 si farà attendere: il lanc...
OnePlus non sente la crisi delle memorie...
I futuri iPhone 18 Pro potrebbero costar...
Bosch eBike Systems MY2027: a sorpresa a...
Amazon, le top 5 offerte del weekend per...
Sesto giorno di Prime Day anticipato Ama...
La scopa elettrica Roborock F25 Ultra sc...
Ho messo uno studio video con Intelligen...
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: 14:34.


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