java版本phash算法优化

phash

本文的参考实现是:https://blog.csdn.net/sunhuaqiang1/article/details/70232679

原有代码中有一个四重for循环:

private double[][] applyDCT(double[][] f) {
        int N = size;

        double[][] F = new double[N][N];
        for (int u=0;u<N;u++) {
            for (int v=0;v<N;v++) {
                double sum = 0.0;
                for (int i=0;i<N;i++) {
                    for (int j=0;j<N;j++) {
                        sum+=Math.cos(((2*i+1)/(2.0*N))*u*Math.PI)*Math.cos(((2*j+1)/(2.0*N))*v*Math.PI)*(f[i][j]);
                    }
                }
                sum*=((c[u]*c[v])/4.0);
                F[u][v] = sum;
            }
        }
        return F;
    }

本文中对其做了一下改进,采用CPU对于矩阵乘法的优化进行加速,代码如下,效果调高20%左右。

  private SimpleMatrix getMatrixA(int NN){
        //获取备用矩阵 A
        SimpleMatrix a_array = new SimpleMatrix(NN, NN);
        for(int i = 0; i< NN; i++){
            for(int j = 0; j < NN; j++){
                a_array.set(i,j,Math.cos(((2*j+1)/(2.0*NN))*i*Math.PI));
            }
        }
        return a_array;
    }

    private double[][] applyDCT_1(double[][] f) {
        int N = size;
        SimpleMatrix f_array = new SimpleMatrix(f);
        SimpleMatrix a_array = getMatrixA(N);
        SimpleMatrix a_array_T = a_array.transpose();

        double[][] F = new double[N][N];
        for (int u=0;u<N;u++) {
            for (int v = 0; v < N; v++) {
                SimpleMatrix a_row_u = a_array.rows(u,u+1);
                SimpleMatrix a_col_v = a_array_T.cols(v,v+1);
                SimpleMatrix mult_res = a_col_v.mult(a_row_u);
                double sum = mult_res.elementMult(f_array).elementSum();
                sum*=((c[u]*c[v])/4.0);
                F[v][u] = sum;//转置关系
            }
        }

        return F;
    }

Java是一种广泛使用的面向对象的编程语言,由Sun Microsystems公司于1995年5月正式发布。它的设计目标是“一次编写,到处运行(Write Once, Run Anywhere)”,这意味着开发者可以使用Java编写应用程序,并在支持Java的任何平台上无需重新编译即可运行,这得益于其独特的跨平台性,通过Java虚拟机(JVM)实现不同操作系统上的兼容。 Java的特点包括: 面向对象:Java全面支持面向对象的特性,如封装、继承和多态,使得代码更易于维护和扩展。 安全:Java提供了丰富的安全特性,如禁止指针运算、自动内存管理和异常处理机制,以减少程序错误和恶意攻击的可能性。 可移植性:Java字节码可以在所有安装了JVM的设备上执行,从服务器到嵌入式系统,再到移动设备和桌面应用。 健壮性与高性能:Java通过垃圾回收机制确保内存的有效管理,同时也能通过JIT编译器优化来提升运行时性能。 标准库丰富:Java拥有庞大的类库,如Java SE(Java Standard Edition)包含基础API,用于开发通用应用程序;Java EE(Java Enterprise Edition)提供企业级服务,如Web服务、EJB等;而Java ME(Java Micro Edition)则针对小型设备和嵌入式系统。 社区活跃:Java有着全球范围内庞大的开发者社区和开源项目,持续推动技术进步和创新。 多线程支持:Java内建对多线程编程的支持,使并发编程变得更加简单直接。 动态性:Java可以通过反射、注解等机制实现在运行时动态加载类和修改行为,增加了程序的灵活性。 综上所述,Java凭借其强大的特性和广泛的适用范围,在企业级应用、互联网服务、移动开发等领域均扮演着举足轻重的角色,是现代软件开发不可或缺的重要工具之一。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

花咪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值