Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-03-2011, 11:35   #1
tenbota87
Junior Member
 
Iscritto dal: Feb 2011
Messaggi: 21
[C] codifica RLE

Salve a tutti..
avrei bisogno di un piccolo aiuto..

dovrei fare un progetto che utilizza la compressione RLE.
Essa consiste nel contare i caratteri ripetuti consecutivamente e salvare questo numero con la lettera corrispondente.

Ad esempio la stringa ddfffm diventa d2f31m

Il mio problema è il salvataggio del numero e della lettera in maniera efficiente, cercando di limitare il più possibile lo spazio occupato.

Sono riuscito a implementare banalmente il salvataggio, ma la mia soluzione richiede troppo spazio e tempo di esecuzione.

Qualcuno potrebbe aiutarmi gentilmente? Grazie per la vostra disponibilità
tenbota87 è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2011, 12:00   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12843
Posta il codice che hai scritto .

Premesso che non sono un esperto di codifica, detta così, non credo tu possa fare di meglio rispetto alle specifiche.

Se RLE prevede quel tipo di codifica, e tu lo devi applicare alla lettera credo che ulteriori ottimizzazioni escano fuori dalle specifiche che hai richiesto.

Comunque ora che mi viene in mente potresti codificare i numeri non come testo ma come bit.

Ad esempio la stringa "255" occupa 3 byte, ovvero 3*8 = 24bit.

Il numero 255 è rappresentabile da una codifica ad 8 bit e quindi può occupare 3 volte meno, risparmiando ben 2 byte .

Una cosa carina sarebbe utilizzare una codifica adattativa sulla base dell'alfabeto che hai e sulla base del massimo numero di ripetizioni che trovi, ti richiederebbe 2 passate, ma potresti arrivare a risparmiare più spazio.

Ad esempio se trovi che il numero massimo di ripetizioni è 15, potresti usare uno schema del tipo:

Codice:
8-bit lettera | 4-bit numero | 8-bit lettera | 4-bit numero ...
In questo caso con 2 lettere risparmi un byte.

Cosa importante: nell'header del file creato devi specificare la lunghezza in bit del campo numerico. Quindi aggiungi all'inizio del file magari 8 bit di intestazione (questi saranno sempre fissi perché devi sapere quanto leggere).

Ultima modifica di WarDuck : 14-03-2011 alle 12:15.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2011, 20:14   #3
Mirkolo
Senior Member
 
L'Avatar di Mirkolo
 
Iscritto dal: Sep 2007
Messaggi: 329
Tempo fa avevo scritto una libreria per aprire file PSD (Photoshop) in C. Lì utilizzano la codifica PackedBits di Apple, che in sostanza è un ibrido tra RLE e la copia dei dati senza alcuna compressione. Se l'input varia di byte in byte la codifica RLE diventa inutilmente esosa. Il trucco sta nel partire con un codice di escape, se questo vale meno di 128 i seguenti n+1 byte devono essere copiati così come sono, se vale 128 non viene considerato, se vale più di 128 il byte successivo va ripetuto 257-n volte (quindi al massimo 257-129 = 128 volte). E così via.

Se il buffer ha tutti caratteri uguali ottieni un rapporto di compressione tendente a 1:128, mentre se sono tutti diversi hai un sovrapprezzo da pagare di x/128 byte, se x è la dimensione del buffer.
__________________
Canon EOS 5D3 | 16-35 f/4 L IS | 24-105 f/4 L IS | 70-200 f/4 L IS | 14 f/2.8 | 24 f/1.4 L | 35 f/1.4 | 135 f/2.0 L | Canon 430EX
Mirkolo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Addio Amazon? ChatGPT ora ti fa comprare...
YouTube chiude la causa con Trump: accor...
Avio: contratto da 40 milioni di € da ES...
Claude Sonnet 4.5, il nuovo modello di A...
Silent Hill f è un successo: gi&a...
Nuova Jeep Compass: aperti i preordini p...
La PS5 Slim con SSD più piccolo s...
Zero combustibili fossili e controllo qu...
Corsair NAUTILUS 360 RS LCD: raffreddame...
Nuovo record nel mondo dei computer quan...
Sony e Universal combatteranno l'IA con....
Il Chips Act europeo attuale è un...
OnePlus 15: debutto globale con design '...
Amazon Prime: addio alla prova gratuita ...
Windows 11 25H2: guida passo-passo per l...
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: 05:34.


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