ND4J/定制操作

package org.nd4j.examples;

import org.nd4j.linalg.api.ndarray.INDArray;
import org.nd4j.linalg.api.ops.CustomOp;
import org.nd4j.linalg.api.ops.DynamicCustomOp;
import org.nd4j.linalg.factory.Nd4j;

/**
 *
 * 定制操作是那些在C++ (libnd4j)中定义的,它们还没有被映射为具有Java便利方法,如1.0.0-beta版本。
 * 最终,所有的操作都将被映射成具有Java便利性的方法。同时,可以使用下面显示的“DynamicCustomOp”方法访问它们
 *
 */
public class CustomOpsExamples {


    public static void main(String[] args){

        //第一个示例:反转操作。此操作沿指定维度反转值。
        //c++代码:https://github.com/deeplearning4j/libnd4j/blob/master/include/ops/declarable/generic/transforms/reverse.cpp#L15
        
        //生成线性间隔向量,如下生成1-50,步长大小为50的标量 
        INDArray input = Nd4j.linspace(1, 50, 50)
                        //变形为5行10列的二维数组
                        .reshape(5,10);
        
        //按输入形状创建一个输出数组
        INDArray output = Nd4j.create(input.shape());
        
        //反转操作
        CustomOp op = DynamicCustomOp.builder("reverse")
            .addInputs(input)
            .addOutputs(output)
            //沿维度0(行)进行反转
            .addIntegerArguments(0)
            .build();
        
        //执行操作
        Nd4j.getExecutioner().exec(op);

        System.out.println("反转前");
        System.out.println(input);
        System.out.println();
        System.out.println("反转后");
        System.out.println(output);

       

        
        //另一个例子:网格
        //c++ 代码: https://github.com/deeplearning4j/libnd4j/blob/master/include/ops/declarable/generic/broadcastable/meshgrid.cpp
        //创建[[         0,    0.3333,    0.6667,    1.0000]],即从0开始到1,生成4个数字,每个数字值=((1-0)/(4-1))n   n=0,1,2,3
        INDArray input1 = Nd4j.linspace(0, 1, 4);
        //创建[[         0,    0.2500,    0.5000,    0.7500,    1.0000]],即从0开始到1,生成5个数字,每个数字值=((1-0)/(5-1))n  n=0,1,2,3,4
        INDArray input2 = Nd4j.linspace(0, 1, 5);
        
        //创建5行4列的二维数组
        INDArray output1 = Nd4j.create(5,4);
        //创建5行4列的二维数组
        INDArray output2 = Nd4j.create(5,4);

        //meshgrid详情参考https://blog.csdn.net/u013346007/article/details/54581253
        op = DynamicCustomOp.builder("meshgrid")
            .addInputs(input1, input2)
            .addOutputs(output1,output2)
            .build();
        
        Nd4j.getExecutioner().exec(op);
        
        System.out.println("meshgrid前");
        System.out.println(input1 + "\n\n" + input2);
        
        System.out.println("meshgrid后");
        //output1=input1列数*input2列数=4*5的矩阵,即用input1垂直堆叠n=input2列数 次
        //output2=input2转置后水平堆叠n=input1列数 次
        System.out.println(output1 + "\n\n"+output2);

    }

}

运行结果

反转前
[[    1.0000,    2.0000,    3.0000,    4.0000,    5.0000,    6.0000,    7.0000,    8.0000,    9.0000,   10.0000], 
 [   11.0000,   12.0000,   13.0000,   14.0000,   15.0000,   16.0000,   17.0000,   18.0000,   19.0000,   20.0000], 
 [   21.0000,   22.0000,   23.0000,   24.0000,   25.0000,   26.0000,   27.0000,   28.0000,   29.0000,   30.0000], 
 [   31.0000,   32.0000,   33.0000,   34.0000,   35.0000,   36.0000,   37.0000,   38.0000,   39.0000,   40.0000], 
 [   41.0000,   42.0000,   43.0000,   44.0000,   45.0000,   46.0000,   47.0000,   48.0000,   49.0000,   50.0000]]

反转后
[[   10.0000,    9.0000,    8.0000,    7.0000,    6.0000,    5.0000,    4.0000,    3.0000,    2.0000,    1.0000], 
 [   20.0000,   19.0000,   18.0000,   17.0000,   16.0000,   15.0000,   14.0000,   13.0000,   12.0000,   11.0000], 
 [   30.0000,   29.0000,   28.0000,   27.0000,   26.0000,   25.0000,   24.0000,   23.0000,   22.0000,   21.0000], 
 [   40.0000,   39.0000,   38.0000,   37.0000,   36.0000,   35.0000,   34.0000,   33.0000,   32.0000,   31.0000], 
 [   50.0000,   49.0000,   48.0000,   47.0000,   46.0000,   45.0000,   44.0000,   43.0000,   42.0000,   41.0000]]
meshgrid前
[[         0,    0.3333,    0.6667,    1.0000]]

[[         0,    0.2500,    0.5000,    0.7500,    1.0000]]
meshgrid后
[[         0,    0.3333,    0.6667,    1.0000], 
 [         0,    0.3333,    0.6667,    1.0000], 
 [         0,    0.3333,    0.6667,    1.0000], 
 [         0,    0.3333,    0.6667,    1.0000], 
 [         0,    0.3333,    0.6667,    1.0000]]

[[         0,         0,         0,         0], 
 [    0.2500,    0.2500,    0.2500,    0.2500], 
 [    0.5000,    0.5000,    0.5000,    0.5000], 
 [    0.7500,    0.7500,    0.7500,    0.7500], 
 [    1.0000,    1.0000,    1.0000,    1.0000]]


翻译:风一样的男子

image
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,281评论 0 2
  • 1. 基础知识 1.1、 基本概念、 功能 冯诺伊曼体系结构1、计算机处理的数据和指令一律用二进制数表示2、顺序执...
    yunpiao阅读 5,220评论 1 22
  • 1)时间片轮番调度法 假设系统中有5个任务,T1,T2,T3,T4,T5,这个时候,操作系统为每一个任务分配时间,...
    随波逐流007阅读 678评论 0 1
  • 又是新的一天,还差两个月,我就恍恍惚惚过了20年,世界每天都在变化,但是这变化离我那么近又那么远。 每天早上起床打...
    阿踔阅读 202评论 0 0
  • 今天是大年初二,是回门的日子。 每年的今天爸爸妈妈都会准备一大桌子菜,看着我们大家吃的开心,老人家会...
    陈QX阅读 198评论 0 0