使用g++编译tf_ops出现undefined symbol: _ZN10tensorflow8internal21CheckOpMessageBuilder9NewStringEv
程序员文章站
2022-07-12 09:36:30
...
1.第一种方式
根据查找资料,才知道sh文件中有错误,
如果你使用的g++版本是5.4.0,那么以下的
-D_GLIBCXX_USE_CXX11_ABI=0 都得去掉
#!/usr/bin/env bash
nvcc=/usr/local/cuda-9.0/bin/nvcc
cudainc=/usr/local/cuda-9.0/include/
cudalib=/usr/local/cuda-9.0/lib64/
TF_INC=$(python3 -c 'import tensorflow as tf; print(tf.sysconfig.get_include())')
TF_LIB=$(python3 -c 'import tensorflow as tf; print(tf.sysconfig.get_lib())')
$nvcc tf_sampling_g.cu -c -o tf_sampling_g.cu.o -std=c++11 -I $TF_INC -DGOOGLE_CUDA=1\
-x cu -Xcompiler -fPIC -O2
g++ tf_sampling.cpp tf_sampling_g.cu.o -o tf_sampling_so.so -std=c++11 -shared -fPIC -I $TF_INC \
-I$TF_INC/external/nsync/public -I $cudainc -L$TF_LIB -ltensorflow_framework -lcudart -L $cudalib -O2 #-D_GLIBCXX_USE_CXX11_ABI=0
2.第二种方式
如果你使用的g++版本为4.8.0,那么你可以尝试 -D_GLIBCXX_USE_CXX11_ABI=0
将这里的0变为1,或者你原本写的是1,将其变为0
第一种方式亲测有效,第二种方式对我没有效果,你们可以都试试。
上一篇: Ubuntu18.04 + cuda 10.2 + cudnn 配置
下一篇: 二分查找及其变形