Senin, 12 Oktober 2015
Compressi ShannonFano Source Code Using Java
package lp2maray.com;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.util.BitSet;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Vector;
public class ShannonFano{
public static void main(String[] args){
InputStream is, isDecompress;
OutputStream os, osDecompress;
String filename = "file3MB.txt";
Path currentRelativePath = Paths.get("");
String s = currentRelativePath.toAbsolutePath().toString();
System.out.println("Current relative path is: " + s);
String fileCom = s+"/doc/file3MB.txt";
String fileDec = s+"/doc/dec.zsf";
//file3MB.txt.zsf
new ShannonFanoCompress(fileCom,null,true); //compress
}
public ShannonFanoCompress(String filename,String destination,boolean verbose){
if(verbose)
System.out.println("compression started, source : "+filename);
HashMap<String,Integer> occurenceTable=new HashMap<String,Integer>();
int total=0;
try{
if(verbose)
System.out.println("counting occurences...");
BufferedReader in=new BufferedReader(new FileReader(filename));
String s=null,c=null;
char tab[]=new char[1];
int i,lineCount=0;
while((s=in.readLine())!=null){
for(i=0;i<s.length();i++)
{tab[0]=s.charAt(i);
c=new String(tab);
if(occurenceTable.containsKey(c))
occurenceTable.put(c,new Integer(occurenceTable.get(c).intValue()+1));
else
occurenceTable.put(c,new Integer(1));
}
total+=s.length()+1;
//count each newline too
lineCount++;
}//while
in.close();
//put ("newline",...) in occurenceTable
occurenceTable.put("newline",new Integer(lineCount));
if(verbose){
System.out.println(lineCount+" line(s) in the file : "+filename);
System.out.println("occurence table");
for(Map.Entry<String,Integer> m:occurenceTable.entrySet())
System.out.println(m.getKey()+" "+m.getValue());
}
}
catch(IOException ioe){ioe.printStackTrace();
return;
}
if(verbose)
System.out.println("computing frequency table...");
LinkedHashMap<String,Float> tmpfrequencyTable=new LinkedHashMap<String,Float>();
for(String tmp:occurenceTable.keySet())
tmpfrequencyTable.put(tmp,new Float(((float)occurenceTable.get(tmp).intValue())/total));
Vector<Float> l=new Vector<Float>();
l.addAll(tmpfrequencyTable.values());
Collections.sort(l,Collections.reverseOrder());
LinkedHashMap<String,Float> frequencyTable=new LinkedHashMap<String,Float>();
for(Float value:l)
for(String key:tmpfrequencyTable.keySet())
if(tmpfrequencyTable.get(key).equals(value))
{frequencyTable.put(key,value);
tmpfrequencyTable.remove(key);
break;
}
if(verbose)
{System.out.println("frequency table");
for(Map.Entry<String,Float> m:frequencyTable.entrySet())
System.out.println(m.getKey()+" "+m.getValue());
}
if(verbose)
System.out.println("computing code table...");
LinkedHashMap<String,StringBuffer> codeTable=new LinkedHashMap<String,StringBuffer>();
for(String tmp:frequencyTable.keySet())
codeTable.put(tmp,new StringBuffer(""));
updateTables(frequencyTable,codeTable);
if(verbose)
{System.out.println("code table");
for(Map.Entry<String,StringBuffer> m:codeTable.entrySet())
System.out.println(m.getKey()+" "+m.getValue());
}
File f;
if(destination==null)
f=new File(filename+".zsf");
else
f=new File(destination);
if(verbose)
System.out.println("destination file : "+f.getName());
try {
if(verbose)
System.out.println("computing bit set from source file by using code table (main compression step)...");
BufferedReader in=new BufferedReader(new FileReader(filename));
String s=null,c=null;
char tab[]=new char[1];
int i=0,j=0,k=0;
BitSet content=new BitSet();
String value=null,newlineValue=new String(codeTable.get("newline"));
while((s=in.readLine())!=null)
{for(i=0;i<s.length();i++)
{tab[0]=s.charAt(i);
c=new String(tab);
value=new String(codeTable.get(c));
for(j=0;j<value.length();j++,k++)
if(value.charAt(j)=='1')
content.set(k,true);
}
for(j=0;j<newlineValue.length();j++,k++)
if(newlineValue.charAt(j)=='1')
content.set(k,true);
}
content.set(k,true);
in.close();
if(f.createNewFile() && verbose)
System.out.println("file "+f.getName()+" created");
if(verbose)
System.out.println("writing code table...");
PrintWriter out=new PrintWriter(new BufferedWriter(new FileWriter(f)));
out.println(codeTable.size());
for(Map.Entry<String,StringBuffer> m:codeTable.entrySet())
out.println(m.getKey()+" "+m.getValue());
byte[] byteContent=convertBitSetInBytes(content);
if(verbose)
System.out.println("writing size of compressed content : "+byteContent.length+" bytes");
out.println(byteContent.length);
out.close();
if(verbose)
System.out.println("writing compressed content...");
BufferedOutputStream out2=new BufferedOutputStream(new FileOutputStream(f,true));
out2.write(byteContent);
out2.close();
if(verbose)
System.out.println("compression successful");
}
catch(IOException ioe)
{ioe.printStackTrace();
return;
}
}
private static void updateTables(LinkedHashMap<String,Float> frequencyTablePart,
LinkedHashMap<String,StringBuffer> codeTablePart){
float leftSum=0,rightSum=0;
int limit=0;
for(Float val:frequencyTablePart.values())
rightSum+=val.floatValue();
for(Float x:frequencyTablePart.values())
{leftSum+=x;
rightSum-=x;
limit++;
if(leftSum>=rightSum)
break;
}
int j=0;
for(Map.Entry<String,StringBuffer> m:codeTablePart.entrySet())
{if(j<limit)
codeTablePart.put(m.getKey(),m.getValue().append("0"));
else
codeTablePart.put(m.getKey(),m.getValue().append("1"));
j++;
}
LinkedHashMap<String,Float> nextFrequencyTablePart;
LinkedHashMap<String,StringBuffer> nextCodeTablePart;
Iterator<String> frequencyKeySetIterator;
Iterator<Float> frequencyValuesIterator;
Iterator<String> codeKeySetIterator;
Iterator<StringBuffer> codeValuesIterator;
if(limit>1)
{frequencyKeySetIterator=frequencyTablePart.keySet().iterator();
frequencyValuesIterator=frequencyTablePart.values().iterator();
codeKeySetIterator=codeTablePart.keySet().iterator();
codeValuesIterator=codeTablePart.values().iterator();
nextFrequencyTablePart=new LinkedHashMap<String,Float>();
for(int i=0;i<limit;i++)
nextFrequencyTablePart.put(frequencyKeySetIterator.next(),frequencyValuesIterator.next());
nextCodeTablePart=new LinkedHashMap<String,StringBuffer>();
for(int i=0;i<limit;i++)
nextCodeTablePart.put(codeKeySetIterator.next(),codeValuesIterator.next());
updateTables(nextFrequencyTablePart,nextCodeTablePart);
}
if(limit<codeTablePart.size()-1)
{frequencyKeySetIterator=frequencyTablePart.keySet().iterator();
frequencyValuesIterator=frequencyTablePart.values().iterator();
codeKeySetIterator=codeTablePart.keySet().iterator();
codeValuesIterator=codeTablePart.values().iterator();
for(int i=0;i<limit;i++)
{frequencyKeySetIterator.next();
frequencyValuesIterator.next();
codeKeySetIterator.next();
codeValuesIterator.next();
}
nextFrequencyTablePart=new LinkedHashMap<String,Float>();
while(frequencyKeySetIterator.hasNext())
nextFrequencyTablePart.put(frequencyKeySetIterator.next(),frequencyValuesIterator.next());
nextCodeTablePart=new LinkedHashMap<String,StringBuffer>();
while(codeKeySetIterator.hasNext())
nextCodeTablePart.put(codeKeySetIterator.next(),codeValuesIterator.next());
updateTables(nextFrequencyTablePart,nextCodeTablePart);
}
}
public static byte[] convertBitSetInBytes(BitSet bitSet){
byte[] byteContent=new byte[(int)Math.ceil(bitSet.length()/8.0f)];
int i;
for(i=0;i<byteContent.length;i++)
byteContent[i]=(byte)0x0000;
for(i=0;i<bitSet.size();i++)
if(bitSet.get(i))
byteContent[i/8]|=1<<(7-(i%8));
return(byteContent);
}
public static BitSet convertBytesInBitSet(byte[] array){
BitSet bitset=new BitSet();
int j;
byte[] mask={(byte)0x01,(byte)0x02,(byte)0x04,(byte)0x08,(byte)0x10,(byte)0x20,(byte)0x40,(byte)0x80};
for(int i=0;i<array.length;i++)
for(j=0;j<8;j++)
if((array[i] & mask[j])!=0)
bitset.set(i*8+(7-j),true);
return(bitset);
}
public static String toBitString(BitSet bitset,int length){
String s=new String("");
for(int i=0;i<length;i++)
if(bitset.get(i))
s+="1";
else
s+="0";
return(s);
}
}
HasilCompressi:
Compressi LZ78 Source Code
package lz78ok;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;
import java.nio.file.Path;
import java.nio.file.Paths;
public class LZ78OK {
public static void main(String[] args) {
LZ78 lz78 = new LZ78();
InputStream is, isDecompress;
OutputStream os, osDecompress;
String filename = "file3MB.txt";
Path currentRelativePath = Paths.get("");
String s = currentRelativePath.toAbsolutePath().toString();
System.out.println("Current relative path is: " + s);
String filePath = s+"/doc/"+filename;
try {
is = new FileInputStream(filePath);
os = new FileOutputStream(new String(filePath + ".lz78"));
lz78.compress(is, os);
isDecompress = new FileInputStream(new String(filePath + ".lz78"));
osDecompress = new FileOutputStream(new String(filePath + ".lz78.decompressed.txt"));
lz78.decompress(isDecompress, osDecompress);
System.out.println("Done");
System.out.println(new String(filePath));
} catch (Exception e) {
}
}
}
======================
package lz78ok;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
public class LZ78 implements Compression {
boolean stopped = false;
public class Code {
Code(int code, int ch) {
this.ch = ch;
this.code = code;
}
int ch;
int code;
};
Dictionary dict;
byte[] buf;
public final ByteArray emptyBA = new ByteArray();
ByteArray w = emptyBA;
public LZ78() {
int numOfBits = 12;
buf = new byte[numOfBits];
dict = new LimitedSizeDictionary(1 << numOfBits);
dict.add(emptyBA);
}
public int encodeOneChar(int n) {
byte c = (byte) n;
ByteArray nw = w.conc(c);
int code = dict.numFromStr(nw);
if (code != -1) {
w = nw;
return -1;
} else {
dict.add(nw);
nw = w;
w = emptyBA;
return dict.numFromStr(nw);
}
}
public Code encodeLast() {
if (w.size() == 0)
return null;
byte bt = w.getLast();
w = w.dropLast();
return new Code(dict.numFromStr(w), (int) bt);
}
public final void writeCode(OutputStream os, Code c) throws IOException {
writeCode(os, c.ch, 8);
writeCode(os, c.code, 12);
}
public final void writeCode(OutputStream os, int num, int bits) throws IOException {
for (int i = 0; i < bits; ++i) {
os.write(num & 1);
num = num / 2;
}
}
public final Code readCode(InputStream is) throws IOException {
int ch = readInt(is, 8);
if (ch < 0)
return null;
int cd = readInt(is, 12);
if (cd < 0)
return null;
return new Code(cd, ch);
}
public final int readInt(InputStream is, int bits) throws IOException {
int num = 0;
for (int i = 0; i < bits; ++i) {
int next = is.read();
if (next < 0)
return -1;
num += next << i;
}
return num;
}
public void compress(InputStream is, OutputStream os) throws IOException {
os = new BitOutputStream(os);
int next;
int code;
while ((next = is.read()) >= 0) {
if (stopped) {
break;
}
code = encodeOneChar(next);
if (code >= 0) {
writeCode(os, new Code(code, next));
}
}
Code c = encodeLast();
if (c != null) {
writeCode(os, c);
}
os.flush();
}
public ByteArray decodeOne(Code c) {
ByteArray str = dict.strFromNum(c.code);
dict.add(str.conc((byte) c.ch));
return str;
}
@SuppressWarnings("unused")
public void decompress(InputStream is, OutputStream os) throws IOException {
is = new BitInputStream(is);
ByteArray str;
Code c;
while ((c = readCode(is)) != null) {
if (stopped) {
break;
}
if (c == null) {
break;
}
str = decodeOne(c);
os.write(str.getBytes());
os.write(c.ch);
}
}
public void stop() {
stopped = true;
}
}
=================
package lz78ok;
public class ByteArray {
final byte[] arr;
ByteArray(byte[] b) {
arr = (byte[]) b.clone();
}
ByteArray() {
arr = new byte[0];
}
ByteArray(byte b) {
arr = new byte[] { b };
}
public boolean equals(Object o) {
ByteArray ba = (ByteArray) o;
return java.util.Arrays.equals(arr, ba.arr);
}
public int hashCode() {
int code = 0;
for (int i = 0; i < arr.length; ++i)
code = code * 2 + arr[i];
return code;
}
public int size() {
return arr.length;
}
byte getAt(int i) {
return arr[i];
}
public ByteArray conc(ByteArray b2) {
int sz = size() + b2.size();
byte[] b = new byte[sz];
for (int i = 0; i < size(); ++i)
b[i] = getAt(i);
for (int i = 0; i < b2.size(); ++i)
b[i + size()] = b2.getAt(i);
return new ByteArray(b);
}
public ByteArray conc(byte b2) {
return conc(new ByteArray(b2));
}
public byte[] getBytes() {
return (byte[]) arr.clone();
}
public boolean isEmpty() {
return size() == 0;
}
public byte getLast() {
return arr[size() - 1];
}
public ByteArray dropLast() {
byte[] newarr = new byte[size() - 1];
for (int i = 0; i < newarr.length; ++i)
newarr[i] = arr[i];
return new ByteArray(newarr);
}
public String toString() {
return new String(arr);
}
}
=======================
package lz78ok;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
public interface Compression {
public void compress(InputStream inp, OutputStream out) throws IOException;
public void decompress(InputStream inp, OutputStream out) throws IOException;
}
=======================
package lz78ok;
import java.io.FilterInputStream;
import java.io.IOException;
import java.io.InputStream;
public class BitInputStream extends FilterInputStream {
/**
* Constructor creates a new instance of BitInputStream, A decarotor to
* InputStream, via FilterInputStream
*/
public BitInputStream(InputStream is) {
super(is);
}
class BitManager {
// Buffer to keep max of 7 bits (one byte)
private int[] buf = new int[8];
// Counter showing the bit number we are reading now
private int cnt = -1;
// If we are at the end of the stream
boolean atTheEnd() {
return ((buf[7] == 1) && (cnt < 0));
}
// Set the flag for the end of stream
void setTheEnd() {
buf[7] = 1;
cnt = -1;
}
// No more buffer, means we need to read the next byte
boolean noMoreBuffer() {
return cnt < 0;
}
// set the buffer
void setNext(int next) { // put the bits of the byte into the array
for (cnt = 0; cnt < 8; ++cnt) {
buf[cnt] = next % 2;
next /= 2;
}
// if this was the last byte
if (buf[7] == 1) {
for (cnt = 7; cnt >= 0; cnt--)
if (buf[cnt] == 0)
break;
cnt--;
} else {
cnt = 6;
}
}
// get the next bit
int getNext() {
return buf[cnt--];
}
// how many left
int left() {
return cnt + 1;
}
};
BitManager bitManager = new BitManager();
byte[] tempBuf = null;
int tempBufPtr = 0;
int tempBufLen = 0;
private int readNextByte() throws IOException {
int val = -1;
if (tempBufPtr == tempBufLen)
val = super.read();
else {
byte b = tempBuf[tempBufPtr++];
if ((b & 0x80) > 0)
val = ((int) (b & 0x7F)) | 0x80;
else
val = b;
}
return val;
}
/**
* Reads a single bit from the included stream. Returns either 1 or 0, and
* at the end of stream returns -1.
*/
public int read() throws IOException {
// If we are already at the end, return -1
if (bitManager.atTheEnd())
return -1;
// If we are in the last bit, then refill the buffer
if (bitManager.noMoreBuffer()) {
int i = readNextByte();
if (i < 0)
bitManager.setTheEnd();
else
bitManager.setNext(i);
return read();
}
// Return the specific bit
return bitManager.getNext();
}
/** Reads a list of bits given in the byte array as 0's and 1's */
public int read(byte[] arr) throws IOException {
return read(arr, 0, arr.length);
}
public int read(byte[] arr, int off, int len) throws IOException {
int bytelen = ((len - bitManager.left()) / 7);
tempBuf = new byte[bytelen];
tempBufLen = in.read(tempBuf);
tempBufPtr = 0;
for (int i = 0; i < len; ++i) {
int next = read();
if (next < 0)
return i;
arr[off + i] = (byte) next;
}
return len;
}
}
============================
package lz78ok;
import java.io.FilterOutputStream;
import java.io.IOException;
import java.io.OutputStream;
public class BitOutputStream extends FilterOutputStream {
class BitManager {
int buf = 0;
int cnt = 0;
int writeOne(int next) {
int ret = -1;
buf = buf * 2 + next;
cnt++;
if (cnt == 7) {
cnt = 0;
ret = buf;
buf = 0;
} else {
ret = -1;
}
return ret;
}
//
int writeLast() {
int x = 0;
for (int i = 0; i < 7 - cnt; ++i)
x = x * 2 + 1;
for (int i = 7 - cnt; i < 8; ++i)
x = x * 2;
return buf | x;
}
}
BitManager bitManager = new BitManager();
public BitOutputStream(OutputStream os) {
super(os);
}
public void write(int i) throws IOException {
int x = bitManager.writeOne(i >= 1 ? 1 : 0);
if (x >= 0)
out.write(x);
}
public void write(byte[] arr) throws IOException {
write(arr, 0, arr.length);
}
public void write(byte[] arr, int off, int len) throws IOException {
int clen = 0;
for (int i = 0; i < len; ++i) {
int x = bitManager.writeOne(arr[off + i]);
if (x >= 0)
arr[off + (clen++)] = (byte) x;
}
out.write(arr, off, clen);
}
public void flush() throws IOException {
out.write(bitManager.writeLast());
super.flush();
}
}
==================================
Ayo Belajar Netbeans / Java /Eclipse IDE
Harga Kursus : Rp. 400.000,00 (Paket u Mhs)
Kategori : App Desktop
Durasi : Lama Belajar 15 jam
SILABUSMateri diajarkan al:
Hari1
Mengenal IDE (Form Design, Object Inspector,Unit,Tool Palette),
Pengenalan Tipe Data,Komponent Standard dan Latihan Pemrograman
Membuat Kalkulator via Button, Radio,CheckBox,ListBox
Hari2
Mengenal Struktur Menu, Manipulasi String (String dan regular expression),
Mendesain GUI Interface,
Tipe Data, Operator, iterator + Latihan program
Membuat Aplikasi kalkulator Toko Klontong
Hari3
Teknik Pemrograman,
Implementasi Pernyataan Kondisional.(If-Then-Else,Case of),
Implementasi Konsep Perulangan (Repeat ..Until,While ..Do)
Pembuatan Fungsi dan Procedure
Implementasi Data Array, Latihan Program.
Hari4
Mengakses Database,
Koneksi,CRUD(Create Read Update Delete)
Latihan Aplikasi ( Pendaftaran Siswa Baru)
Hari5
Database Lanjutan,
koneksi 2 tabel,Query,
Bonus Mempaketkan pustaka dalam pemrograman
Latihan Program & Evaluasi.
===============================================
Info lebih silakan Kami di
+ http://www.lp2maray.com
+ http://aplikasi-skripsi.com/
cp:Adi
+085279959498
+021-78889003
+021-92771708
Langganan:
Postingan (Atom)