model_init.py 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. import os
  2. import torch
  3. from loguru import logger
  4. from magic_pdf.config.constants import MODEL_NAME
  5. from magic_pdf.model.model_list import AtomicModel
  6. from magic_pdf.model.sub_modules.language_detection.yolov11.YOLOv11 import YOLOv11LangDetModel
  7. from magic_pdf.model.sub_modules.layout.doclayout_yolo.DocLayoutYOLO import DocLayoutYOLOModel
  8. from magic_pdf.model.sub_modules.layout.layoutlmv3.model_init import Layoutlmv3_Predictor
  9. from magic_pdf.model.sub_modules.mfd.yolov8.YOLOv8 import YOLOv8MFDModel
  10. from magic_pdf.model.sub_modules.mfr.unimernet.Unimernet import UnimernetModel
  11. try:
  12. from magic_pdf_ascend_plugin.libs.license_verifier import load_license, LicenseFormatError, LicenseSignatureError, LicenseExpiredError
  13. from magic_pdf_ascend_plugin.model_plugin.ocr.paddleocr.ppocr_273_npu import ModifiedPaddleOCR
  14. from magic_pdf_ascend_plugin.model_plugin.table.rapidtable.rapid_table_npu import RapidTableModel
  15. license_key = load_license()
  16. logger.info(f'Using Ascend Plugin Success, License id is {license_key["payload"]["id"]},'
  17. f' License expired at {license_key["payload"]["date"]["end_date"]}')
  18. except Exception as e:
  19. if isinstance(e, ImportError):
  20. pass
  21. elif isinstance(e, LicenseFormatError):
  22. logger.error("Ascend Plugin: Invalid license format. Please check the license file.")
  23. elif isinstance(e, LicenseSignatureError):
  24. logger.error("Ascend Plugin: Invalid signature. The license may be tampered with.")
  25. elif isinstance(e, LicenseExpiredError):
  26. logger.error("Ascend Plugin: License has expired. Please renew your license.")
  27. elif isinstance(e, FileNotFoundError):
  28. logger.error("Ascend Plugin: Not found License file.")
  29. else:
  30. logger.error(f"Ascend Plugin: {e}")
  31. from magic_pdf.model.sub_modules.ocr.paddleocr.ppocr_273_mod import ModifiedPaddleOCR
  32. # from magic_pdf.model.sub_modules.ocr.paddleocr.ppocr_291_mod import ModifiedPaddleOCR
  33. from magic_pdf.model.sub_modules.table.rapidtable.rapid_table import RapidTableModel
  34. from magic_pdf.model.sub_modules.table.structeqtable.struct_eqtable import StructTableModel
  35. from magic_pdf.model.sub_modules.table.tablemaster.tablemaster_paddle import TableMasterPaddleModel
  36. def table_model_init(table_model_type, model_path, max_time, _device_='cpu', ocr_engine=None, table_sub_model_name=None):
  37. if table_model_type == MODEL_NAME.STRUCT_EQTABLE:
  38. table_model = StructTableModel(model_path, max_new_tokens=2048, max_time=max_time)
  39. elif table_model_type == MODEL_NAME.TABLE_MASTER:
  40. config = {
  41. 'model_dir': model_path,
  42. 'device': _device_
  43. }
  44. table_model = TableMasterPaddleModel(config)
  45. elif table_model_type == MODEL_NAME.RAPID_TABLE:
  46. table_model = RapidTableModel(ocr_engine, table_sub_model_name)
  47. else:
  48. logger.error('table model type not allow')
  49. exit(1)
  50. return table_model
  51. def mfd_model_init(weight, device='cpu'):
  52. if str(device).startswith("npu"):
  53. device = torch.device(device)
  54. mfd_model = YOLOv8MFDModel(weight, device)
  55. return mfd_model
  56. def mfr_model_init(weight_dir, cfg_path, device='cpu'):
  57. mfr_model = UnimernetModel(weight_dir, cfg_path, device)
  58. return mfr_model
  59. def layout_model_init(weight, config_file, device):
  60. model = Layoutlmv3_Predictor(weight, config_file, device)
  61. return model
  62. def doclayout_yolo_model_init(weight, device='cpu'):
  63. if str(device).startswith("npu"):
  64. device = torch.device(device)
  65. model = DocLayoutYOLOModel(weight, device)
  66. return model
  67. def langdetect_model_init(langdetect_model_weight, device='cpu'):
  68. if str(device).startswith("npu"):
  69. device = torch.device(device)
  70. model = YOLOv11LangDetModel(langdetect_model_weight, device)
  71. return model
  72. def ocr_model_init(show_log: bool = False,
  73. det_db_box_thresh=0.3,
  74. lang=None,
  75. use_dilation=True,
  76. det_db_unclip_ratio=1.8,
  77. ):
  78. if lang is not None and lang != '':
  79. model = ModifiedPaddleOCR(
  80. show_log=show_log,
  81. det_db_box_thresh=det_db_box_thresh,
  82. lang=lang,
  83. use_dilation=use_dilation,
  84. det_db_unclip_ratio=det_db_unclip_ratio,
  85. )
  86. else:
  87. model = ModifiedPaddleOCR(
  88. show_log=show_log,
  89. det_db_box_thresh=det_db_box_thresh,
  90. use_dilation=use_dilation,
  91. det_db_unclip_ratio=det_db_unclip_ratio,
  92. )
  93. return model
  94. class AtomModelSingleton:
  95. _instance = None
  96. _models = {}
  97. def __new__(cls, *args, **kwargs):
  98. if cls._instance is None:
  99. cls._instance = super().__new__(cls)
  100. return cls._instance
  101. def get_atom_model(self, atom_model_name: str, **kwargs):
  102. lang = kwargs.get('lang', None)
  103. layout_model_name = kwargs.get('layout_model_name', None)
  104. table_model_name = kwargs.get('table_model_name', None)
  105. if atom_model_name in [AtomicModel.OCR]:
  106. key = (atom_model_name, lang)
  107. elif atom_model_name in [AtomicModel.Layout]:
  108. key = (atom_model_name, layout_model_name)
  109. elif atom_model_name in [AtomicModel.Table]:
  110. key = (atom_model_name, table_model_name)
  111. else:
  112. key = atom_model_name
  113. if key not in self._models:
  114. self._models[key] = atom_model_init(model_name=atom_model_name, **kwargs)
  115. return self._models[key]
  116. def atom_model_init(model_name: str, **kwargs):
  117. atom_model = None
  118. if model_name == AtomicModel.Layout:
  119. if kwargs.get('layout_model_name') == MODEL_NAME.LAYOUTLMv3:
  120. atom_model = layout_model_init(
  121. kwargs.get('layout_weights'),
  122. kwargs.get('layout_config_file'),
  123. kwargs.get('device')
  124. )
  125. elif kwargs.get('layout_model_name') == MODEL_NAME.DocLayout_YOLO:
  126. atom_model = doclayout_yolo_model_init(
  127. kwargs.get('doclayout_yolo_weights'),
  128. kwargs.get('device')
  129. )
  130. else:
  131. logger.error('layout model name not allow')
  132. exit(1)
  133. elif model_name == AtomicModel.MFD:
  134. atom_model = mfd_model_init(
  135. kwargs.get('mfd_weights'),
  136. kwargs.get('device')
  137. )
  138. elif model_name == AtomicModel.MFR:
  139. atom_model = mfr_model_init(
  140. kwargs.get('mfr_weight_dir'),
  141. kwargs.get('mfr_cfg_path'),
  142. kwargs.get('device')
  143. )
  144. elif model_name == AtomicModel.OCR:
  145. atom_model = ocr_model_init(
  146. kwargs.get('ocr_show_log'),
  147. kwargs.get('det_db_box_thresh'),
  148. kwargs.get('lang'),
  149. )
  150. elif model_name == AtomicModel.Table:
  151. atom_model = table_model_init(
  152. kwargs.get('table_model_name'),
  153. kwargs.get('table_model_path'),
  154. kwargs.get('table_max_time'),
  155. kwargs.get('device'),
  156. kwargs.get('ocr_engine'),
  157. kwargs.get('table_sub_model_name')
  158. )
  159. elif model_name == AtomicModel.LangDetect:
  160. if kwargs.get('langdetect_model_name') == MODEL_NAME.YOLO_V11_LangDetect:
  161. atom_model = langdetect_model_init(
  162. kwargs.get('langdetect_model_weight'),
  163. kwargs.get('device')
  164. )
  165. else:
  166. logger.error('langdetect model name not allow')
  167. exit(1)
  168. else:
  169. logger.error('model name not allow')
  170. exit(1)
  171. if atom_model is None:
  172. logger.error('model init failed')
  173. exit(1)
  174. else:
  175. return atom_model