Skip to content

Commit 2d5dfc6

Browse files
ivanallenliufeng27
authored and
liufeng27
committed
import span to speed up
1 parent ce847d5 commit 2d5dfc6

File tree

6 files changed

+642
-8
lines changed

6 files changed

+642
-8
lines changed

examples/eager_op_multithread/CMakeLists.txt

+2
Original file line numberDiff line numberDiff line change
@@ -6,9 +6,11 @@ find_package(Threads REQUIRED)
66

77
set(CMAKE_CXX_STANDARD 17)
88

9+
910
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-omit-frame-pointer -fsanitize=thread")
1011
#set(CMAKE_LINKER_FLAGS "${CMAKE_LINKER_FLAGS} -fno-omit-frame-pointer -fsanitize=thread")
1112

1213
add_executable(example main.cpp)
1314
target_include_directories(example PRIVATE ../../include $ENV{HOME}/libtensorflow2/include)
15+
target_link_libraries (example "${TENSORFLOW_LIB}")
1416
target_link_libraries(example "${TENSORFLOW_LIB}" Threads::Threads)

examples/tensor_span/CMakeLists.txt

+16
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
cmake_minimum_required(VERSION 3.10)
2+
project(example)
3+
4+
find_library(TENSORFLOW_LIB tensorflow HINT $ENV{HOME}/libtensorflow2/lib)
5+
find_package(Threads REQUIRED)
6+
7+
#set(CMAKE_CXX_STANDARD 20)
8+
set(CMAKE_CXX_STANDARD 17)
9+
10+
11+
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-omit-frame-pointer -fsanitize=address")
12+
set(CMAKE_LINKER_FLAGS "${CMAKE_LINKER_FLAGS} -lasan")
13+
14+
add_executable(example main.cpp)
15+
target_include_directories(example PRIVATE ../../include $ENV{HOME}/libtensorflow2/include)
16+
target_link_libraries (example "${TENSORFLOW_LIB}")

examples/tensor_span/main.cpp

+23
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
#include <cmath>
2+
#include <vector>
3+
#include <cassert>
4+
5+
#include "cppflow/cppflow.h"
6+
7+
template<typename T>
8+
void test(const std::initializer_list<T>& input) {
9+
std::vector<T> values = input;
10+
cppflow::tensor t(input);
11+
auto span_result = t.get_data<T>();
12+
13+
assert(span_result.size() == values.size());
14+
for(size_t i = 0; i < span_result.size(); i++) {
15+
assert(std::abs(values[i]/span_result[i]-1.0f) < 1e-6);
16+
}
17+
}
18+
19+
int main() {
20+
test({10, 20, 30});
21+
test({10.0, 20.1, 30.3});
22+
return 0;
23+
}

include/cppflow/model.h

+1
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@
1414
#include "context.h"
1515
#include "defer.h"
1616
#include "tensor.h"
17+
#include "defer.h"
1718

1819
namespace cppflow {
1920

0 commit comments

Comments
 (0)