手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>程序设计>C/C++>列表

算术编码用c 的实现

来源:互联网 作者:west263.com 时间:2008-02-23
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!

  算术编码在图象数据压缩标准(如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专业版下运行通过,这是我个人第一次用C 写的比较完整的程式,更有些不尽人意的地方,比如变量和函数命名不太专业,以后会注意,慢慢也会好的。呵呵~




文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

热点关注
IDC资讯 虚拟主机 域名注册 托管租用 vps主机 智能建站
网站运营 建站经验 策划盈利 搜索优化 网站推广 免费资源
网站联盟 联盟新闻 联盟介绍 联盟点评 网赚技巧
行业资讯 业界动态 搜索引擎 网络游戏 门户动态 电子商务 广告传媒
网络编程 Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术 Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷 Internet Explorer
网页制作 FrontPages Dreamweaver Javascript css photoshop fireworks Flash
程序设计 Java技术 C/C++ VB delphi
网络知识 网络协议 网络安全 网络管理 组网方案 Cisco技术
操作系统 Win2000 WinXP Win2003 Mac OS Linux FreeBSD
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 价格总览 | 资讯中心 | 友情链接 | 网站地图 | 招贤纳士 | RSS