C++調(diào)用tensorflow教程
目前深度學(xué)習(xí)越來(lái)越火,學(xué)習(xí)、使用tensorflow的相關(guān)工作者也越來(lái)越多。但是目前絕大部分的python都是擁有著豐富的python的API,而c++的API不夠完善。這就導(dǎo)致絕大多是使用tensorflow的項(xiàng)目都是基于python。
如果項(xiàng)目是由c++編寫,想調(diào)用python下的tensorflow?可參考本教程(tensorflow模型是CNN卷積神經(jīng)網(wǎng)絡(luò))
具體步驟:
1.python環(huán)境
首先安裝python,可以在Anaconda官網(wǎng)直接下載。記住python一定選擇64bit,目前tensorflow不支持32位的python,這也是我之前被坑過的地方。下載Anaconda后直接
bash Anaconda3-4.3.1-Linux-x86_64.sh
就可以安裝,然后
gedit ~/.bashrc
在最后面加上
export PATH=/<你的anaconda路徑>/bin:$PATH
將python安裝路徑添加到系統(tǒng)路徑中,這樣在終端敲python后會(huì)運(yùn)行安裝的python3.6,如下圖所示,代表安裝成功:
2.tensorflow
直接終端輸入:
pip install tensorflow
就會(huì)自動(dòng)幫你安裝到python下。
如果出現(xiàn)類似“沒有找到匹配版本”(或者紅色英文提示),那么你可能裝的是python32bit版本,暫時(shí)不支持tensorflow!
安裝成功后在終端如下操作:
顯示tensorflow版本,表示安裝成功!
3.C++Demo
一個(gè)簡(jiǎn)單的c++調(diào)取python+tensorflow的demo,按照實(shí)際需要可以依葫蘆畫瓢。
#include <Python.h> #include <iostream> int main(int argc, char** argv) { char* picpath ="/home/pdd/PD/c++/c++python/pic/0.0.jpg"; Py_Initialize(); if ( !Py_IsInitialized() ) { return -1; } PyRun_SimpleString("import sys"); PyRun_SimpleString("sys.path.append('./')"); PyObject* pMod = NULL; PyObject* pFunc = NULL; PyObject* pParm = NULL; PyObject* pRetVal = NULL; int iRetVal = -999; char* modulName="classify"; //這個(gè)是被調(diào)用的py文件模塊名字 pMod = PyImport_ImportModule(modulName); if(!pMod) { return -1; } char* funcName="evaluate"; //這是此py文件模塊中被調(diào)用的函數(shù)名字 pFunc = PyObject_GetAttrString(pMod, funcName); if(!pFunc) { return -2; } pParm = PyTuple_New(1); PyTuple_SetItem(pParm, 0, Py_BuildValue("s",picpath));//傳入的參數(shù),是圖片的路徑 pRetVal = PyEval_CallObject(pFunc, pParm);//這里開始執(zhí)行py腳本 PyArg_Parse(pRetVal, "i", &iRetVal);//py腳本返回值給iRetVal //PyErr_Print(); std::cout<<iRetVal; return iRetVal; }
4.tensorflow的python腳本
默認(rèn)你已經(jīng)寫好tensorflow的python腳本,并能跑成功。(tensorflow的使用不是本文重點(diǎn))
c++需要調(diào)用的就是這個(gè)classify.py里面的evaluate函數(shù),傳入圖片路徑,返回分類結(jié)果給c++程序。
from PIL import Image import numpy as np import tensorflow as tf def evaluate(pic): image = Image.open(pic) image = image.resize([256, 256]) image_array = np.array(image) with tf.Graph().as_default(): 里面就是對(duì)圖像讀取模型,預(yù)測(cè),得到prediction…… max_index = np.argmax(prediction) return max_index
5.c++調(diào)用python腳本的環(huán)境
這時(shí)候需要寫一個(gè)簡(jiǎn)單的makefile加入需要的依賴環(huán)境。例如c++代碼第一行的Python.h和相關(guān)的庫(kù)文件。
簡(jiǎn)單的makefile如下:
main:c++python.cpp g++ -o out c++python.cpp -I/home/pdd/anaconda3/include/python3.6m -lpython3.6m -L /home/pdd/anaconda3/lib clean: rm -rf *.o
-I后面的/home/pdd/anaconda3/include/python3.6m有需要的Python.h;-lpython3.6m鏈接到需要的libpython3.6m.so;-L指出鏈接的路徑。
終端輸入make。如果提示需要什么libpython3.6m..so,就把/home/pdd/anaconda3/lib下的libpython3.6m..so復(fù)制到/usr/lib/下(sudo cp ——–)
此時(shí)再次輸入make,一切ok!得到out文件,輸入./out,結(jié)果如下:
得到結(jié)果0。任務(wù)完成!
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
C/C++實(shí)現(xiàn)矩陣的轉(zhuǎn)置(示例代碼)
C/C++實(shí)現(xiàn)矩陣的轉(zhuǎn)置(示例代碼)需要的朋友可以過來(lái)參考下,希望對(duì)大家有所幫助2013-10-10模擬實(shí)現(xiàn)C語(yǔ)言中的內(nèi)存管理
這篇文章主要內(nèi)容是模擬C語(yǔ)言中的內(nèi)存管理,需要的朋友可以參考下2015-07-07C語(yǔ)言驅(qū)動(dòng)開發(fā)之判斷自身是否加載成功詳解
在驅(qū)動(dòng)開發(fā)中我們有時(shí)需要得到驅(qū)動(dòng)自身是否被加載成功的狀態(tài),這個(gè)功能看似沒啥用實(shí)際上在某些特殊場(chǎng)景中還是需要的。本文將通過示例詳細(xì)講講這一功能的實(shí)現(xiàn)方法,需要的可以參考下2022-10-10c++實(shí)現(xiàn)加載so動(dòng)態(tài)庫(kù)中的資源
下面小編就為大家?guī)?lái)一篇c++實(shí)現(xiàn)加載so動(dòng)態(tài)庫(kù)中的資源。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2016-12-12如何用C寫一個(gè)web服務(wù)器之CGI協(xié)議
本文主要介紹了如何用C寫一個(gè)web服務(wù)器之CGI協(xié)議,對(duì)C語(yǔ)言和web感興趣的同學(xué),可以詳細(xì)看下,并且試驗(yàn)一下。2021-05-05