Skip to content

Commit

Permalink
[ML-226] Migrate correlation daal to DPC++ (#215)
Browse files Browse the repository at this point in the history
* 1. add JNI wrapper
2. modify compiler config
3. add unit test

Signed-off-by: minmingzhu <[email protected]>

* add ci test

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* java code style

Signed-off-by: minmingzhu <[email protected]>

* cpp code style

Signed-off-by: minmingzhu <[email protected]>

* Update ci-local-test.sh

* Update ci-local-test.sh

* Update install-build-deps-ubuntu.sh

* Update install-build-deps-ubuntu.sh

* Update ci-local-test.sh

* Update ci-local-test.sh

* Update ci-local-test.sh

* Update install-build-deps-ubuntu.sh

* Update install-build-deps-ubuntu.sh

* Update install-build-deps-ubuntu.sh

* Update install-build-deps-ubuntu.sh

* Update install-build-deps-ubuntu.sh

* Update prepare-build-deps.sh

* add convert array, vector to homogentable

Signed-off-by: minmingzhu <[email protected]>

* 1. rollback ci config
2. remove CI test becaue homogentable only support GPU

Signed-off-by: minmingzhu <[email protected]>

* 1. update prepare-build-deps.sh

Signed-off-by: minmingzhu <[email protected]>

* remove ci GPU test

Signed-off-by: minmingzhu <[email protected]>

* 1. remove GPU CI test

Signed-off-by: minmingzhu <[email protected]>

* update code style

Signed-off-by: minmingzhu <[email protected]>

* update code style

Signed-off-by: minmingzhu <[email protected]>

* fix comments

Signed-off-by: minmingzhu <[email protected]>

* update Makefile

Signed-off-by: minmingzhu <[email protected]>

* fix comments

Signed-off-by: minmingzhu <[email protected]>

* 1. fix ci

Signed-off-by: minmingzhu <[email protected]>

* update header

Signed-off-by: minmingzhu <[email protected]>

* update header

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* Update ci-cluster-test.sh

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci conf

Signed-off-by: minmingzhu <[email protected]>

* update oneapi to 2022.1.2

Signed-off-by: minmingzhu <[email protected]>

* update ci conf

Signed-off-by: minmingzhu <[email protected]>

* fix comment

Signed-off-by: minmingzhu <[email protected]>

* Update build-jni.sh

* update Makefile

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* Update test.sh

* Update test.sh

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* Update test.sh

* Update test.sh

* update test.sh

Signed-off-by: minmingzhu <[email protected]>

* update test.sh

Signed-off-by: minmingzhu <[email protected]>

* update test.sh

Signed-off-by: minmingzhu <[email protected]>

* fix link libze_loader.so.1

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update ci-local-dpc-test.sh

Signed-off-by: minmingzhu <[email protected]>

* update oneapi to 2022.1.2

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* Update ci-local-dpc-test.sh

* update

Signed-off-by: minmingzhu <[email protected]>

* update Makefile

Signed-off-by: minmingzhu <[email protected]>

* Update ci-local-dpc-test.sh

* Update prepare-build-deps-gpu.sh

* Update prepare-build-deps-gpu.sh

* Update prepare-build-deps.sh

* update ci

Signed-off-by: minmingzhu <[email protected]>

* Update ci-local-dpc-test.sh

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* Update install-build-level-zero-deps-ubuntun.sh

* Update install-build-level-zero-deps-ubuntun.sh

* Update install-build-level-zero-deps-ubuntun.sh

* Update ci-local-dpc-test.sh

* Update GPU.cpp

* Update GPU.cpp

* Update ci-build-test.sh

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update HomogenTableImpl.cpp

Signed-off-by: minmingzhu <[email protected]>

* Update ci-local-dpc-test.sh

* Update ci-local-dpc-test.sh

* Update ci-local-dpc-test.sh

* update HomogenTable API

Signed-off-by: minmingzhu <[email protected]>

* update install-build-level-zero-deps-ubuntu.sh

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update code style

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* Update ci-local-dpc-test.sh

* update ci

Signed-off-by: minmingzhu <[email protected]>

* Update ci-local-dpc-test.sh

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* update ci

Signed-off-by: minmingzhu <[email protected]>

* Update run.sh

* Update build-jni.sh

* 1. Merge branch 'make_homogen_table' into convert_homogentable
2. update ci
3. add a new parameters for HomogenTable class

Signed-off-by: minmingzhu <[email protected]>

* Update pom.xml

* Update test.sh

* Update Makefile

* update

Signed-off-by: minmingzhu <[email protected]>

* Update ConvertHomogenTableSuite.scala

* Update install-level-zero-ubuntu.sh

* Update install-level-zero-ubuntu.sh

* Update build.sh

* Update test.sh

* Update test.sh

* Update HomogenTableImpl.cpp

* Update install-build-deps-ubuntu.sh

* Update HomogenTableImpl.cpp

* update

Signed-off-by: minmingzhu <[email protected]>

* update code style

Signed-off-by: minmingzhu <[email protected]>

* Update install-build-deps-ubuntu.sh

* fix comments

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* Update list-compute-devices.cpp

* Convert homogentable to array/vector/matrix (#4)

* 1. convert homogenTable to array/vector/matrix
2. add unit test

Signed-off-by: minmingzhu <[email protected]>

* Merge branch 'make_homogen_table' into convert_homogentable

Signed-off-by: minmingzhu <[email protected]>

* update code style

Signed-off-by: minmingzhu <[email protected]>

* fix comments

Signed-off-by: minmingzhu <[email protected]>

* Convert RDD[Vector]/RDD[LabeledPoint] to HomogenTable (#8)

* 1. convert rdd to HomogenTable
* 2. add unit test

Signed-off-by: minmingzhu <[email protected]>

* add empty homogentable

Signed-off-by: minmingzhu <[email protected]>

* Mirgate kmeans daal to DPC++ (#7)

Signed-off-by: minmingzhu <[email protected]>

* 1. Mirgate kmeans daal to DPC++
* 2. add unit test

* 1. migrate pca to DPC++
2. add unit test

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* normalize data

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* 1. migrate correlation to DPC++ interface
2. add unit test

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* 1. move local host to distributed host
2. add cluster test
3. code style

Signed-off-by: minmingzhu <[email protected]>

* update code style

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* Update ci-cluster-test.sh

* Update ci-cluster-test.sh

* Update build.sh

* Update build.sh

* Update OneDAL.cpp

* Update OneDAL.cpp

* Update OneDAL.cpp

* Update com_intel_oap_mllib_OneDAL__.h

* update code style

Signed-off-by: minmingzhu <[email protected]>

* Update NaiveBayesResult.java

* 1. update code style
2. When using the Host/CPU device throws a fail

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* rollback code style

Signed-off-by: minmingzhu <[email protected]>

* rollback code style

Signed-off-by: minmingzhu <[email protected]>

* rollback checkstyle.xml

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* rollback checkstyle.xml

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update OneDAL.scala

Signed-off-by: minmingzhu <[email protected]>

* revert ALS.scala

* revert checkstyle.xml

* :Revert "revert checkstyle.xml"

This reverts commit 4f74bac.

* disable cluster test for gpu

* disable cluster test for gpu

* nit

* migrate cpa to DPC++

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* Update OutputHelpers.hpp

* update com_intel_oap_mllib_feature_PCADALImpl.h

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update PCADALImpl.scala

Signed-off-by: minmingzhu <[email protected]>

* 1. update function name and variable name

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update stayHomogenTablePtrToVector to saveHomogenTablePtrToVector

Signed-off-by: minmingzhu <[email protected]>

* change compute_device to ComputeDevice

Signed-off-by: minmingzhu <[email protected]>

* 1. migrate pca to DPC++
2. add unit test

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* normalize data

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* 1. migrate correlation to DPC++ interface
2. add unit test

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* Update prepare-build-deps-gpu.sh

* update

Signed-off-by: minmingzhu <[email protected]>

* Update Makefile

* Update OutputHelpers.hpp

* Update PCAOneAPIImpl.cpp

* Update service.h

* update

Signed-off-by: minmingzhu <[email protected]>

* Update OneDAL.scala

* Update PCADALImpl.scala

* Update KmeansHomogenTableSuite.scala

* Update TestCommon.scala

* Update test.sh

* update

Signed-off-by: minmingzhu <[email protected]>

* fix comments

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update

Signed-off-by: minmingzhu <[email protected]>

* update code style

Signed-off-by: minmingzhu <[email protected]>

Signed-off-by: minmingzhu <[email protected]>
Co-authored-by: minmingz <[email protected]>
Co-authored-by: Wu, Xiaochang <[email protected]>
  • Loading branch information
3 people authored Aug 31, 2022
1 parent dc5736a commit c123064
Show file tree
Hide file tree
Showing 21 changed files with 1,387 additions and 247 deletions.
4 changes: 2 additions & 2 deletions examples/correlation/run-gpu-standalone.sh
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ DATA_FILE=$HDFS_ROOT/data/sample_kmeans_data.txt
APP_JAR=target/oap-mllib-examples-$OAP_MLLIB_VERSION.jar
APP_CLASS=org.apache.spark.examples.ml.CorrelationExample

USE_GPU=true
DEVICE=GPU
RESOURCE_FILE=$PWD/IntelGpuResourceFile.json
WORKER_GPU_AMOUNT=4
EXECUTOR_GPU_AMOUNT=1
Expand All @@ -27,7 +27,7 @@ time $SPARK_HOME/bin/spark-submit --master $SPARK_MASTER \
--conf "spark.sql.shuffle.partitions=$SPARK_DEFAULT_PARALLELISM" \
--conf "spark.driver.extraClassPath=$SPARK_DRIVER_CLASSPATH" \
--conf "spark.executor.extraClassPath=$SPARK_EXECUTOR_CLASSPATH" \
--conf "spark.oap.mllib.useGPU=$USE_GPU" \
--conf "spark.oap.mllib.device=$DEVICE" \
--conf "spark.worker.resourcesFile=$RESOURCE_FILE" \
--conf "spark.worker.resource.gpu.amount=$WORKER_GPU_AMOUNT" \
--conf "spark.executor.resource.gpu.amount=$EXECUTOR_GPU_AMOUNT" \
Expand Down
3 changes: 2 additions & 1 deletion examples/correlation/run.sh
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

source ../../conf/env.sh


DEVICE=CPU
APP_JAR=target/oap-mllib-examples-$OAP_MLLIB_VERSION.jar
APP_CLASS=org.apache.spark.examples.ml.CorrelationExample

Expand All @@ -17,6 +17,7 @@ time $SPARK_HOME/bin/spark-submit --master $SPARK_MASTER \
--conf "spark.sql.shuffle.partitions=$SPARK_DEFAULT_PARALLELISM" \
--conf "spark.driver.extraClassPath=$SPARK_DRIVER_CLASSPATH" \
--conf "spark.executor.extraClassPath=$SPARK_EXECUTOR_CLASSPATH" \
--conf "spark.oap.mllib.device=$DEVICE" \
--conf "spark.shuffle.reduceLocality.enabled=false" \
--conf "spark.network.timeout=1200s" \
--conf "spark.task.maxFailures=1" \
Expand Down
2 changes: 2 additions & 0 deletions examples/pca/run.sh
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ APP_JAR=target/oap-mllib-examples-$OAP_MLLIB_VERSION.jar
APP_CLASS=org.apache.spark.examples.ml.PCAExample

# Dataset is created in the code, so no need to pass in as parameter
DEVICE=CPU

time $SPARK_HOME/bin/spark-submit --master $SPARK_MASTER \
--num-executors $SPARK_NUM_EXECUTORS \
Expand All @@ -18,6 +19,7 @@ time $SPARK_HOME/bin/spark-submit --master $SPARK_MASTER \
--conf "spark.sql.shuffle.partitions=$SPARK_DEFAULT_PARALLELISM" \
--conf "spark.driver.extraClassPath=$SPARK_DRIVER_CLASSPATH" \
--conf "spark.executor.extraClassPath=$SPARK_EXECUTOR_CLASSPATH" \
--conf "spark.oap.mllib.device=$DEVICE" \
--conf "spark.shuffle.reduceLocality.enabled=false" \
--conf "spark.network.timeout=1200s" \
--conf "spark.task.maxFailures=1" \
Expand Down
192 changes: 0 additions & 192 deletions mllib-dal/src/main/native/CorrelationDALImpl.cpp

This file was deleted.

89 changes: 89 additions & 0 deletions mllib-dal/src/main/native/CorrelationOneAPIImpl.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
/*******************************************************************************
* Copyright 2020 Intel Corporation
*
* Licensed 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.
*******************************************************************************/

#include <chrono>

#ifdef CPU_GPU_PROFILE
#include "GPU.h"
#ifndef ONEDAL_DATA_PARALLEL
#define ONEDAL_DATA_PARALLEL
#endif

#include "Communicator.hpp"
#include "OutputHelpers.hpp"
#include "com_intel_oap_mllib_stat_CorrelationDALImpl.h"
#include "oneapi/dal/algo/covariance.hpp"
#include "oneapi/dal/table/homogen.hpp"
#include "service.h"

using namespace std;
using namespace oneapi::dal;
const int ccl_root = 0;

static void doCorrelationOneAPICompute(JNIEnv *env, jint rankId,
jlong pNumTabData, jint executorNum,
const ccl::string &ipPort,
jint computeDeviceOrdinal,
jobject resultObj) {
std::cout << "oneDAL (native): compute start , rankid = " << rankId
<< "; device = " << ComputeDeviceString[computeDeviceOrdinal]
<< std::endl;
const bool isRoot = (rankId == ccl_root);
ComputeDevice device = getComputeDeviceByOrdinal(computeDeviceOrdinal);
homogen_table htable =
*reinterpret_cast<const homogen_table *>(pNumTabData);

const auto cor_desc = covariance::descriptor{}.set_result_options(
covariance::result_options::cor_matrix |
covariance::result_options::means);
auto queue = getQueue(device);
auto comm = preview::spmd::make_communicator<preview::spmd::backend::ccl>(
queue, executorNum, rankId, ipPort);
const auto result_train = preview::compute(comm, cor_desc, htable);
if (isRoot) {
std::cout << "Mean:\n" << result_train.get_means() << std::endl;
std::cout << "Correlation:\n"
<< result_train.get_cor_matrix() << std::endl;
// Return all covariance & mean
jclass clazz = env->GetObjectClass(resultObj);

// Get Field references
jfieldID correlationNumericTableField =
env->GetFieldID(clazz, "correlationNumericTable", "J");

HomogenTablePtr correlation =
std::make_shared<homogen_table>(result_train.get_cor_matrix());
saveHomogenTablePtrToVector(correlation);

env->SetLongField(resultObj, correlationNumericTableField,
(jlong)correlation.get());
}
}

JNIEXPORT jlong JNICALL
Java_com_intel_oap_mllib_stat_CorrelationDALImpl_cCorrelationTrainDAL(
JNIEnv *env, jobject obj, jlong pNumTabData, jint executorNum,
jint computeDeviceOrdinal, jint rankId, jstring ipPort, jobject resultObj) {
std::cout << "oneDAL (native): use DPC++ kernels " << std::endl;
const char *ipPortPtr = env->GetStringUTFChars(ipPort, 0);
std::string ipPortStr = std::string(ipPortPtr);
doCorrelationOneAPICompute(env, rankId, pNumTabData, executorNum, ipPortStr,
computeDeviceOrdinal, resultObj);

env->ReleaseStringUTFChars(ipPort, ipPortPtr);
return 0;
}
#endif
7 changes: 3 additions & 4 deletions mllib-dal/src/main/native/KMeansOneAPIImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@
#include <chrono>
#include <iomanip>
#include <iostream>
#include <mutex>

#ifdef CPU_GPU_PROFILE
#include "GPU.h"
Expand All @@ -41,8 +40,8 @@ static jlong doKMeansOneAPICompute(JNIEnv *env, jint rankId, jlong pNumTabData,
jint executorNum, const ccl::string &ipPort,
jint computeDeviceOrdinal,
jobject resultObj) {
std::cout << "oneDAL (native): GPU/CPU compute start , rankid = " << rankId
<< "; device = " << computeDeviceOrdinal << "(0:HOST;1:GPU;2:CPU)"
std::cout << "oneDAL (native): compute start , rankid = " << rankId
<< "; device = " << ComputeDeviceString[computeDeviceOrdinal]
<< std::endl;
const bool isRoot = (rankId == ccl_root);
ComputeDevice device = getComputeDeviceByOrdinal(computeDeviceOrdinal);
Expand Down Expand Up @@ -93,7 +92,7 @@ Java_com_intel_oap_mllib_clustering_KMeansDALImpl_cKMeansOneapiComputeWithInitCe
JNIEnv *env, jobject obj, jlong pNumTabData, jlong pNumTabCenters,
jint clusterNum, jdouble tolerance, jint iterationNum, jint executorNum,
jint computeDeviceOrdinal, jint rankId, jstring ipPort, jobject resultObj) {
std::cout << "oneDAL (native): use GPU DPC++ kernels " << std::endl;
std::cout << "oneDAL (native): use DPC++ kernels " << std::endl;
const char *ipPortPtr = env->GetStringUTFChars(ipPort, 0);
std::string ipPortStr = std::string(ipPortPtr);
jlong ret = 0L;
Expand Down
6 changes: 3 additions & 3 deletions mllib-dal/src/main/native/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ LIBS_COMMON := -L$(CCL_ROOT)/lib/cpu_gpu_dpcpp -lccl \

ONEDAL_LIBS := -lonedal_dpc \
-lonedal_core \
-lonedal_thread
-lonedal_thread

ifeq ($(PLATFORM_PROFILE),CPU_ONLY_PROFILE)
LIBS := $(LIBS_COMMON) $(ONEDAL_LIBS)
Expand All @@ -78,7 +78,7 @@ CPP_SRCS += \
./ALSDALImpl.cpp ./ALSShuffle.cpp \
./NaiveBayesDALImpl.cpp \
./LinearRegressionDALImpl.cpp \
./CorrelationDALImpl.cpp \
./CorrelationOneAPIImpl.cpp \
./SummarizerDALImpl.cpp \
./oneapi/dal/HomogenTableImpl.cpp \
./oneapi/dal/SimpleMetadataImpl.cpp \
Expand All @@ -93,7 +93,7 @@ OBJS += \
./ALSDALImpl.o ./ALSShuffle.o \
./NaiveBayesDALImpl.o \
./LinearRegressionDALImpl.o \
./CorrelationDALImpl.o \
./CorrelationOneAPIImpl.o \
./SummarizerDALImpl.o \
./oneapi/dal/HomogenTableImpl.o \
./oneapi/dal/SimpleMetadataImpl.o \
Expand Down
2 changes: 1 addition & 1 deletion mllib-dal/src/main/native/OutputHelpers.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
#include "oneapi/dal/table/row_accessor.hpp"
#include "oneapi/dal/table/common.hpp"

std::ostream &operator<<(std::ostream &stream, const oneapi::dal::table &table) {
inline std::ostream &operator<<(std::ostream &stream, const oneapi::dal::table &table) {
auto arr = oneapi::dal::row_accessor<const float>(table).pull();
const auto x = arr.get_data();

Expand Down
Loading

0 comments on commit c123064

Please sign in to comment.