算术编码用c++的实现

        算术编码在图象数据压缩标准(如jpeg,jbig)中扮演了重要的角色。在算术编码中,消息用0到1之间的实数进行编码。算术编码用到了两个基本的参数:符号的概率和它的编码间隔。信源符号的概率决定压缩编码的效率,也决定编码过程中信源符号的间隔,而这些间隔包含在0到1之间。编码过程中的间隔决定了符号压缩后的输出。 

       算术编码需要输入的是符号,各个符号的概率还有需要编码的符号序列,根据概率可以算出初始编码间隔,先设几个变量在后面可用:High——当前编码的上限,Low——当前编码的下限,high——中间变量,用来计算下一个编码符号的当前间隔的上限,low——中间变量,用来计算下一个编码符号的当前间隔的下限,d——当前间隔之间的距离。第1个编码符号的当前间隔为其初始的编码间隔,第i个编码符号的当前间隔为第i-1个编码后的[Low,High),第i+1个编码符号的当前间隔算法如下:high=Low+d*第i+1个初始编码符号对应的上限,low=Low+d*第i+1个编码符号对应的下限,然后High=high,Low=low,d=d*第i个编码符号的概率。

编码程序如下:

#include <iostream.h>
#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."<<endl;
 for(int i=0;i<N;i++)
 {
  cin>>n>>c;
  number[i]=n;
  chance[i]=c;
 }
 if(i==20)
  cout<<"the number is full."<<endl;
 count=i;
}

void suanshu::get_code()
{
 cout<<"please input the code's length:";
 cin>>length;
 while(length>=M)
 {
  cout<<"the length is too larger,please input a smaller one.";
  cin>>length;
 }
 for(int i=0;i<length;i++)
 {
  cin>>code[i];
 }
}

void suanshu::coding()
{
 int i,j=0;
 for(i=0;i<count;i++)
  if(code[0]==number[i]) break;
 while(j<i)
  Low+=chance[j++];
 d=chance[j];
 High=Low+d;
 for(i=1;i<length;i++)
  for(j=0;j<count;j++)
  {
   if(code[i]==number[j])
   {
    if(j==0)
    {
     low=Low;
     high=Low+chance[j]*d;
     High=high;
     d*=chance[j];
    }
    else
    {
     float chance_l=0.0;
     for(int k=0;k<=j-1;k++)
      chance_l+=chance[k];
     low=Low+d*chance_l;
     high=Low+d*(chance_l+chance[j]);
     Low=low;
     High=high;
     d*=chance[j];
    }
   }
   else continue;
  }
 cout<<"the result is:"<<Low<<endl;
}

int main()
{
 suanshu a;
 a.get_number();
 a.get_code();
 a.coding();
 return 0;
}

本程序在VC6.0和xp专业版下运行通过。

 

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值