Files
SAE32_2025/src/fr/iutfbleau/sae/mhuffman/CanonicalCode.java
T

70 lines
2.6 KiB
Java
Raw Normal View History

2026-01-03 13:08:16 +01:00
package fr.iutfbleau.sae.mhuffman;
import java.util.*;
2026-01-07 19:27:03 +01:00
/**
*
* Classe pour generer des codes canoniques de Huffman.
* Les codes canoniques sont des codes de Huffman reorganises
* pour faciliter la compression et le decodage.
*/
public class CanonicalCode {
2026-01-03 13:08:16 +01:00
2026-01-07 19:27:03 +01:00
/**
* Genere des codes canoniques a partir de codes de Huffman.
*
* @param codesHuffman les codes de Huffman initiaux
* @return les codes canoniques generes
*/
public Map<Integer, String> generateCodes(Map<Integer, String> codesHuffman) {
// On recupere les entrees des codes Huffman pour pouvoir les trier
List<Map.Entry<Integer, String>> liste = new ArrayList<>(codesHuffman.entrySet());
2026-01-03 13:08:16 +01:00
2026-01-07 19:27:03 +01:00
// On trie par longueur de la valeur ou sinon par la cle
2026-01-03 13:08:16 +01:00
Collections.sort(liste, new ComparateurCanonique());
2026-01-07 19:27:03 +01:00
Map<Integer, String> canonicalCodes = new HashMap<>();
int code = 0; // Code canonique a attribuer
int temp = 0; // Garde la longueur du code precedent, pour gerer le decalage
2026-01-03 13:08:16 +01:00
2026-01-07 19:27:03 +01:00
for (Map.Entry<Integer, String> entree : liste) {
int valeur = entree.getKey(); // Symbole actuel
int longueur = entree.getValue().length(); // Longueur du code actuel
2026-01-03 13:08:16 +01:00
2026-01-07 19:27:03 +01:00
code <<= (longueur - temp); // Permet de decaler le code actuel si la longueur augmente
2026-01-03 13:08:16 +01:00
String codeBinaire = Integer.toBinaryString(code);
2026-01-07 19:27:03 +01:00
// Permet d'ajouter des zeros si necessaire
while (codeBinaire.length() < longueur) {
codeBinaire = "0" + codeBinaire;
}
2026-01-03 13:08:16 +01:00
2026-01-07 19:27:03 +01:00
canonicalCodes.put(valeur, codeBinaire); // Ajout dans le dictionnaire
code++; // Incrementation pour la valeur qui suit
temp = longueur; // Mise a jour de la longueur precedente
2026-01-03 13:08:16 +01:00
}
2026-01-07 19:27:03 +01:00
return canonicalCodes;
}
2026-01-03 13:08:16 +01:00
2026-01-07 19:27:03 +01:00
/**
* Recupere le code canonique d'une valeur.
*
* @param canonicalCodes la table des codes canoniques
* @param value la valeur dont on veut le code
* @return le code canonique correspondant
*/
public String getCode(Map<Integer, String> canonicalCodes, int value) {
return canonicalCodes.get(value);
}
2026-01-03 13:08:16 +01:00
2026-01-07 19:27:03 +01:00
/**
* Recupere la longueur d'un code pour une valeur donnee.
*
* @param codesH la table des codes
* @param value la valeur dont on veut la longueur
* @return la longueur du code en bits
*/
public int getLength(Map<Integer, String> codesH, int value) {
return codesH.get(value).length();
}
}