Merge branch 'dygraph' into dy/fix_data_format
This commit is contained in:
commit
7607b57024
|
@ -147,6 +147,7 @@ class MainWindow(QMainWindow, WindowMixin):
|
||||||
self.itemsToShapesbox = {}
|
self.itemsToShapesbox = {}
|
||||||
self.shapesToItemsbox = {}
|
self.shapesToItemsbox = {}
|
||||||
self.prevLabelText = getStr('tempLabel')
|
self.prevLabelText = getStr('tempLabel')
|
||||||
|
self.noLabelText = getStr('nullLabel')
|
||||||
self.model = 'paddle'
|
self.model = 'paddle'
|
||||||
self.PPreader = None
|
self.PPreader = None
|
||||||
self.autoSaveNum = 5
|
self.autoSaveNum = 5
|
||||||
|
@ -1020,7 +1021,7 @@ class MainWindow(QMainWindow, WindowMixin):
|
||||||
item.setText(str([(int(p.x()), int(p.y())) for p in shape.points]))
|
item.setText(str([(int(p.x()), int(p.y())) for p in shape.points]))
|
||||||
self.updateComboBox()
|
self.updateComboBox()
|
||||||
|
|
||||||
def updateComboBox(self): # TODO:貌似没用
|
def updateComboBox(self):
|
||||||
# Get the unique labels and add them to the Combobox.
|
# Get the unique labels and add them to the Combobox.
|
||||||
itemsTextList = [str(self.labelList.item(i).text()) for i in range(self.labelList.count())]
|
itemsTextList = [str(self.labelList.item(i).text()) for i in range(self.labelList.count())]
|
||||||
|
|
||||||
|
@ -1040,7 +1041,7 @@ class MainWindow(QMainWindow, WindowMixin):
|
||||||
return dict(label=s.label, # str
|
return dict(label=s.label, # str
|
||||||
line_color=s.line_color.getRgb(),
|
line_color=s.line_color.getRgb(),
|
||||||
fill_color=s.fill_color.getRgb(),
|
fill_color=s.fill_color.getRgb(),
|
||||||
points=[(p.x(), p.y()) for p in s.points], # QPonitF
|
points=[(int(p.x()), int(p.y())) for p in s.points], # QPonitF
|
||||||
# add chris
|
# add chris
|
||||||
difficult=s.difficult) # bool
|
difficult=s.difficult) # bool
|
||||||
|
|
||||||
|
@ -1069,7 +1070,7 @@ class MainWindow(QMainWindow, WindowMixin):
|
||||||
# print('Image:{0} -> Annotation:{1}'.format(self.filePath, annotationFilePath))
|
# print('Image:{0} -> Annotation:{1}'.format(self.filePath, annotationFilePath))
|
||||||
return True
|
return True
|
||||||
except:
|
except:
|
||||||
self.errorMessage(u'Error saving label data')
|
self.errorMessage(u'Error saving label data', u'Error saving label data')
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def copySelectedShape(self):
|
def copySelectedShape(self):
|
||||||
|
@ -1802,10 +1803,14 @@ class MainWindow(QMainWindow, WindowMixin):
|
||||||
result.insert(0, box)
|
result.insert(0, box)
|
||||||
print('result in reRec is ', result)
|
print('result in reRec is ', result)
|
||||||
self.result_dic.append(result)
|
self.result_dic.append(result)
|
||||||
if result[1][0] == shape.label:
|
else:
|
||||||
print('label no change')
|
print('Can not recognise the box')
|
||||||
else:
|
self.result_dic.append([box,(self.noLabelText,0)])
|
||||||
rec_flag += 1
|
|
||||||
|
if self.noLabelText == shape.label or result[1][0] == shape.label:
|
||||||
|
print('label no change')
|
||||||
|
else:
|
||||||
|
rec_flag += 1
|
||||||
|
|
||||||
if len(self.result_dic) > 0 and rec_flag > 0:
|
if len(self.result_dic) > 0 and rec_flag > 0:
|
||||||
self.saveFile(mode='Auto')
|
self.saveFile(mode='Auto')
|
||||||
|
@ -1836,9 +1841,14 @@ class MainWindow(QMainWindow, WindowMixin):
|
||||||
print('label no change')
|
print('label no change')
|
||||||
else:
|
else:
|
||||||
shape.label = result[1][0]
|
shape.label = result[1][0]
|
||||||
self.singleLabel(shape)
|
else:
|
||||||
self.setDirty()
|
print('Can not recognise the box')
|
||||||
print(box)
|
if self.noLabelText == shape.label:
|
||||||
|
print('label no change')
|
||||||
|
else:
|
||||||
|
shape.label = self.noLabelText
|
||||||
|
self.singleLabel(shape)
|
||||||
|
self.setDirty()
|
||||||
|
|
||||||
def autolcm(self):
|
def autolcm(self):
|
||||||
vbox = QVBoxLayout()
|
vbox = QVBoxLayout()
|
||||||
|
|
|
@ -45,7 +45,7 @@ class Canvas(QWidget):
|
||||||
CREATE, EDIT = list(range(2))
|
CREATE, EDIT = list(range(2))
|
||||||
_fill_drawing = False # draw shadows
|
_fill_drawing = False # draw shadows
|
||||||
|
|
||||||
epsilon = 11.0
|
epsilon = 5.0
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super(Canvas, self).__init__(*args, **kwargs)
|
super(Canvas, self).__init__(*args, **kwargs)
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -87,6 +87,7 @@ creatPolygon=四点标注
|
||||||
drawSquares=正方形标注
|
drawSquares=正方形标注
|
||||||
saveRec=保存识别结果
|
saveRec=保存识别结果
|
||||||
tempLabel=待识别
|
tempLabel=待识别
|
||||||
|
nullLabel=无法识别
|
||||||
steps=操作步骤
|
steps=操作步骤
|
||||||
choseModelLg=选择模型语言
|
choseModelLg=选择模型语言
|
||||||
cancel=取消
|
cancel=取消
|
||||||
|
|
|
@ -77,7 +77,7 @@ IR=Image Resize
|
||||||
autoRecognition=Auto Recognition
|
autoRecognition=Auto Recognition
|
||||||
reRecognition=Re-recognition
|
reRecognition=Re-recognition
|
||||||
mfile=File
|
mfile=File
|
||||||
medit=Eidt
|
medit=Edit
|
||||||
mview=View
|
mview=View
|
||||||
mhelp=Help
|
mhelp=Help
|
||||||
iconList=Icon List
|
iconList=Icon List
|
||||||
|
@ -87,6 +87,7 @@ creatPolygon=Create Quadrilateral
|
||||||
drawSquares=Draw Squares
|
drawSquares=Draw Squares
|
||||||
saveRec=Save Recognition Result
|
saveRec=Save Recognition Result
|
||||||
tempLabel=TEMPORARY
|
tempLabel=TEMPORARY
|
||||||
|
nullLabel=NULL
|
||||||
steps=Steps
|
steps=Steps
|
||||||
choseModelLg=Choose Model Language
|
choseModelLg=Choose Model Language
|
||||||
cancel=Cancel
|
cancel=Cancel
|
||||||
|
|
|
@ -32,7 +32,8 @@ PaddleOCR supports both dynamic graph and static graph programming paradigm
|
||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
<img src="doc/imgs_results/ch_ppocr_mobile_v2.0/test_add_91.jpg" width="800">
|
<img src="doc/imgs_results/ch_ppocr_mobile_v2.0/test_add_91.jpg" width="800">
|
||||||
<img src="doc/imgs_results/ch_ppocr_mobile_v2.0/00018069.jpg" width="800">
|
<img src="doc/imgs_results/multi_lang/img_01.jpg" width="800">
|
||||||
|
<img src="doc/imgs_results/multi_lang/img_02.jpg" width="800">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
The above pictures are the visualizations of the general ppocr_server model. For more effect pictures, please see [More visualizations](./doc/doc_en/visualization_en.md).
|
The above pictures are the visualizations of the general ppocr_server model. For more effect pictures, please see [More visualizations](./doc/doc_en/visualization_en.md).
|
||||||
|
|
|
@ -118,7 +118,6 @@ class ArgsParser(ArgumentParser):
|
||||||
return config
|
return config
|
||||||
|
|
||||||
def _set_language(self, type):
|
def _set_language(self, type):
|
||||||
print("type:", type)
|
|
||||||
lang = type[0]
|
lang = type[0]
|
||||||
assert (type), "please use -l or --language to choose language type"
|
assert (type), "please use -l or --language to choose language type"
|
||||||
assert(
|
assert(
|
||||||
|
|
|
@ -40,6 +40,7 @@ endif()
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
include_directories("${PADDLE_LIB}/paddle/fluid/inference")
|
include_directories("${PADDLE_LIB}/paddle/fluid/inference")
|
||||||
include_directories("${PADDLE_LIB}/paddle/include")
|
include_directories("${PADDLE_LIB}/paddle/include")
|
||||||
|
link_directories("${PADDLE_LIB}/paddle/lib")
|
||||||
link_directories("${PADDLE_LIB}/paddle/fluid/inference")
|
link_directories("${PADDLE_LIB}/paddle/fluid/inference")
|
||||||
find_package(OpenCV REQUIRED PATHS ${OPENCV_DIR}/build/ NO_DEFAULT_PATH)
|
find_package(OpenCV REQUIRED PATHS ${OPENCV_DIR}/build/ NO_DEFAULT_PATH)
|
||||||
|
|
||||||
|
@ -140,22 +141,22 @@ else()
|
||||||
endif ()
|
endif ()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Note: libpaddle_inference_api.so/a must put before libpaddle_fluid.so/a
|
# Note: libpaddle_inference_api.so/a must put before libpaddle_inference.so/a
|
||||||
if(WITH_STATIC_LIB)
|
if(WITH_STATIC_LIB)
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set(DEPS
|
set(DEPS
|
||||||
${PADDLE_LIB}/paddle/lib/paddle_fluid${CMAKE_STATIC_LIBRARY_SUFFIX})
|
${PADDLE_LIB}/paddle/lib/paddle_inference${CMAKE_STATIC_LIBRARY_SUFFIX})
|
||||||
else()
|
else()
|
||||||
set(DEPS
|
set(DEPS
|
||||||
${PADDLE_LIB}/paddle/lib/libpaddle_fluid${CMAKE_STATIC_LIBRARY_SUFFIX})
|
${PADDLE_LIB}/paddle/lib/libpaddle_inference${CMAKE_STATIC_LIBRARY_SUFFIX})
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set(DEPS
|
set(DEPS
|
||||||
${PADDLE_LIB}/paddle/lib/paddle_fluid${CMAKE_SHARED_LIBRARY_SUFFIX})
|
${PADDLE_LIB}/paddle/lib/paddle_inference${CMAKE_SHARED_LIBRARY_SUFFIX})
|
||||||
else()
|
else()
|
||||||
set(DEPS
|
set(DEPS
|
||||||
${PADDLE_LIB}/paddle/lib/libpaddle_fluid${CMAKE_SHARED_LIBRARY_SUFFIX})
|
${PADDLE_LIB}/paddle/lib/libpaddle_inference${CMAKE_SHARED_LIBRARY_SUFFIX})
|
||||||
endif()
|
endif()
|
||||||
endif(WITH_STATIC_LIB)
|
endif(WITH_STATIC_LIB)
|
||||||
|
|
||||||
|
|
|
@ -74,9 +74,10 @@ opencv3/
|
||||||
|
|
||||||
* 有2种方式获取Paddle预测库,下面进行详细介绍。
|
* 有2种方式获取Paddle预测库,下面进行详细介绍。
|
||||||
|
|
||||||
|
|
||||||
#### 1.2.1 直接下载安装
|
#### 1.2.1 直接下载安装
|
||||||
|
|
||||||
* [Paddle预测库官网](https://www.paddlepaddle.org.cn/documentation/docs/zh/develop/guides/05_inference_deployment/inference/build_and_install_lib_cn.html)上提供了不同cuda版本的Linux预测库,可以在官网查看并选择合适的预测库版本。
|
* [Paddle预测库官网](https://www.paddlepaddle.org.cn/documentation/docs/zh/advanced_guide/inference_deployment/inference/build_and_install_lib_cn.html)上提供了不同cuda版本的Linux预测库,可以在官网查看并选择合适的预测库版本(*建议选择paddle版本>=2.0.1版本的预测库* )。
|
||||||
|
|
||||||
* 下载之后使用下面的方法解压。
|
* 下载之后使用下面的方法解压。
|
||||||
|
|
||||||
|
@ -130,8 +131,6 @@ build/paddle_inference_install_dir/
|
||||||
其中`paddle`就是C++预测所需的Paddle库,`version.txt`中包含当前预测库的版本信息。
|
其中`paddle`就是C++预测所需的Paddle库,`version.txt`中包含当前预测库的版本信息。
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## 2 开始运行
|
## 2 开始运行
|
||||||
|
|
||||||
### 2.1 将模型导出为inference model
|
### 2.1 将模型导出为inference model
|
||||||
|
|
|
@ -91,8 +91,8 @@ tar -xf paddle_inference.tgz
|
||||||
Finally you can see the following files in the folder of `paddle_inference/`.
|
Finally you can see the following files in the folder of `paddle_inference/`.
|
||||||
|
|
||||||
#### 1.2.2 Compile from the source code
|
#### 1.2.2 Compile from the source code
|
||||||
* If you want to get the latest Paddle inference library features, you can download the latest code from Paddle github repository and compile the inference library from the source code.
|
* If you want to get the latest Paddle inference library features, you can download the latest code from Paddle github repository and compile the inference library from the source code. It is recommended to download the inference library with paddle version greater than or equal to 2.0.1.
|
||||||
* You can refer to [Paddle inference library] (https://www.paddlepaddle.org.cn/documentation/docs/en/develop/guides/05_inference_deployment/inference/build_and_install_lib_en.html) to get the Paddle source code from github, and then compile To generate the latest inference library. The method of using git to access the code is as follows.
|
* You can refer to [Paddle inference library] (https://www.paddlepaddle.org.cn/documentation/docs/en/advanced_guide/inference_deployment/inference/build_and_install_lib_en.html) to get the Paddle source code from github, and then compile To generate the latest inference library. The method of using git to access the code is as follows.
|
||||||
|
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
|
|
|
@ -113,7 +113,7 @@ python3 generate_multi_language_configs.py -l it \
|
||||||
| cyrillic_mobile_v2.0_rec | 斯拉夫字母 | [rec_cyrillic_lite_train.yml](../../configs/rec/multi_language/rec_cyrillic_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_train.tar) |
|
| cyrillic_mobile_v2.0_rec | 斯拉夫字母 | [rec_cyrillic_lite_train.yml](../../configs/rec/multi_language/rec_cyrillic_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_train.tar) |
|
||||||
| devanagari_mobile_v2.0_rec | 梵文字母 | [rec_devanagari_lite_train.yml](../../configs/rec/multi_language/rec_devanagari_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_train.tar) |
|
| devanagari_mobile_v2.0_rec | 梵文字母 | [rec_devanagari_lite_train.yml](../../configs/rec/multi_language/rec_devanagari_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_train.tar) |
|
||||||
|
|
||||||
更多支持语种请参考: [多语言模型](https://github.com/PaddlePaddle/PaddleOCR/blob/release/2.1/doc/doc_ch/multi_languages.md#%E8%AF%AD%E7%A7%8D%E7%BC%A9%E5%86%99)
|
更多支持语种请参考: [多语言模型](./multi_languages.md)
|
||||||
|
|
||||||
|
|
||||||
<a name="文本方向分类模型"></a>
|
<a name="文本方向分类模型"></a>
|
||||||
|
|
|
@ -134,7 +134,7 @@ paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --rec false
|
||||||
<a name="python_脚本运行"></a>
|
<a name="python_脚本运行"></a>
|
||||||
### 2.2 python 脚本运行
|
### 2.2 python 脚本运行
|
||||||
|
|
||||||
ppocr 也支持在python脚本中运行,便于嵌入到您自己的代码中:
|
ppocr 也支持在python脚本中运行,便于嵌入到您自己的代码中 :
|
||||||
|
|
||||||
* 整图预测(检测+识别)
|
* 整图预测(检测+识别)
|
||||||
|
|
||||||
|
@ -155,7 +155,7 @@ image = Image.open(img_path).convert('RGB')
|
||||||
boxes = [line[0] for line in result]
|
boxes = [line[0] for line in result]
|
||||||
txts = [line[1][0] for line in result]
|
txts = [line[1][0] for line in result]
|
||||||
scores = [line[1][1] for line in result]
|
scores = [line[1][1] for line in result]
|
||||||
im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/korean.ttf')
|
im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/fonts/korean.ttf')
|
||||||
im_show = Image.fromarray(im_show)
|
im_show = Image.fromarray(im_show)
|
||||||
im_show.save('result.jpg')
|
im_show.save('result.jpg')
|
||||||
```
|
```
|
||||||
|
@ -240,7 +240,7 @@ ppocr 支持使用自己的数据进行自定义训练或finetune, 其中识别
|
||||||
|德文|german|german|
|
|德文|german|german|
|
||||||
|日文|japan|japan|
|
|日文|japan|japan|
|
||||||
|韩文|korean|korean|
|
|韩文|korean|korean|
|
||||||
|中文繁体|chinese traditional |ch_tra|
|
|中文繁体|chinese traditional |chinese_cht|
|
||||||
|意大利文| Italian |it|
|
|意大利文| Italian |it|
|
||||||
|西班牙文|Spanish |es|
|
|西班牙文|Spanish |es|
|
||||||
|葡萄牙文| Portuguese|pt|
|
|葡萄牙文| Portuguese|pt|
|
||||||
|
@ -259,10 +259,9 @@ ppocr 支持使用自己的数据进行自定义训练或finetune, 其中识别
|
||||||
|乌克兰文|Ukranian|uk|
|
|乌克兰文|Ukranian|uk|
|
||||||
|白俄罗斯文|Belarusian|be|
|
|白俄罗斯文|Belarusian|be|
|
||||||
|泰卢固文|Telugu |te|
|
|泰卢固文|Telugu |te|
|
||||||
|卡纳达文|Kannada |kn|
|
|
||||||
|泰米尔文|Tamil |ta|
|
|泰米尔文|Tamil |ta|
|
||||||
|南非荷兰文 |Afrikaans |af|
|
|南非荷兰文 |Afrikaans |af|
|
||||||
|阿塞拜疆文 |Azerbaijani |az|
|
|阿塞拜疆文 |Azerbaijani |az|
|
||||||
|波斯尼亚文|Bosnian|bs|
|
|波斯尼亚文|Bosnian|bs|
|
||||||
|捷克文|Czech|cs|
|
|捷克文|Czech|cs|
|
||||||
|威尔士文 |Welsh |cy|
|
|威尔士文 |Welsh |cy|
|
||||||
|
|
|
@ -111,7 +111,7 @@ python3 generate_multi_language_configs.py -l it \
|
||||||
| cyrillic_mobile_v2.0_rec | Lightweight model for cyrillic recognition | [rec_cyrillic_lite_train.yml](../../configs/rec/multi_language/rec_cyrillic_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_train.tar) |
|
| cyrillic_mobile_v2.0_rec | Lightweight model for cyrillic recognition | [rec_cyrillic_lite_train.yml](../../configs/rec/multi_language/rec_cyrillic_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/cyrillic_ppocr_mobile_v2.0_rec_train.tar) |
|
||||||
| devanagari_mobile_v2.0_rec | Lightweight model for devanagari recognition | [rec_devanagari_lite_train.yml](../../configs/rec/multi_language/rec_devanagari_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_train.tar) |
|
| devanagari_mobile_v2.0_rec | Lightweight model for devanagari recognition | [rec_devanagari_lite_train.yml](../../configs/rec/multi_language/rec_devanagari_lite_train.yml) |2.6M|[推理模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_infer.tar) / [训练模型](https://paddleocr.bj.bcebos.com/dygraph_v2.0/multilingual/devanagari_ppocr_mobile_v2.0_rec_train.tar) |
|
||||||
|
|
||||||
For more supported languages, please refer to : [Multi-language model](https://github.com/PaddlePaddle/PaddleOCR/blob/release/2.1/doc/doc_en/multi_languages_en.md#4-support-languages-and-abbreviations)
|
For more supported languages, please refer to : [Multi-language model](./multi_languages_en.md)
|
||||||
|
|
||||||
|
|
||||||
<a name="Angle"></a>
|
<a name="Angle"></a>
|
||||||
|
|
|
@ -153,7 +153,7 @@ image = Image.open(img_path).convert('RGB')
|
||||||
boxes = [line[0] for line in result]
|
boxes = [line[0] for line in result]
|
||||||
txts = [line[1][0] for line in result]
|
txts = [line[1][0] for line in result]
|
||||||
scores = [line[1][1] for line in result]
|
scores = [line[1][1] for line in result]
|
||||||
im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/korean.ttf')
|
im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/fonts/korean.ttf')
|
||||||
im_show = Image.fromarray(im_show)
|
im_show = Image.fromarray(im_show)
|
||||||
im_show.save('result.jpg')
|
im_show.save('result.jpg')
|
||||||
```
|
```
|
||||||
|
@ -232,7 +232,7 @@ For functions such as data annotation, you can read the complete [Document Tutor
|
||||||
|german|german|
|
|german|german|
|
||||||
|japan|japan|
|
|japan|japan|
|
||||||
|korean|korean|
|
|korean|korean|
|
||||||
|chinese traditional |ch_tra|
|
|chinese traditional |chinese_cht|
|
||||||
| Italian |it|
|
| Italian |it|
|
||||||
|Spanish |es|
|
|Spanish |es|
|
||||||
| Portuguese|pt|
|
| Portuguese|pt|
|
||||||
|
@ -251,7 +251,6 @@ For functions such as data annotation, you can read the complete [Document Tutor
|
||||||
|Ukranian|uk|
|
|Ukranian|uk|
|
||||||
|Belarusian|be|
|
|Belarusian|be|
|
||||||
|Telugu |te|
|
|Telugu |te|
|
||||||
|Kannada |kn|
|
|
||||||
|Tamil |ta|
|
|Tamil |ta|
|
||||||
|Afrikaans |af|
|
|Afrikaans |af|
|
||||||
|Azerbaijani |az|
|
|Azerbaijani |az|
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 107 KiB |
Binary file not shown.
After Width: | Height: | Size: 231 KiB |
14
paddleocr.py
14
paddleocr.py
|
@ -30,6 +30,7 @@ from ppocr.utils.logging import get_logger
|
||||||
|
|
||||||
logger = get_logger()
|
logger = get_logger()
|
||||||
from ppocr.utils.utility import check_and_read_gif, get_image_file_list
|
from ppocr.utils.utility import check_and_read_gif, get_image_file_list
|
||||||
|
from tools.infer.utility import draw_ocr
|
||||||
|
|
||||||
__all__ = ['PaddleOCR']
|
__all__ = ['PaddleOCR']
|
||||||
|
|
||||||
|
@ -117,7 +118,7 @@ model_urls = {
|
||||||
}
|
}
|
||||||
|
|
||||||
SUPPORT_DET_MODEL = ['DB']
|
SUPPORT_DET_MODEL = ['DB']
|
||||||
VERSION = 2.1
|
VERSION = '2.1'
|
||||||
SUPPORT_REC_MODEL = ['CRNN']
|
SUPPORT_REC_MODEL = ['CRNN']
|
||||||
BASE_DIR = os.path.expanduser("~/.paddleocr/")
|
BASE_DIR = os.path.expanduser("~/.paddleocr/")
|
||||||
|
|
||||||
|
@ -315,14 +316,13 @@ class PaddleOCR(predict_system.TextSystem):
|
||||||
|
|
||||||
# init model dir
|
# init model dir
|
||||||
if postprocess_params.det_model_dir is None:
|
if postprocess_params.det_model_dir is None:
|
||||||
postprocess_params.det_model_dir = os.path.join(
|
postprocess_params.det_model_dir = os.path.join(BASE_DIR, VERSION,
|
||||||
BASE_DIR, '{}/det/{}'.format(VERSION, det_lang))
|
'det', det_lang)
|
||||||
if postprocess_params.rec_model_dir is None:
|
if postprocess_params.rec_model_dir is None:
|
||||||
postprocess_params.rec_model_dir = os.path.join(
|
postprocess_params.rec_model_dir = os.path.join(BASE_DIR, VERSION,
|
||||||
BASE_DIR, '{}/rec/{}'.format(VERSION, lang))
|
'rec', lang)
|
||||||
if postprocess_params.cls_model_dir is None:
|
if postprocess_params.cls_model_dir is None:
|
||||||
postprocess_params.cls_model_dir = os.path.join(
|
postprocess_params.cls_model_dir = os.path.join(BASE_DIR, 'cls')
|
||||||
BASE_DIR, '{}/cls'.format(VERSION))
|
|
||||||
print(postprocess_params)
|
print(postprocess_params)
|
||||||
# download model
|
# download model
|
||||||
maybe_download(postprocess_params.det_model_dir,
|
maybe_download(postprocess_params.det_model_dir,
|
||||||
|
|
|
@ -96,7 +96,7 @@ class BaseRecLabelEncode(object):
|
||||||
'ch', 'en', 'EN_symbol', 'french', 'german', 'japan', 'korean',
|
'ch', 'en', 'EN_symbol', 'french', 'german', 'japan', 'korean',
|
||||||
'EN', 'it', 'xi', 'pu', 'ru', 'ar', 'ta', 'ug', 'fa', 'ur', 'rs',
|
'EN', 'it', 'xi', 'pu', 'ru', 'ar', 'ta', 'ug', 'fa', 'ur', 'rs',
|
||||||
'oc', 'rsc', 'bg', 'uk', 'be', 'te', 'ka', 'chinese_cht', 'hi',
|
'oc', 'rsc', 'bg', 'uk', 'be', 'te', 'ka', 'chinese_cht', 'hi',
|
||||||
'mr', 'ne'
|
'mr', 'ne', 'latin', 'arabic', 'cyrillic', 'devanagari'
|
||||||
]
|
]
|
||||||
assert character_type in support_character_type, "Only {} are supported now but get {}".format(
|
assert character_type in support_character_type, "Only {} are supported now but get {}".format(
|
||||||
support_character_type, character_type)
|
support_character_type, character_type)
|
||||||
|
|
|
@ -28,7 +28,7 @@ class BaseRecLabelDecode(object):
|
||||||
'ch', 'en', 'EN_symbol', 'french', 'german', 'japan', 'korean',
|
'ch', 'en', 'EN_symbol', 'french', 'german', 'japan', 'korean',
|
||||||
'it', 'xi', 'pu', 'ru', 'ar', 'ta', 'ug', 'fa', 'ur', 'rs', 'oc',
|
'it', 'xi', 'pu', 'ru', 'ar', 'ta', 'ug', 'fa', 'ur', 'rs', 'oc',
|
||||||
'rsc', 'bg', 'uk', 'be', 'te', 'ka', 'chinese_cht', 'hi', 'mr',
|
'rsc', 'bg', 'uk', 'be', 'te', 'ka', 'chinese_cht', 'hi', 'mr',
|
||||||
'ne', 'EN'
|
'ne', 'EN', 'latin', 'arabic', 'cyrillic', 'devanagari'
|
||||||
]
|
]
|
||||||
assert character_type in support_character_type, "Only {} are supported now but get {}".format(
|
assert character_type in support_character_type, "Only {} are supported now but get {}".format(
|
||||||
support_character_type, character_type)
|
support_character_type, character_type)
|
||||||
|
|
Loading…
Reference in New Issue