IDCT变换(JAVA)

IDCT变换(JAVA)主要代码:


public static double[][] inverseDCTconvertion(double[][] Fp) {  // IDCT
      int sizeX = Fp.length;
      int sizeY = Fp[0].length;
      double[][] fp = new double[sizeX][sizeY];
      int u, v, x, y;           
      for(int xx = 0; xx < sizeX; xx += 8){
           for(int yy = 0; yy < sizeY; yy += 8){ 
                for(int x1 = xx; x1 < xx + 8; x1++){
                   x = x1 - xx;
                   for(int y1 = yy; y1 < yy + 8; y1++){
                       y = y1 - yy;
                       double subSum = 0.0;
                       for(int u1 = xx; u1 < xx + 8; u1++){
                           u = u1 - xx;
                           for(int v1 = yy; v1 < yy + 8; v1++){
                               v = v1 - yy;
                                subSum += Cfunc(u) * Cfunc(v) * Fp[u1][v1] * Math.cos(((2.0*x + 1.0)*u*Math.PI)/(16.0)) * Math.cos(((2.0*y + 1.0)*v*Math.PI)/(16.0));
                           }
                       }
                       fp[x1][y1] = ((1.0 / 4.0) * subSum);
                 }
                }
           }
     }
      return fp;
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值