上一篇( mlp模型參數(shù)提取 : http://www.reibang.com/p/2e5b2ff068eb )中我們得到了mlp訓(xùn)練模型的參數(shù)。
這篇介紹如何將這個(gè)模型應(yīng)用在c++工程中進(jìn)行銀行卡圖片預(yù)測(cè)。
首先需要介紹一個(gè)c++矩陣計(jì)算庫。Eigen杜漠,開源的媒峡∝罢可以去官網(wǎng)上下載最新版本編譯安裝。
官網(wǎng)地址:http://eigen.tuxfamily.org/index.php?title=Main_Page
下載后解壓:
進(jìn)入目錄探橱,在源碼目錄下新建一個(gè)build文件夾(執(zhí)行下面三個(gè)命令):
mkdir buildrelease
cd buildrelease
cmake -DEIGEN_TEST_NO_OPENGL=1 ..
p1.png
再執(zhí)行命令
make
sudo make install
坐等它安裝成功即可。
下一步绘证,打開ide隧膏,配置環(huán)境變量,導(dǎo)入頭文件,定義需要計(jì)算的矩陣
#include <eigen3/Eigen/Core>
#include <eigen3/Eigen/Dense>
typedef Eigen::Matrix<float, 1, 513, Eigen::RowMajor> FullyNumberImage;//輸入矩陣
typedef Eigen::Matrix<float, 1, 513, Eigen::RowMajor> ModelInputImage;
typedef Eigen::Matrix<float, 513, 128, Eigen::RowMajor> ModelCWeight1Type;//模型參數(shù)中weight1的矩陣
typedef Eigen::Matrix<float, 128, 32, Eigen::RowMajor> ModelCWeight2Type; //模型參數(shù)中weight2的矩陣
typedef Eigen::Matrix<float, 32, 10, Eigen::RowMajor> ModelCWeight3Type; //模型參數(shù)中weight3的矩陣
typedef Eigen::Matrix<float, 1, 128, Eigen::RowMajor> ModelCB1; //模型參數(shù)中b1的矩陣
typedef Eigen::Matrix<float, 1, 32, Eigen::RowMajor> ModelCB2; //模型參數(shù)中b2的矩陣
typedef Eigen::Matrix<float, 1, 10, Eigen::RowMajor> ModelCB3; //模型參數(shù)中b3的矩陣
typedef Eigen::Matrix<float, 27, 19, Eigen::RowMajor> NumberImage;
typedef Eigen::Matrix<float, 1, 10, Eigen::RowMajor> SingleNumberScores;
typedef Eigen::Matrix<float, 1, 513, Eigen::RowMajor> FullyNumberImage;
定義數(shù)據(jù)嚷那,由于數(shù)據(jù)太多了胞枕,我就只寫一部分意思下:
static float data_513_128[65664] ={-0.047784225994872205, -0.07284609638534617, -0.041955766457765144,.........};
static float data_128_32[4096]={-0.17730805116015405, 0.2448316226022322, 0.07461592356579184,........};
static float data_32_10[320]={-0.014385057734315638,.......};
static float data_1_128[128]={-0.0012434375941485945,....};
static float data_1_32[32]={-0.013492870061084548,......};
static float data_1_10[10]={0.04521966,.......};
下面是矩陣計(jì)算部分,還是那個(gè)公式魏宽,上一步得到的結(jié)果作為下一步的輸入:
QunarModelCOutput_5c241121 apply_qunarmodel_2719(const QunarModelCInput_5c241121& input){
Eigen::Map<ModelCWeight1Type, Eigen::Aligned> weight1((float *)data_513_128);
Eigen::Map<ModelCWeight2Type, Eigen::Aligned> weight2((float *)data_128_32);
Eigen::Map<ModelCWeight3Type, Eigen::Aligned> weight3((float *)data_32_10);
Eigen::Map<ModelCB1, Eigen::Aligned> b1((float *)data_1_128);
Eigen::Map<ModelCB2, Eigen::Aligned> b2((float *)data_1_32);
Eigen::Map<ModelCB3, Eigen::Aligned> b3((float *)data_1_10);
//Eigen::Map<ModelCB3, Eigen::Aligned> r12((float *)data_10_1);
ModelCB1 output1 = input*weight1+b1;
ModelCB2 output2 = output1*weight2+b2;
ModelCB3 output3 = output2*weight3+b3;
//Eigen::Map<QunarModelCOutput_5c241121, Eigen::Aligned> r1((float *)data_10_1);
return output3;
}
使用測(cè)試數(shù)據(jù)還是和上一篇中用到的一個(gè)數(shù)字一樣:
static float data_test_image[513]={228, 207, 220, 227, 223, 222, 211, 213, 224, 215, 213, 221, 223, 218, 223, 234, 227, 224, 222, 219, 215, 226, 213, 205, 220, 223, 227, 211, 211, 209, 208, 213, 219, 216, 208, 210, 206, 203, 220, 215, 228, 226, 223, 213, 181, 169, 162, 181, 186, 175, 176, 196, 207, 201, 160, 154, 144, 238, 212, 209, 205, 186, 148, 123, 148, 197, 212, 200, 150, 103, 90, 99, 109, 122, 124, 123, 216, 211, 209, 174, 120, 74, 81, 149, 163, 166, 157, 122, 72, 44, 55, 79, 110, 122, 131, 215, 223, 200, 129, 74, 48, 56, 111, 139, 128, 122, 113, 81, 40, 31, 45, 85, 106, 123, 214, 195, 134, 55, 32, 39, 50, 96, 119, 110, 113, 119, 95, 52, 29, 33, 56, 88, 118, 128, 111, 74, 34, 34, 34, 41, 96, 121, 123, 131, 128, 94, 46, 21, 22, 45, 81, 113, 122, 85, 55, 29, 25, 31, 48, 96, 117, 128, 118, 115, 90, 42, 27, 29, 37, 65, 106, 121, 83, 52, 26, 21, 25, 42, 90, 116, 128, 118, 115, 90, 41, 25, 26, 32, 59, 100, 120, 82, 51, 28, 23, 27, 44, 95, 116, 128, 119, 116, 90, 40, 22, 22, 26, 52, 91, 115, 75, 46, 27, 25, 30, 49, 102, 116, 128, 119, 117, 90, 39, 20, 19, 25, 48, 83, 109, 68, 39, 22, 21, 25, 44, 99, 116, 128, 119, 117, 90, 38, 19, 18, 26, 46, 78, 112, 69, 40, 24, 21, 22, 40, 96, 118, 129, 119, 116, 90, 39, 21, 20, 26, 45, 75, 115, 70, 41, 26, 23, 23, 41, 98, 119, 130, 119, 116, 90, 40, 23, 23, 29, 46, 74, 107, 63, 35, 21, 21, 20, 40, 98, 120, 130, 119, 115, 89, 40, 25, 26, 31, 47, 73, 116, 73, 36, 18, 22, 20, 38, 105, 121, 131, 120, 116, 90, 42, 29, 32, 34, 59, 82, 117, 80, 44, 23, 27, 27, 41, 99, 124, 133, 121, 118, 93, 45, 31, 33, 43, 71, 98, 119, 91, 57, 29, 29, 32, 43, 94, 123, 133, 122, 120, 97, 50, 35, 35, 46, 78, 108, 121, 103, 73, 34, 26, 30, 45, 96, 119, 131, 122, 122, 99, 50, 34, 33, 50, 83, 113, 123, 114, 89, 44, 26, 27, 45, 100, 119, 132, 124, 121, 95, 45, 29, 31, 64, 94, 121, 126, 122, 104, 63, 41, 33, 46, 101, 121, 134, 124, 118, 89, 41, 34, 42, 82, 106, 126, 129, 125, 116, 88, 69, 49, 47, 95, 116, 130, 119, 111, 83, 46, 54, 74, 103, 118, 129, 131, 126, 123, 107, 92, 64, 49, 88, 109, 123, 112, 104, 81, 54, 75, 105, 122, 131, 134, 128, 127, 127, 124, 116, 105, 98, 95, 106, 111, 113, 107, 99, 99, 112, 124, 127, 127, 127, 129, 130, 131, 131, 127, 122, 119, 117, 114, 116, 117, 117, 116, 118, 123, 128, 127, 127, 127, 127, 128, 129, 130, 130, 130, 130, 129, 125, 123, 123, 127, 132, 133, 130, 125, 127, 127, 127};
運(yùn)行程序:
p3.png
debug模式下查看程序每一步的輸出:
p4.png
和上一篇中用python實(shí)現(xiàn)的結(jié)果是一致的曲稼。