You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@systemml.apache.org by mb...@apache.org on 2017/11/05 01:56:29 UTC
[2/3] systemml git commit: [SYSTEMML-1986] New nary cbind/rbind
(compiler/runtime for cp/spark)
http://git-wip-us.apache.org/repos/asf/systemml/blob/c0b6ef5c/src/test/java/org/apache/sysml/test/integration/functions/append/NaryCBindTest.java
----------------------------------------------------------------------
diff --git a/src/test/java/org/apache/sysml/test/integration/functions/append/NaryCBindTest.java b/src/test/java/org/apache/sysml/test/integration/functions/append/NaryCBindTest.java
new file mode 100644
index 0000000..13ba799
--- /dev/null
+++ b/src/test/java/org/apache/sysml/test/integration/functions/append/NaryCBindTest.java
@@ -0,0 +1,192 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+package org.apache.sysml.test.integration.functions.append;
+
+import java.util.HashMap;
+
+import org.junit.Assert;
+import org.junit.Test;
+
+import org.apache.sysml.api.DMLScript;
+import org.apache.sysml.api.DMLScript.RUNTIME_PLATFORM;
+import org.apache.sysml.lops.LopProperties.ExecType;
+import org.apache.sysml.runtime.matrix.data.MatrixValue.CellIndex;
+import org.apache.sysml.test.integration.AutomatedTestBase;
+import org.apache.sysml.test.integration.TestConfiguration;
+import org.apache.sysml.test.utils.TestUtils;
+
+public class NaryCBindTest extends AutomatedTestBase
+{
+ private final static String TEST_NAME = "NaryCbind";
+ private final static String TEST_DIR = "functions/append/";
+ private final static String TEST_CLASS_DIR = TEST_DIR + NaryCBindTest.class.getSimpleName() + "/";
+
+ private final static double epsilon=0.0000000001;
+
+ private final static int rows = 1101;
+ private final static int cols1 = 101;
+ private final static int cols2 = 79;
+ private final static int cols3 = 123;
+
+ private final static double sparsity1 = 0.7;
+ private final static double sparsity2 = 0.07;
+
+ @Override
+ public void setUp() {
+ TestUtils.clearAssertionInformation();
+ addTestConfiguration(TEST_NAME, new TestConfiguration(TEST_CLASS_DIR, TEST_NAME, new String[] {"R"}));
+ }
+
+ @Test
+ public void testNaryCbindDenseDenseDenseCP() {
+ runCbindTest(false, false, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindDenseDenseSparseCP() {
+ runCbindTest(false, false, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindDenseSparseDenseCP() {
+ runCbindTest(false, true, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindDenseSparseSparseCP() {
+ runCbindTest(false, true, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindSparseDenseDenseCP() {
+ runCbindTest(true, false, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindSparseDenseSparseCP() {
+ runCbindTest(true, false, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindSparseSparseDenseCP() {
+ runCbindTest(true, true, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindSparseSparseSparseCP() {
+ runCbindTest(true, true, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryCbindDenseDenseDenseSP() {
+ runCbindTest(false, false, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryCbindDenseDenseSparseSP() {
+ runCbindTest(false, false, true, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryCbindDenseSparseDenseSP() {
+ runCbindTest(false, true, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryCbindDenseSparseSparseSP() {
+ runCbindTest(false, true, true, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryCbindSparseDenseDenseSP() {
+ runCbindTest(true, false, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryCbindSparseDenseSparseSP() {
+ runCbindTest(true, false, true, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryCbindSparseSparseDenseSP() {
+ runCbindTest(true, true, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryCbindSparseSparseSparseSP() {
+ runCbindTest(true, true, true, ExecType.CP);
+ }
+
+
+ public void runCbindTest(boolean sparse1, boolean sparse2, boolean sparse3, ExecType et)
+ {
+ RUNTIME_PLATFORM platformOld = rtplatform;
+ switch( et ) {
+ case MR: rtplatform = RUNTIME_PLATFORM.HADOOP; break;
+ case SPARK: rtplatform = RUNTIME_PLATFORM.SPARK; break;
+ default: rtplatform = RUNTIME_PLATFORM.HYBRID_SPARK; break;
+ }
+
+ boolean sparkConfigOld = DMLScript.USE_LOCAL_SPARK_CONFIG;
+ if( rtplatform == RUNTIME_PLATFORM.SPARK || rtplatform == RUNTIME_PLATFORM.HYBRID_SPARK )
+ DMLScript.USE_LOCAL_SPARK_CONFIG = true;
+
+ try
+ {
+ TestConfiguration config = getAndLoadTestConfiguration(TEST_NAME);
+ loadTestConfiguration(config);
+
+ String RI_HOME = SCRIPT_DIR + TEST_DIR;
+ fullDMLScriptName = RI_HOME + TEST_NAME + ".dml";
+ programArgs = new String[]{"-stats", "-args", input("A"),
+ input("B"), input("C"), output("R") };
+ fullRScriptName = RI_HOME + TEST_NAME + ".R";
+ rCmd = "Rscript" + " " + fullRScriptName + " " +
+ inputDir() + " "+ expectedDir();
+
+ //generate input data
+ double sp1 = sparse1 ? sparsity2 : sparsity1;
+ double sp2 = sparse2 ? sparsity2 : sparsity1;
+ double sp3 = sparse3 ? sparsity2 : sparsity1;
+ double[][] A = getRandomMatrix(rows, cols1, -1, 1, sp1, 711);
+ double[][] B = getRandomMatrix(rows, cols2, -1, 1, sp2, 722);
+ double[][] C = getRandomMatrix(rows, cols3, -1, 1, sp3, 733);
+ writeInputMatrixWithMTD("A", A, true);
+ writeInputMatrixWithMTD("B", B, true);
+ writeInputMatrixWithMTD("C", C, true);
+
+ //run tests
+ runTest(true, false, null, -1);
+ runRScript(true);
+
+ //compare result data
+ HashMap<CellIndex, Double> dmlfile = readDMLMatrixFromHDFS("R");
+ HashMap<CellIndex, Double> rfile = readRMatrixFromFS("R");
+ TestUtils.compareMatrices(dmlfile, rfile, epsilon, "DML", "R");
+
+ //check for spark instructions
+ Assert.assertTrue(heavyHittersContainsSubString("sp_cbind")==(et==ExecType.SPARK));
+ }
+ finally {
+ rtplatform = platformOld;
+ DMLScript.USE_LOCAL_SPARK_CONFIG = sparkConfigOld;
+ }
+ }
+}
http://git-wip-us.apache.org/repos/asf/systemml/blob/c0b6ef5c/src/test/java/org/apache/sysml/test/integration/functions/append/NaryRBindTest.java
----------------------------------------------------------------------
diff --git a/src/test/java/org/apache/sysml/test/integration/functions/append/NaryRBindTest.java b/src/test/java/org/apache/sysml/test/integration/functions/append/NaryRBindTest.java
new file mode 100644
index 0000000..f820bf5
--- /dev/null
+++ b/src/test/java/org/apache/sysml/test/integration/functions/append/NaryRBindTest.java
@@ -0,0 +1,192 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+package org.apache.sysml.test.integration.functions.append;
+
+import java.util.HashMap;
+
+import org.junit.Assert;
+import org.junit.Test;
+
+import org.apache.sysml.api.DMLScript;
+import org.apache.sysml.api.DMLScript.RUNTIME_PLATFORM;
+import org.apache.sysml.lops.LopProperties.ExecType;
+import org.apache.sysml.runtime.matrix.data.MatrixValue.CellIndex;
+import org.apache.sysml.test.integration.AutomatedTestBase;
+import org.apache.sysml.test.integration.TestConfiguration;
+import org.apache.sysml.test.utils.TestUtils;
+
+public class NaryRBindTest extends AutomatedTestBase
+{
+ private final static String TEST_NAME = "NaryRbind";
+ private final static String TEST_DIR = "functions/append/";
+ private final static String TEST_CLASS_DIR = TEST_DIR + NaryRBindTest.class.getSimpleName() + "/";
+
+ private final static double epsilon=0.0000000001;
+
+ private final static int cols = 101;
+ private final static int rows1 = 1101;
+ private final static int rows2 = 1179;
+ private final static int rows3 = 1123;
+
+ private final static double sparsity1 = 0.7;
+ private final static double sparsity2 = 0.07;
+
+ @Override
+ public void setUp() {
+ TestUtils.clearAssertionInformation();
+ addTestConfiguration(TEST_NAME, new TestConfiguration(TEST_CLASS_DIR, TEST_NAME, new String[] {"R"}));
+ }
+
+ @Test
+ public void testNaryRbindDenseDenseDenseCP() {
+ runRbindTest(false, false, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindDenseDenseSparseCP() {
+ runRbindTest(false, false, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindDenseSparseDenseCP() {
+ runRbindTest(false, true, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindDenseSparseSparseCP() {
+ runRbindTest(false, true, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindSparseDenseDenseCP() {
+ runRbindTest(true, false, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindSparseDenseSparseCP() {
+ runRbindTest(true, false, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindSparseSparseDenseCP() {
+ runRbindTest(true, true, false, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindSparseSparseSparseCP() {
+ runRbindTest(true, true, true, ExecType.CP);
+ }
+
+ @Test
+ public void testNaryRbindDenseDenseDenseSP() {
+ runRbindTest(false, false, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryRbindDenseDenseSparseSP() {
+ runRbindTest(false, false, true, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryRbindDenseSparseDenseSP() {
+ runRbindTest(false, true, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryRbindDenseSparseSparseSP() {
+ runRbindTest(false, true, true, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryRbindSparseDenseDenseSP() {
+ runRbindTest(true, false, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryRbindSparseDenseSparseSP() {
+ runRbindTest(true, false, true, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryRbindSparseSparseDenseSP() {
+ runRbindTest(true, true, false, ExecType.SPARK);
+ }
+
+ @Test
+ public void testNaryRbindSparseSparseSparseSP() {
+ runRbindTest(true, true, true, ExecType.CP);
+ }
+
+
+ public void runRbindTest(boolean sparse1, boolean sparse2, boolean sparse3, ExecType et)
+ {
+ RUNTIME_PLATFORM platformOld = rtplatform;
+ switch( et ) {
+ case MR: rtplatform = RUNTIME_PLATFORM.HADOOP; break;
+ case SPARK: rtplatform = RUNTIME_PLATFORM.SPARK; break;
+ default: rtplatform = RUNTIME_PLATFORM.HYBRID_SPARK; break;
+ }
+
+ boolean sparkConfigOld = DMLScript.USE_LOCAL_SPARK_CONFIG;
+ if( rtplatform == RUNTIME_PLATFORM.SPARK || rtplatform == RUNTIME_PLATFORM.HYBRID_SPARK )
+ DMLScript.USE_LOCAL_SPARK_CONFIG = true;
+
+ try
+ {
+ TestConfiguration config = getAndLoadTestConfiguration(TEST_NAME);
+ loadTestConfiguration(config);
+
+ String RI_HOME = SCRIPT_DIR + TEST_DIR;
+ fullDMLScriptName = RI_HOME + TEST_NAME + ".dml";
+ programArgs = new String[]{"-stats", "-args", input("A"),
+ input("B"), input("C"), output("R") };
+ fullRScriptName = RI_HOME + TEST_NAME + ".R";
+ rCmd = "Rscript" + " " + fullRScriptName + " " +
+ inputDir() + " "+ expectedDir();
+
+ //generate input data
+ double sp1 = sparse1 ? sparsity2 : sparsity1;
+ double sp2 = sparse2 ? sparsity2 : sparsity1;
+ double sp3 = sparse3 ? sparsity2 : sparsity1;
+ double[][] A = getRandomMatrix(rows1, cols, -1, 1, sp1, 711);
+ double[][] B = getRandomMatrix(rows2, cols, -1, 1, sp2, 722);
+ double[][] C = getRandomMatrix(rows3, cols, -1, 1, sp3, 733);
+ writeInputMatrixWithMTD("A", A, true);
+ writeInputMatrixWithMTD("B", B, true);
+ writeInputMatrixWithMTD("C", C, true);
+
+ //run tests
+ runTest(true, false, null, -1);
+ runRScript(true);
+
+ //compare result data
+ HashMap<CellIndex, Double> dmlfile = readDMLMatrixFromHDFS("R");
+ HashMap<CellIndex, Double> rfile = readRMatrixFromFS("R");
+ TestUtils.compareMatrices(dmlfile, rfile, epsilon, "DML", "R");
+
+ //check for spark instructions
+ Assert.assertTrue(heavyHittersContainsSubString("sp_rbind")==(et==ExecType.SPARK));
+ }
+ finally {
+ rtplatform = platformOld;
+ DMLScript.USE_LOCAL_SPARK_CONFIG = sparkConfigOld;
+ }
+ }
+}
http://git-wip-us.apache.org/repos/asf/systemml/blob/c0b6ef5c/src/test/scripts/functions/append/NaryCbind.R
----------------------------------------------------------------------
diff --git a/src/test/scripts/functions/append/NaryCbind.R b/src/test/scripts/functions/append/NaryCbind.R
new file mode 100644
index 0000000..4cc8d89
--- /dev/null
+++ b/src/test/scripts/functions/append/NaryCbind.R
@@ -0,0 +1,32 @@
+#-------------------------------------------------------------
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+#-------------------------------------------------------------
+
+args <- commandArgs(TRUE)
+options(digits=22)
+library("Matrix")
+
+A = as.matrix(readMM(paste(args[1], "A.mtx", sep="")))
+B = as.matrix(readMM(paste(args[1], "B.mtx", sep="")))
+C = as.matrix(readMM(paste(args[1], "C.mtx", sep="")))
+
+R = cbind(cbind(A, B), C);
+
+writeMM(as(R,"CsparseMatrix"), paste(args[2], "R", sep=""))
http://git-wip-us.apache.org/repos/asf/systemml/blob/c0b6ef5c/src/test/scripts/functions/append/NaryCbind.dml
----------------------------------------------------------------------
diff --git a/src/test/scripts/functions/append/NaryCbind.dml b/src/test/scripts/functions/append/NaryCbind.dml
new file mode 100644
index 0000000..18331ad
--- /dev/null
+++ b/src/test/scripts/functions/append/NaryCbind.dml
@@ -0,0 +1,26 @@
+#-------------------------------------------------------------
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+#-------------------------------------------------------------
+
+A = read($1)
+B = read($2)
+C = read($3)
+R = cbind(A, B, C);
+write(R, $4)
http://git-wip-us.apache.org/repos/asf/systemml/blob/c0b6ef5c/src/test/scripts/functions/append/NaryRbind.R
----------------------------------------------------------------------
diff --git a/src/test/scripts/functions/append/NaryRbind.R b/src/test/scripts/functions/append/NaryRbind.R
new file mode 100644
index 0000000..30ed40b
--- /dev/null
+++ b/src/test/scripts/functions/append/NaryRbind.R
@@ -0,0 +1,32 @@
+#-------------------------------------------------------------
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+#-------------------------------------------------------------
+
+args <- commandArgs(TRUE)
+options(digits=22)
+library("Matrix")
+
+A = as.matrix(readMM(paste(args[1], "A.mtx", sep="")))
+B = as.matrix(readMM(paste(args[1], "B.mtx", sep="")))
+C = as.matrix(readMM(paste(args[1], "C.mtx", sep="")))
+
+R = rbind(rbind(A, B), C);
+
+writeMM(as(R,"CsparseMatrix"), paste(args[2], "R", sep=""))
http://git-wip-us.apache.org/repos/asf/systemml/blob/c0b6ef5c/src/test/scripts/functions/append/NaryRbind.dml
----------------------------------------------------------------------
diff --git a/src/test/scripts/functions/append/NaryRbind.dml b/src/test/scripts/functions/append/NaryRbind.dml
new file mode 100644
index 0000000..515c4ce
--- /dev/null
+++ b/src/test/scripts/functions/append/NaryRbind.dml
@@ -0,0 +1,26 @@
+#-------------------------------------------------------------
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+#-------------------------------------------------------------
+
+A = read($1)
+B = read($2)
+C = read($3)
+R = rbind(A, B, C);
+write(R, $4)
http://git-wip-us.apache.org/repos/asf/systemml/blob/c0b6ef5c/src/test_suites/java/org/apache/sysml/test/integration/functions/append/ZPackageSuite.java
----------------------------------------------------------------------
diff --git a/src/test_suites/java/org/apache/sysml/test/integration/functions/append/ZPackageSuite.java b/src/test_suites/java/org/apache/sysml/test/integration/functions/append/ZPackageSuite.java
index 5f0842b..df7cdd1 100644
--- a/src/test_suites/java/org/apache/sysml/test/integration/functions/append/ZPackageSuite.java
+++ b/src/test_suites/java/org/apache/sysml/test/integration/functions/append/ZPackageSuite.java
@@ -29,6 +29,8 @@ import org.junit.runners.Suite;
AppendChainTest.class,
AppendMatrixTest.class,
AppendVectorTest.class,
+ NaryCBindTest.class,
+ NaryRBindTest.class,
RBindCBindMatrixTest.class,
StringAppendTest.class,
})