nd4j 矩阵(matrix)repeat重写 性能150倍提升(干货!)

上篇文章提到的INDArray中的repeat重写,我项目中使用的是40*1*300的矩阵操作,本人亲测性能得到了150倍的提升。

现在给出个直观的算法概念和具体实现代码:


Nd4j的repeat实现算法如图:



本人重写后的实现算法如图:



下面是针对我的项目情况的代码实现, 我的实现只针对被repeat的维度长度为1的情况,如果大家需要对任意长度维度的repeat操作,需要做少许修该。

    /*
    This funciton only support repeat the dimension of which the length of it is one.
    * */
    static INDArray repeat_ndarray(INDArray input, int dimension, int repeats){
        if (1 != input.shape()[dimension]){
            return input;
        }

        int[] permute_dimension = input.shape().clone();
        for (int i = 0; i < permute_dimension.length; ++i)
            permute_dimension[i] = i;
        permute_dimension[0] = dimension;
        permute_dimension[dimension] = 0;
        INDArray input_dup_permute = input.permute(permute_dimension);

        int[] shape_tmp = input.shape();
        shape_tmp[dimension] = shape_tmp[0];
        shape_tmp[0] = repeats;
        INDArray array_tmp = Nd4j.create(shape_tmp);

        for (int i = 0; i < repeats; ++ i){
            array_tmp.putRow(i, input_dup_permute.getRow(0));
        }

        return array_tmp.permute(permute_dimension);
    }


如果对这个算法实现有疑问或者感兴趣, 欢迎提问

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值