久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3095|回復: 0
打印 上一主題 下一主題
收起左側

(信息論編碼)Huffman編碼

[復制鏈接]
跳轉到指定樓層
樓主
ID:105323 發表于 2016-2-23 01:13 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. #include <stdio.h>
  2. #include <math.h>

  3. /*huffman tree 結構定義*/
  4. typedef struct
  5. {
  6. float weight;
  7.     int   flag;
  8.   int   parent;
  9.   int   lchild;
  10.   int   rchild;
  11. }huffnode;



  12. void main(void)
  13. {
  14.   huffnode huff_node[50];         /*為huffman tree 定義了50個結點*/
  15.   int huff_code[50][10],cd,d[10],a[50];  
  16.   int i,j,x1,x2,n,c,p;
  17.   float m1,m2,temp,hx=0,L=0,sum=0;/*hx為信源熵,L為平均碼長*/
  18.   printf("the number of input information source:\nN=  ");      /*輸入信源符號的個數*/
  19.   scanf("%d",&n);
  20.   for(i=0;i<=2*n-1;i++)   /*初始化huffman樹各個結點的值*/
  21.   {
  22.    huff_node[i].weight=0;
  23.     huff_node[i].parent=0;
  24.     huff_node[i].flag=0;
  25.     huff_node[i].lchild=-1;
  26.     huff_node[i].rchild=-1;
  27.    }
  28.    printf("Please input probability distribution :\n");
  29.    for(i=0;i<n;i++)    /*輸入信源輸入分布*/
  30.    {
  31.     printf("p[%d]=  ",i+1);
  32.     scanf("%f",&temp);
  33.     sum+=temp;
  34.     huff_node[i].weight=temp;
  35.     hx=hx-temp*3.332*log10(temp);  /*求信源的熵H(X)*/
  36.    }

  37.    if(fabs((sum-1))>0.00001) /*判斷信源輸入分布是否正確*/
  38.    {
  39.     printf("Error!");
  40.     exit(-1);
  41.    }

  42. /*構建霍夫曼樹(參考數據結構書)*/
  43.   for(i=0;i<n-1;i++)
  44.   {
  45.     m1=m2=1.1;
  46.     x1=x2=0;
  47.     for(j=0;j<n+i;j++)
  48.      {
  49.       if(huff_node[j].weight<m1&&huff_node[j].flag==0)
  50.       {
  51.        m2=m1;
  52.        x2=x1;
  53.        m1=huff_node[j].weight;
  54.        x1=j;
  55.       }
  56.       else
  57.       if(huff_node[j].weight<m2&&huff_node[j].flag==0)
  58.       {
  59.        m2=huff_node[j].weight;
  60.        x2=j;
  61.       }
  62.    
  63.     }
  64.          huff_node[x1].parent=n+i;
  65.   huff_node[x2].parent=n+i;         /*將找出的兩棵子樹合并為一棵子樹*/
  66.   huff_node[x1].flag=1;
  67.   huff_node[x2].flag=1;
  68.   huff_node[n+i].weight=huff_node[x1].weight+huff_node[x2].weight;
  69.   
  70.   if(huff_node[x1].weight==huff_node[x2].weight)       /*如果值相等,則將其置于最上面*/
  71.    {   
  72.     huff_node[n+i].lchild=x1;
  73.     huff_node[n+i].rchild=x2;
  74.    }
  75.    else
  76.    {
  77.     huff_node[n+i].lchild=x2;
  78.     huff_node[n+i].rchild=x1;
  79.    }
  80. }


  81. /*求信源符號的huffman編碼*/
  82.   for(i=0;i<n;i++)
  83.   {
  84.    cd=n;      
  85.    c=i;
  86.    p=huff_node[c].parent;
  87.    while(p!=0)      /*為信源si編碼*/
  88.      {
  89.          if(huff_node[p].lchild==c)    /*左孩子編碼為0*/
  90.      d[cd]=0;
  91.         else  
  92.      d[cd]=1;    /*左孩子編碼為1*/
  93.      cd=cd-1;
  94.      c=p;
  95.      p=huff_node[p].parent;
  96.      }
  97.     cd++;     
  98.   for(j=cd;j<=n;j++)   /*存儲信源si的huffman編碼*/
  99.   huff_code[i][j]=d[j];  
  100.   a[i]=cd;   
  101.   }
  102.   
  103. /*輸出信源符號的huffman編碼、信源熵和平均碼長*/
  104.   printf("\ninformaition source\thuffmancode\n");
  105.   for(i=0;i<n;i++)
  106.   {
  107.     printf("p[%d]=%2.3f\t\t",i+1,huff_node[i].weight);/*輸出信源分布*/
  108.     for(j=a[i];j<=n;j++)
  109.     printf("%d",huff_code[i][j]);              /*輸出huffman編碼*/
  110.     /*求平均碼長*/
  111.     L=L+(n+1-a[i])*huff_node[i].weight;                /*(n-cd+1)表示的是信源符號si的碼長*/            
  112.     printf("\n");
  113.   }
  114.   printf("\nH(X)=%.2f bit/Symbol\n",hx);/*輸出信源熵*/
  115.   printf("The average length of code is:\tL=%.2f\n",L);/*輸出平均碼長*/
  116.   printf("The rate is:\tR=%.3f",hx/L);           /*輸出編碼效率*/
  117. }
  118.   
復制代碼


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: www.日韩| 九九热在线观看视频 | 国产伦一区二区三区视频 | 在线观看国产 | 国产亚洲精品久久久久久牛牛 | 国产91久久久久蜜臀青青天草二 | h视频在线观看免费 | 日韩在线观看 | 日韩欧美一区二区三区免费看 | 久久com| 欧美黄色片| 福利精品| 亚洲成人午夜电影 | 亚洲精品久久久9婷婷中文字幕 | 免费九九视频 | 波多野结衣中文视频 | 国产精品久久久久久久久久久久 | aaa级片 | 精品日韩一区 | 国产精品久久久久久久久久免费看 | 欧美国产激情 | 一级a爱片久久毛片 | 亚洲男人的天堂网站 | 久久精品国产一区二区电影 | 一区二区三区四区av | 日韩成人在线视频 | 亚洲激情在线观看 | 午夜视频在线免费观看 | 亚洲第一网站 | 超碰人人人 | 中文字幕在线一区 | 中文字幕精品一区 | 一区二区三区在线免费观看 | 精品久久久久久久 | 激情五月婷婷综合 | 精品在线免费观看视频 | 免费看的黄网站 | 草久久久 | 91麻豆精品国产91久久久更新资源速度超快 | 曰批视频在线观看 | av一级毛片|