dedecms织梦内容管理系统    
首页 | java | C/C++ | PHP | 操作系统 | ajax | 脚本编程 | 安全技术 | 本站下载页 | flex | CRM | 专题 | QQ群 | 测试中心 | 会员中心 | 积分规则
  当前位置:主页>C/C++>C/C++技术资料>文章内容
算术编码用c++的实现
来源:bc-cn 作者:不详

  算术编码在图象数据压缩标准(如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
#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;
}

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{
  cin>>code[i];
}
}

void suanshu::coding()
{
int i,j=0;
for(i=0;i  if(code[0]==number[i]) break;
while(j  Low+=chance[j++];
d=chance[j];
High=Low+d;
for(i=1;i  for(j=0;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:"<}

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

  本程序在VC6.0和xp专业版下运行通过,这是我个人第一次用C++写的比较完整的程序,还有些不尽人意的地方,比如变量和函数命名不太专业,以后会注意,慢慢也会好的。呵呵~


上一篇:论C/C++函数间动态内存的传递   下一篇:Command模式应用实践
[收藏] [推荐] [评论(0条)] [返回顶部] [打印本页] [关闭窗口]  
用户名: 新注册) 密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
 §最新评论
  热点文章
·C语言数组排序小结
·Python 与 C++ 程序的简单实例对
·c++ 数组与指针
·C++中的内存管理(new、delete、
·如何用C语言开发DSP嵌入式系统
·如何用C语言开发DSP嵌入式系统
·Linux下C语言编程
·学习arm的话先看哪本书?
·C++初学者应该关心的优秀图书一
·利用C语言小程序来解决大问题
·用C语言写PHP扩展的步骤
·用C语言扩展PHP功能
  相关文章
·论C/C++函数间动态内存的传递
·Command模式应用实践
·C++箴言:只要可能就用const
·泛型<编程>:volatile——多线程
·C++箴言:将强制转型减到最少
·mscorwks.dll在.Net中的地位以及
·C++箴言:理解inline的介入和排
·C++基本数据类型与输入输出
·C++箴言:绝不在构造或析构期调
·C++类对象的复制-拷贝构造函数
·C++箴言:让=返回一个*this的引
·C++类对象的拷贝构造函数
  相关信息
copy right @ 百家拳软件项目研究室 2007 辽ICP备07011763