算術(shù)編碼在圖象數(shù)據(jù)壓縮標(biāo)準(zhǔn)(如jpeg,jbig)中扮演了重要的角色。在算術(shù)編碼中,消息用0到1之間的實(shí)數(shù)進(jìn)行編碼。算術(shù)編碼用到了兩個(gè)基本的參數(shù):符號(hào)的概率和它的編碼間隔。信源符號(hào)的概率決定壓縮編碼的效率,也決定編碼過(guò)程中信源符號(hào)的間隔,而這些間隔包含在0到1之間。編碼過(guò)程中的間隔決定了符號(hào)壓縮后的輸出。
算術(shù)編碼需要輸入的是符號(hào),各個(gè)符號(hào)的概率還有需要編碼的符號(hào)序列,根據(jù)概率可以算出初始編碼間隔,先設(shè)幾個(gè)變量在后面可用:High——當(dāng)前編碼的上限,Low——當(dāng)前編碼的下限,high——中間變量,用來(lái)計(jì)算下一個(gè)編碼符號(hào)的當(dāng)前間隔的上限,low——中間變量,用來(lái)計(jì)算下一個(gè)編碼符號(hào)的當(dāng)前間隔的下限,d——當(dāng)前間隔之間的距離。第1個(gè)編碼符號(hào)的當(dāng)前間隔為其初始的編碼間隔,第i個(gè)編碼符號(hào)的當(dāng)前間隔為第i-1個(gè)編碼后的[Low,High),第i+1個(gè)編碼符號(hào)的當(dāng)前間隔算法如下:high=Low+d*第i+1個(gè)初始編碼符號(hào)對(duì)應(yīng)的上限,low=Low+d*第i+1個(gè)編碼符號(hào)對(duì)應(yīng)的下限,然后High=high,Low=low,d=d*第i個(gè)編碼符號(hào)的概率。
編碼程序如下:
#include
#define M 100
#define N 4
class suanshu
{
int count,length;
char number[N],n;
long double chance[N],c;
char code[M];
long double High,Low,high,low,d;
public:
suanshu()
{High=0;Low=0;}
void get_number();
void get_code();
void coding();
~suanshu(){}
};
void suanshu::get_number()
{
cout<<"please input the number and its chance."< for(int i=0;i {
cin>>n>>c;
number[i]=n;
chance[i]=c;
}
if(i==20)
cout<<"the number is full."< count=i;
}
算術(shù)編碼需要輸入的是符號(hào),各個(gè)符號(hào)的概率還有需要編碼的符號(hào)序列,根據(jù)概率可以算出初始編碼間隔,先設(shè)幾個(gè)變量在后面可用:High——當(dāng)前編碼的上限,Low——當(dāng)前編碼的下限,high——中間變量,用來(lái)計(jì)算下一個(gè)編碼符號(hào)的當(dāng)前間隔的上限,low——中間變量,用來(lái)計(jì)算下一個(gè)編碼符號(hào)的當(dāng)前間隔的下限,d——當(dāng)前間隔之間的距離。第1個(gè)編碼符號(hào)的當(dāng)前間隔為其初始的編碼間隔,第i個(gè)編碼符號(hào)的當(dāng)前間隔為第i-1個(gè)編碼后的[Low,High),第i+1個(gè)編碼符號(hào)的當(dāng)前間隔算法如下:high=Low+d*第i+1個(gè)初始編碼符號(hào)對(duì)應(yīng)的上限,low=Low+d*第i+1個(gè)編碼符號(hào)對(duì)應(yīng)的下限,然后High=high,Low=low,d=d*第i個(gè)編碼符號(hào)的概率。
編碼程序如下:
#include
#define M 100
#define N 4
class suanshu
{
int count,length;
char number[N],n;
long double chance[N],c;
char code[M];
long double High,Low,high,low,d;
public:
suanshu()
{High=0;Low=0;}
void get_number();
void get_code();
void coding();
~suanshu(){}
};
void suanshu::get_number()
{
cout<<"please input the number and its chance."<
cin>>n>>c;
number[i]=n;
chance[i]=c;
}
if(i==20)
cout<<"the number is full."<
}

