Crnn_chinese_characters 中文字符识别

Crnn_chinese_characters 中文字符识别

重要的源码地址:

一、实验环境

没网、没权限、centos 64

二、实验步骤

1、离线安装 anaconda

anaconda清华镜像源

先下载anaconda3-4.2对应py3.5, Anaconda3-4.2.0-Linux-x86_64.sh

相关博客

2、离线安装 torch

再下载torch-0.4.0-cp35-cp35m-linux_x86_64.whl

3、配置环境变量

修改~/.bashrc 增加如下环境变量

## WARP_CTC
export CUDA_HOME="/usr/local/cuda"
export TENSORFLOW_SRC_PATH="/data/home/douglaswang/anaconda3/lib/python3.5/site-packages:$TENSORFLOW_SRC_PATH"
export WARP_CTC_PATH="/data/home/douglaswang/2019-01/warp-ctc/build:$WARP_CTC_PATH"

4、安装warp-ctc

git clone https://github.com/SeanNaren/warp-ctc.git
cd warp-ctc
mkdir build; cd build
cmake ..
make

然后安装bindings

cd pytorch_binding
python setup.py install

5、在Crnn_chinese_characters_rec目录下执行python test.py,进行测试

因为当前环境离线,会提出缺少相关whl文件,下载地址pypi,安装方式如下:

  • torchvision-0.1.8-py2.py3-none-any.whl
    • pip install torchvision-0.1.8-py2.py3-none-any.whl
  • lmdb-0.94.tar.gz (源码安装)
    • tar xzvf lmdb-0.94.tar.gz
    • cd lmdb-0.9.4
    • python setup.py install

效果如下:

[douglaswang@Tencent-SNG ~/2019-01/crnn_chinese_characters_rec]$ python test.py
loading pretrained model from trained_models/mixed_second_finetune_acc97p7.pth
results: 男装、女装、童装、婴儿装、内衣、服饰、泳衣、家用饰品、针纺织品、服装面料及辅
elapsed time: 0.0521390438079834

三、安装pytorch: warp-ctc遇到的问题

Q: fatal error: torch/extension.h: No such file or directory

src/binding.cpp:6:10: fatal error: torch/extension.h: No such file or directory
 #include <torch/extension.h>
 
代码版本不一致导致的问题,将代码回退到0.4版本    `git checkout ac045b6072b9bc3454fb9f9f17674f0d59373789`

Q:THC_API cudaError_t THCudaMalloc(THCState *state, void **ptr, size_t size);

THC_API cudaError_t THCudaMalloc(THCState *state, void **ptr, size_t size);
error: command 'x86_64-linux-gnu-gcc' failed with exit status 1。

修改pytorch_binding/src/binding.cpp文件为如下:
1 at 92 line
    int probs_size = THCudaTensor_size(state, probs, 2);
2 at l05 lines
    void* gpu_workspace;
    THCudaMalloc(state, &gpu_workspace, gpu_size_bytes);

安装 caffe遇到部分问题

Q: ImportError: libcusolver.so.8.0: cannot open shared object file: No such file or directory

A:  sudo vim ~/.bashrc 
    export LD_LIBRARY_PATH=”$LD_LIBRARY_PATH:/usr/local/cuda/lib64” 
    export CUDA_HOME=/usr/local/cuda 
    source ~/.bashrc`

Q: ‘kEmptyString’ is not a member of ‘google::protobuf::internel’

这时由于protoc编译器版本和protobuf头文件不对应的问题,原因就是系统里可能存在多个protoc的版本,但是protobuf的包含文件可能只有一种,所以就会造成这种问题,解决问题的方案就是,在Makefile里面重新指定protoc的版本

#$(Q)protoc --proto_path=$(PROTO_SEC_DIR) --cpp_out=$(PROTO_BUILD_DIR)
$(Q)/usr/bin/protoc --proto_path=$(PROTO_SEC_DIR) --cpp_out=$(PROTO_BUILD_DIR)

在Makefile 中修改这两句:
    $(Q)protoc --proto_path=$(PROTO_SRC_DIR) --cpp_out=$(PROTO_BUILD_DIR) $<
    $(Q)protoc --proto_path=$(PROTO_SRC_DIR) --python_out=$(PY_PROTO_BUILD_DIR) $<
为
    $(Q)/usr/bin/protoc --proto_path=$(PROTO_SRC_DIR) --cpp_out=$(PROTO_BUILD_DIR) $<
    $(Q)/usr/bin/protoc --proto_path=$(PROTO_SRC_DIR) --python_out=$(PY_PROTO_BUILD_DIR) $<

Caffe 训练问题

Q:F0107 18:58:32.448169 21800 syncedmem.cpp:71] Check failed: error == cudaSuccess (2 vs. 0) out of memory

A:train的batch_size设置过大,改小后可以。 http://blog.sina.com.cn/s/blog_141f234870102w8is.html

some tricks

  • 可以在Makefile文件中直接指定protoc路径
    • 命令 whereis protoc 可以查看哪些路径下安装了protoc
    • 命令which protoc 可以查看默认选用protoc的路径
    • 命令 protoc --version 可以查看当前protoc版本
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容

  • 也是很难过的,别人一条pip指令就可以安装pytorch,轮到我就是各种出错。所以记录一下安装过程遇到的问题。 尝...
    大脸猫猫脸大阅读 9,247评论 0 2
  • --> 在六七月份参加了一个比赛,做的项目是提取图片中的文字信息,首先是接触了一些文本检测算法(如CTPN,Ea...
    Sierkinhane阅读 13,926评论 3 11
  • Tensorflow安装手册 tony:~ xdwang$ sudo easy_install pip Pass...
    sennchi阅读 1,568评论 0 1
  • 一. 小时候,老家院里有颗核桃树,也不知道这树有多大了,只有粗糙而硕大的树干能看出岁月沧桑,春天来了,外婆就催着外...
    xr安稳阅读 422评论 0 1
  • 李龙学最近明显地见瘦,腰围小了一大圈,裤子条条穿不住,不得不用腰带紧紧地束着。老婆看着心疼,一个劲儿地催他去医院看...
    冬妮娅阅读 481评论 0 1