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版本
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

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