Java双精度数组丢失精度

Java双精度数组丢失精度,java,precision,nd4j,Java,Precision,Nd4j,我无法将double转换为Nd4j.INDArray而不丢失精度 double[] weight = new double[]{-0.13404223866376802,-0.11294084872465669,0.11232944517596409,-0.01687720880184701,0.13288394029423414,-0.06916641552096867,0.1518882606786481}; INDArray array = Nd4j.create(weight, new

我无法将double转换为Nd4j.INDArray而不丢失精度

double[] weight = new double[]{-0.13404223866376802,-0.11294084872465669,0.11232944517596409,-0.01687720880184701,0.13288394029423414,-0.06916641552096867,0.1518882606786481};
INDArray array = Nd4j.create(weight, new int[]{1, 7});
System.out.println(array);
输出是

[-0.13,  -0.11,  0.11,  -0.02,  0.13,  -0.07,  0.15]
所需的输出应为

[-0.13404223866376802,-0.11294084872465669,0.11232944517596409,-0.01687720880184701,0.13288394029423414,-0.06916641552096867,0.1518882606786481]
如何进行全精度转换?

使用

int precision = 7;
String printed = new NDArrayStrings(precision).format(this);
System.out.println(printed);

无论你想精确到什么程度
NDArrayStrings
org.nd4j.linalg.string
包中。

我也有同样的问题,最新的0.9.x nd4j:

    new NDArrayStrings(15).format(Nd4j.create(new double[]{0.4,0.3}))
    [0.400000005960464,  0.300000011920929]

    Nd4j.create(new double[]{0.4}).getDouble(0)
    0.4000000059604645
编辑:现在我明白了原因,Nd4j只初始化为“浮动”数字。。。 所以只有7位是正确的,最好使用“getFloat”


在创建INDArray之前使用此行:

Nd4j.setDefaultDataTypes(org.nd4j.linalg.api.buffer.DataType.DOUBLE, org.nd4j.linalg.api.buffer.DataType.FLOAT16);
这会将默认精度Nd4j更改为Double和Float16

您可以在类中放置一个静态调用,这样您只需调用一次就可以忘记它

    class Foo {
       static {
          putTheCallHere();
       }
    }

@LeoAso所说的背后的要点是,INDArray实际上并没有截断您的数据——它存储并操作整个double。这正是它的toString()方法所做的。他的答案可以让你以你想要的精度格式化INDARY。@Theaarchitect这很有趣。我刚刚使用了INDArray的
到doublematrix
并检查了这个。我得到的结果似乎不同于最初用于创建INDArray的double[][],从第7位小数开始。数据似乎被截断为一个
浮动缓冲区
,当转换回
双[][]
时,随机垃圾被添加到末尾。
    class Foo {
       static {
          putTheCallHere();
       }
    }