endoreg-db 0.5.2__py3-none-any.whl → 0.6.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of endoreg-db might be problematic. Click here for more details.

Files changed (320) hide show
  1. endoreg_db/admin.py +90 -1
  2. endoreg_db/urls.py +173 -0
  3. endoreg_db/views.py +0 -3
  4. endoreg_db-0.6.0.dist-info/METADATA +151 -0
  5. endoreg_db-0.6.0.dist-info/RECORD +11 -0
  6. {endoreg_db-0.5.2.dist-info → endoreg_db-0.6.0.dist-info}/WHEEL +2 -1
  7. endoreg_db-0.6.0.dist-info/top_level.txt +1 -0
  8. endoreg_db/data/__init__.py +0 -72
  9. endoreg_db/data/active_model/data.yaml +0 -3
  10. endoreg_db/data/agl_service/data.yaml +0 -19
  11. endoreg_db/data/case_template/rule/00_patient_lab_sample_add_default_value.yaml +0 -167
  12. endoreg_db/data/case_template/rule/01_patient-set-age.yaml +0 -8
  13. endoreg_db/data/case_template/rule/01_patient-set-gender.yaml +0 -9
  14. endoreg_db/data/case_template/rule/11_create_patient_lab_sample.yaml +0 -23
  15. endoreg_db/data/case_template/rule/12_create-patient_medication-anticoagulation.yaml +0 -19
  16. endoreg_db/data/case_template/rule/13_create-patient_medication_schedule-anticoagulation.yaml +0 -19
  17. endoreg_db/data/case_template/rule/19_create_patient.yaml +0 -17
  18. endoreg_db/data/case_template/rule_type/base_types.yaml +0 -35
  19. endoreg_db/data/case_template/rule_value/.init +0 -0
  20. endoreg_db/data/case_template/rule_value_type/base_types.yaml +0 -59
  21. endoreg_db/data/case_template/template/base.yaml +0 -8
  22. endoreg_db/data/case_template/template_type/pre_endoscopy.yaml +0 -3
  23. endoreg_db/data/case_template/tmp/_rule_value +0 -13
  24. endoreg_db/data/case_template/tmp/rule/01_atrial_fibrillation.yaml +0 -21
  25. endoreg_db/data/case_template/tmp/rule/02_create_object.yaml +0 -10
  26. endoreg_db/data/case_template/tmp/template/atrial_fibrillation_low_risk.yaml +0 -7
  27. endoreg_db/data/center/data.yaml +0 -60
  28. endoreg_db/data/center_resource/green_endoscopy_dashboard_CenterResource.yaml +0 -144
  29. endoreg_db/data/center_waste/green_endoscopy_dashboard_CenterWaste.yaml +0 -48
  30. endoreg_db/data/disease/cardiovascular.yaml +0 -37
  31. endoreg_db/data/disease/hepatology.yaml +0 -5
  32. endoreg_db/data/disease/misc.yaml +0 -6
  33. endoreg_db/data/disease/renal.yaml +0 -5
  34. endoreg_db/data/disease_classification/chronic_kidney_disease.yaml +0 -6
  35. endoreg_db/data/disease_classification/coronary_vessel_disease.yaml +0 -6
  36. endoreg_db/data/disease_classification_choice/chronic_kidney_disease.yaml +0 -41
  37. endoreg_db/data/disease_classification_choice/coronary_vessel_disease.yaml +0 -20
  38. endoreg_db/data/distribution/date/patient.yaml +0 -7
  39. endoreg_db/data/distribution/multiple_categorical/.init +0 -0
  40. endoreg_db/data/distribution/numeric/.init +0 -0
  41. endoreg_db/data/distribution/single_categorical/patient.yaml +0 -7
  42. endoreg_db/data/emission_factor/green_endoscopy_dashboard_EmissionFactor.yaml +0 -132
  43. endoreg_db/data/endoscope_type/data.yaml +0 -11
  44. endoreg_db/data/endoscopy_processor/data.yaml +0 -47
  45. endoreg_db/data/event/cardiology.yaml +0 -28
  46. endoreg_db/data/event/neurology.yaml +0 -14
  47. endoreg_db/data/event/surgery.yaml +0 -13
  48. endoreg_db/data/event/thrombembolism.yaml +0 -20
  49. endoreg_db/data/examination/examinations/data.yaml +0 -66
  50. endoreg_db/data/examination/time/data.yaml +0 -48
  51. endoreg_db/data/examination/time-type/data.yaml +0 -8
  52. endoreg_db/data/examination/type/data.yaml +0 -5
  53. endoreg_db/data/gender/data.yaml +0 -18
  54. endoreg_db/data/information_source/data.yaml +0 -30
  55. endoreg_db/data/information_source/medication.yaml +0 -6
  56. endoreg_db/data/lab_value/cardiac_enzymes.yaml +0 -31
  57. endoreg_db/data/lab_value/coagulation.yaml +0 -49
  58. endoreg_db/data/lab_value/electrolytes.yaml +0 -190
  59. endoreg_db/data/lab_value/gastrointestinal_function.yaml +0 -121
  60. endoreg_db/data/lab_value/hematology.yaml +0 -169
  61. endoreg_db/data/lab_value/hormones.yaml +0 -53
  62. endoreg_db/data/lab_value/lipids.yaml +0 -44
  63. endoreg_db/data/lab_value/misc.yaml +0 -30
  64. endoreg_db/data/lab_value/renal_function.yaml +0 -11
  65. endoreg_db/data/label/label/data.yaml +0 -62
  66. endoreg_db/data/label/label-set/data.yaml +0 -18
  67. endoreg_db/data/label/label-type/data.yaml +0 -7
  68. endoreg_db/data/log_type/data.yaml +0 -57
  69. endoreg_db/data/material/material.yaml +0 -91
  70. endoreg_db/data/medication/anticoagulation.yaml +0 -65
  71. endoreg_db/data/medication/tah.yaml +0 -70
  72. endoreg_db/data/medication_indication/anticoagulation.yaml +0 -120
  73. endoreg_db/data/medication_indication_type/data.yaml +0 -11
  74. endoreg_db/data/medication_indication_type/thrombembolism.yaml +0 -41
  75. endoreg_db/data/medication_intake_time/base.yaml +0 -31
  76. endoreg_db/data/medication_schedule/apixaban.yaml +0 -95
  77. endoreg_db/data/medication_schedule/ass.yaml +0 -12
  78. endoreg_db/data/medication_schedule/enoxaparin.yaml +0 -26
  79. endoreg_db/data/model_type/data.yaml +0 -7
  80. endoreg_db/data/network_device/data.yaml +0 -29
  81. endoreg_db/data/network_device_type/data.yaml +0 -12
  82. endoreg_db/data/patient_lab_sample_type/generic.yaml +0 -6
  83. endoreg_db/data/pdf_type/data.yaml +0 -28
  84. endoreg_db/data/product/green_endoscopy_dashboard_Product.yaml +0 -66
  85. endoreg_db/data/product_group/green_endoscopy_dashboard_ProductGroup.yaml +0 -33
  86. endoreg_db/data/product_material/green_endoscopy_dashboard_ProductMaterial.yaml +0 -308
  87. endoreg_db/data/product_weight/green_endoscopy_dashboard_ProductWeight.yaml +0 -88
  88. endoreg_db/data/profession/data.yaml +0 -70
  89. endoreg_db/data/reference_product/green_endoscopy_dashboard_ReferenceProduct.yaml +0 -55
  90. endoreg_db/data/report_reader_flag/ukw-examination-generic.yaml +0 -26
  91. endoreg_db/data/report_reader_flag/ukw-histology-generic.yaml +0 -19
  92. endoreg_db/data/resource/green_endoscopy_dashboard_Resource.yaml +0 -15
  93. endoreg_db/data/tmp/chronic_kidney_disease.yaml +0 -0
  94. endoreg_db/data/tmp/congestive_heart_failure.yaml +0 -0
  95. endoreg_db/data/transport_route/green_endoscopy_dashboard_TransportRoute.yaml +0 -12
  96. endoreg_db/data/unit/concentration.yaml +0 -92
  97. endoreg_db/data/unit/data.yaml +0 -17
  98. endoreg_db/data/unit/length.yaml +0 -31
  99. endoreg_db/data/unit/misc.yaml +0 -20
  100. endoreg_db/data/unit/rate.yaml +0 -6
  101. endoreg_db/data/unit/time.yaml +0 -13
  102. endoreg_db/data/unit/volume.yaml +0 -35
  103. endoreg_db/data/unit/weight.yaml +0 -38
  104. endoreg_db/data/waste/data.yaml +0 -12
  105. endoreg_db/forms/__init__.py +0 -3
  106. endoreg_db/forms/questionnaires/__init__.py +0 -1
  107. endoreg_db/forms/questionnaires/tto_questionnaire.py +0 -23
  108. endoreg_db/forms/settings/__init__.py +0 -8
  109. endoreg_db/forms/unit.py +0 -6
  110. endoreg_db/management/commands/_load_model_template.py +0 -41
  111. endoreg_db/management/commands/delete_all.py +0 -18
  112. endoreg_db/management/commands/delete_legacy_images.py +0 -19
  113. endoreg_db/management/commands/delete_legacy_videos.py +0 -17
  114. endoreg_db/management/commands/extract_legacy_video_frames.py +0 -18
  115. endoreg_db/management/commands/fetch_legacy_image_dataset.py +0 -32
  116. endoreg_db/management/commands/fix_auth_permission.py +0 -20
  117. endoreg_db/management/commands/import_legacy_images.py +0 -94
  118. endoreg_db/management/commands/import_legacy_videos.py +0 -76
  119. endoreg_db/management/commands/load_active_model_data.py +0 -45
  120. endoreg_db/management/commands/load_ai_model_data.py +0 -45
  121. endoreg_db/management/commands/load_base_db_data.py +0 -136
  122. endoreg_db/management/commands/load_center_data.py +0 -43
  123. endoreg_db/management/commands/load_disease_classification_choices_data.py +0 -41
  124. endoreg_db/management/commands/load_disease_classification_data.py +0 -41
  125. endoreg_db/management/commands/load_disease_data.py +0 -40
  126. endoreg_db/management/commands/load_distribution_data.py +0 -66
  127. endoreg_db/management/commands/load_endoscope_type_data.py +0 -45
  128. endoreg_db/management/commands/load_endoscopy_processor_data.py +0 -45
  129. endoreg_db/management/commands/load_event_data.py +0 -41
  130. endoreg_db/management/commands/load_examination_data.py +0 -75
  131. endoreg_db/management/commands/load_g_play_data.py +0 -113
  132. endoreg_db/management/commands/load_gender_data.py +0 -44
  133. endoreg_db/management/commands/load_green_endoscopy_wuerzburg_data.py +0 -133
  134. endoreg_db/management/commands/load_information_source.py +0 -45
  135. endoreg_db/management/commands/load_lab_value_data.py +0 -50
  136. endoreg_db/management/commands/load_label_data.py +0 -67
  137. endoreg_db/management/commands/load_logging_data.py +0 -39
  138. endoreg_db/management/commands/load_medication_data.py +0 -41
  139. endoreg_db/management/commands/load_medication_indication_data.py +0 -63
  140. endoreg_db/management/commands/load_medication_indication_type_data.py +0 -41
  141. endoreg_db/management/commands/load_medication_intake_time_data.py +0 -41
  142. endoreg_db/management/commands/load_medication_schedule_data.py +0 -55
  143. endoreg_db/management/commands/load_network_data.py +0 -57
  144. endoreg_db/management/commands/load_pdf_type_data.py +0 -61
  145. endoreg_db/management/commands/load_profession_data.py +0 -44
  146. endoreg_db/management/commands/load_report_reader_flag.py +0 -46
  147. endoreg_db/management/commands/load_unit_data.py +0 -46
  148. endoreg_db/management/commands/load_user_groups.py +0 -28
  149. endoreg_db/management/commands/register_ai_model.py +0 -64
  150. endoreg_db/management/commands/reset_celery_schedule.py +0 -9
  151. endoreg_db/migrations/0001_initial.py +0 -1567
  152. endoreg_db/migrations/0002_anonymizedimagelabel_anonymousimageannotation_and_more.py +0 -55
  153. endoreg_db/migrations/0003_anonymousimageannotation_original_image_url_and_more.py +0 -39
  154. endoreg_db/migrations/0004_alter_rawpdffile_file.py +0 -20
  155. endoreg_db/migrations/0005_uploadedfile_alter_rawpdffile_file_anonymizedfile.py +0 -40
  156. endoreg_db/migrations/0006_alter_rawpdffile_file.py +0 -20
  157. endoreg_db/migrations/0007_networkdevicelogentry_datetime_and_more.py +0 -43
  158. endoreg_db/migrations/0008_networkdevicelogentry_aglnet_ip_and_more.py +0 -28
  159. endoreg_db/migrations/0009_alter_networkdevicelogentry_vpn_service_status.py +0 -18
  160. endoreg_db/migrations/0010_remove_networkdevicelogentry_hostname.py +0 -17
  161. endoreg_db/migrations/__init__.py +0 -0
  162. endoreg_db/models/__init__.py +0 -73
  163. endoreg_db/models/ai_model/__init__.py +0 -3
  164. endoreg_db/models/ai_model/active_model.py +0 -9
  165. endoreg_db/models/ai_model/model_meta.py +0 -24
  166. endoreg_db/models/ai_model/model_type.py +0 -26
  167. endoreg_db/models/ai_model/utils.py +0 -8
  168. endoreg_db/models/annotation/__init__.py +0 -3
  169. endoreg_db/models/annotation/anonymized_image_annotation.py +0 -60
  170. endoreg_db/models/annotation/binary_classification_annotation_task.py +0 -80
  171. endoreg_db/models/annotation/image_classification.py +0 -27
  172. endoreg_db/models/case_template/__init__.py +0 -6
  173. endoreg_db/models/case_template/case_template.py +0 -81
  174. endoreg_db/models/case_template/case_template_rule.py +0 -276
  175. endoreg_db/models/case_template/case_template_rule_value.py +0 -73
  176. endoreg_db/models/case_template/case_template_type.py +0 -28
  177. endoreg_db/models/center/__init__.py +0 -4
  178. endoreg_db/models/center/center.py +0 -25
  179. endoreg_db/models/center/center_product.py +0 -34
  180. endoreg_db/models/center/center_resource.py +0 -19
  181. endoreg_db/models/center/center_waste.py +0 -11
  182. endoreg_db/models/data_file/__init__.py +0 -6
  183. endoreg_db/models/data_file/base_classes/__init__.py +0 -2
  184. endoreg_db/models/data_file/base_classes/abstract_frame.py +0 -51
  185. endoreg_db/models/data_file/base_classes/abstract_video.py +0 -201
  186. endoreg_db/models/data_file/frame.py +0 -45
  187. endoreg_db/models/data_file/import_classes/__init__.py +0 -32
  188. endoreg_db/models/data_file/import_classes/processing_functions/__init__.py +0 -35
  189. endoreg_db/models/data_file/import_classes/processing_functions/pdf.py +0 -28
  190. endoreg_db/models/data_file/import_classes/processing_functions/video.py +0 -260
  191. endoreg_db/models/data_file/import_classes/raw_pdf.py +0 -188
  192. endoreg_db/models/data_file/import_classes/raw_video.py +0 -343
  193. endoreg_db/models/data_file/metadata/__init__.py +0 -3
  194. endoreg_db/models/data_file/metadata/pdf_meta.py +0 -70
  195. endoreg_db/models/data_file/metadata/sensitive_meta.py +0 -31
  196. endoreg_db/models/data_file/metadata/video_meta.py +0 -133
  197. endoreg_db/models/data_file/report_file.py +0 -89
  198. endoreg_db/models/data_file/video/__init__.py +0 -7
  199. endoreg_db/models/data_file/video/import_meta.py +0 -25
  200. endoreg_db/models/data_file/video/video.py +0 -25
  201. endoreg_db/models/data_file/video_segment.py +0 -107
  202. endoreg_db/models/disease.py +0 -56
  203. endoreg_db/models/emission/__init__.py +0 -1
  204. endoreg_db/models/emission/emission_factor.py +0 -20
  205. endoreg_db/models/event.py +0 -22
  206. endoreg_db/models/examination/__init__.py +0 -4
  207. endoreg_db/models/examination/examination.py +0 -26
  208. endoreg_db/models/examination/examination_time.py +0 -27
  209. endoreg_db/models/examination/examination_time_type.py +0 -24
  210. endoreg_db/models/examination/examination_type.py +0 -18
  211. endoreg_db/models/hardware/__init__.py +0 -2
  212. endoreg_db/models/hardware/endoscope.py +0 -44
  213. endoreg_db/models/hardware/endoscopy_processor.py +0 -143
  214. endoreg_db/models/information_source.py +0 -29
  215. endoreg_db/models/label/__init__.py +0 -1
  216. endoreg_db/models/label/label.py +0 -84
  217. endoreg_db/models/laboratory/__init__.py +0 -1
  218. endoreg_db/models/laboratory/lab_value.py +0 -102
  219. endoreg_db/models/legacy_data/__init__.py +0 -3
  220. endoreg_db/models/legacy_data/image.py +0 -34
  221. endoreg_db/models/logging/__init__.py +0 -4
  222. endoreg_db/models/logging/agl_service.py +0 -19
  223. endoreg_db/models/logging/base.py +0 -22
  224. endoreg_db/models/logging/log_type.py +0 -23
  225. endoreg_db/models/logging/network_device.py +0 -27
  226. endoreg_db/models/medication/__init__.py +0 -1
  227. endoreg_db/models/medication/medication.py +0 -148
  228. endoreg_db/models/network/__init__.py +0 -3
  229. endoreg_db/models/network/agl_service.py +0 -38
  230. endoreg_db/models/network/network_device.py +0 -53
  231. endoreg_db/models/network/network_device_type.py +0 -23
  232. endoreg_db/models/other/__init__.py +0 -5
  233. endoreg_db/models/other/distribution.py +0 -215
  234. endoreg_db/models/other/material.py +0 -16
  235. endoreg_db/models/other/resource.py +0 -18
  236. endoreg_db/models/other/transport_route.py +0 -21
  237. endoreg_db/models/other/waste.py +0 -20
  238. endoreg_db/models/patient_examination/__init__.py +0 -35
  239. endoreg_db/models/permissions/__init__.py +0 -44
  240. endoreg_db/models/persons/__init__.py +0 -7
  241. endoreg_db/models/persons/examiner/__init__.py +0 -2
  242. endoreg_db/models/persons/examiner/examiner.py +0 -16
  243. endoreg_db/models/persons/examiner/examiner_type.py +0 -2
  244. endoreg_db/models/persons/first_name.py +0 -18
  245. endoreg_db/models/persons/gender.py +0 -22
  246. endoreg_db/models/persons/last_name.py +0 -20
  247. endoreg_db/models/persons/patient/__init__.py +0 -8
  248. endoreg_db/models/persons/patient/case/__init__.py +0 -0
  249. endoreg_db/models/persons/patient/case/case.py +0 -30
  250. endoreg_db/models/persons/patient/patient.py +0 -216
  251. endoreg_db/models/persons/patient/patient_disease.py +0 -16
  252. endoreg_db/models/persons/patient/patient_event.py +0 -22
  253. endoreg_db/models/persons/patient/patient_lab_sample.py +0 -106
  254. endoreg_db/models/persons/patient/patient_lab_value.py +0 -176
  255. endoreg_db/models/persons/patient/patient_medication.py +0 -44
  256. endoreg_db/models/persons/patient/patient_medication_schedule.py +0 -28
  257. endoreg_db/models/persons/person.py +0 -31
  258. endoreg_db/models/persons/portal_user_information.py +0 -27
  259. endoreg_db/models/prediction/__init__.py +0 -2
  260. endoreg_db/models/prediction/image_classification.py +0 -37
  261. endoreg_db/models/prediction/video_prediction_meta.py +0 -244
  262. endoreg_db/models/product/__init__.py +0 -5
  263. endoreg_db/models/product/product.py +0 -97
  264. endoreg_db/models/product/product_group.py +0 -19
  265. endoreg_db/models/product/product_material.py +0 -24
  266. endoreg_db/models/product/product_weight.py +0 -26
  267. endoreg_db/models/product/reference_product.py +0 -99
  268. endoreg_db/models/questionnaires/__init__.py +0 -114
  269. endoreg_db/models/quiz/__init__.py +0 -2
  270. endoreg_db/models/quiz/quiz_answer.py +0 -41
  271. endoreg_db/models/quiz/quiz_question.py +0 -54
  272. endoreg_db/models/report_reader/__init__.py +0 -2
  273. endoreg_db/models/report_reader/report_reader_config.py +0 -53
  274. endoreg_db/models/report_reader/report_reader_flag.py +0 -20
  275. endoreg_db/models/rules/__init__.py +0 -5
  276. endoreg_db/models/rules/rule.py +0 -24
  277. endoreg_db/models/rules/rule_applicator.py +0 -224
  278. endoreg_db/models/rules/rule_attribute_dtype.py +0 -19
  279. endoreg_db/models/rules/rule_type.py +0 -22
  280. endoreg_db/models/rules/ruleset.py +0 -19
  281. endoreg_db/models/unit.py +0 -22
  282. endoreg_db/queries/__init__.py +0 -5
  283. endoreg_db/queries/annotations/__init__.py +0 -3
  284. endoreg_db/queries/annotations/legacy.py +0 -158
  285. endoreg_db/queries/get/__init__.py +0 -6
  286. endoreg_db/queries/get/annotation.py +0 -0
  287. endoreg_db/queries/get/center.py +0 -42
  288. endoreg_db/queries/get/model.py +0 -13
  289. endoreg_db/queries/get/patient.py +0 -14
  290. endoreg_db/queries/get/patient_examination.py +0 -20
  291. endoreg_db/queries/get/prediction.py +0 -0
  292. endoreg_db/queries/get/report_file.py +0 -33
  293. endoreg_db/queries/get/video.py +0 -31
  294. endoreg_db/queries/get/video_import_meta.py +0 -0
  295. endoreg_db/queries/get/video_prediction_meta.py +0 -0
  296. endoreg_db/queries/sanity/__init_.py +0 -0
  297. endoreg_db/serializers/__init__.py +0 -10
  298. endoreg_db/serializers/ai_model.py +0 -19
  299. endoreg_db/serializers/annotation.py +0 -17
  300. endoreg_db/serializers/center.py +0 -11
  301. endoreg_db/serializers/examination.py +0 -33
  302. endoreg_db/serializers/frame.py +0 -13
  303. endoreg_db/serializers/hardware.py +0 -21
  304. endoreg_db/serializers/label.py +0 -22
  305. endoreg_db/serializers/patient.py +0 -10
  306. endoreg_db/serializers/prediction.py +0 -15
  307. endoreg_db/serializers/report_file.py +0 -7
  308. endoreg_db/serializers/video.py +0 -27
  309. endoreg_db/utils/__init__.py +0 -1
  310. endoreg_db/utils/cropping.py +0 -29
  311. endoreg_db/utils/dataloader.py +0 -92
  312. endoreg_db/utils/file_operations.py +0 -30
  313. endoreg_db/utils/hashs.py +0 -34
  314. endoreg_db/utils/legacy_ocr.py +0 -201
  315. endoreg_db/utils/ocr.py +0 -190
  316. endoreg_db/utils/uuid.py +0 -4
  317. endoreg_db/utils/video_metadata.py +0 -87
  318. endoreg_db-0.5.2.dist-info/METADATA +0 -27
  319. endoreg_db-0.5.2.dist-info/RECORD +0 -319
  320. {endoreg_db-0.5.2.dist-info/licenses → endoreg_db-0.6.0.dist-info}/LICENSE +0 -0
@@ -1,201 +0,0 @@
1
- # import cv2
2
- from PIL import Image
3
- from django.core.files.base import ContentFile
4
- from django.db import models, transaction
5
- from tqdm import tqdm
6
- # import cv2
7
- import io
8
- from datetime import date
9
-
10
- BATCH_SIZE = 1000
11
-
12
- class AbstractVideo(models.Model):
13
- file = models.FileField(upload_to="raw_videos", blank=True, null=True)
14
- video_hash = models.CharField(max_length=255, unique=True)
15
- patient = models.ForeignKey("Patient", on_delete=models.CASCADE, blank=True, null=True)
16
- date = models.DateField(blank=True, null=True)
17
- suffix = models.CharField(max_length=255)
18
- fps = models.FloatField()
19
- duration = models.FloatField()
20
- width = models.IntegerField()
21
- height = models.IntegerField()
22
- endoscope_image_x = models.IntegerField(blank=True, null=True)
23
- endoscope_image_y = models.IntegerField(blank=True, null=True)
24
- endoscope_image_width = models.IntegerField(blank=True, null=True)
25
- endoscope_image_height = models.IntegerField(blank=True, null=True)
26
- center = models.ForeignKey("Center", on_delete=models.CASCADE, blank=True, null=True)
27
- endoscopy_processor = models.ForeignKey("EndoscopyProcessor", on_delete=models.CASCADE, blank=True, null=True)
28
- frames_extracted = models.BooleanField(default=False)
29
-
30
- meta = models.JSONField(blank=True, null=True)
31
-
32
- class Meta:
33
- abstract = True
34
-
35
- def get_roi_endoscope_image(self):
36
- return {
37
- 'x': self.endoscope_image_content_x,
38
- 'y': self.endoscope_image_content_y,
39
- 'width': self.endoscope_image_content_width,
40
- 'height': self.endoscope_image_content_height,
41
- }
42
-
43
- def initialize_metadata_in_db(self, video_meta=None):
44
- if not video_meta:
45
- video_meta = self.meta
46
- self.set_examination_date_from_video_meta(video_meta)
47
- self.patient, created = self.get_or_create_patient(video_meta)
48
- self.save()
49
-
50
- def get_or_create_patient(self, video_meta=None):
51
- from ...persons import Patient
52
- if not video_meta:
53
- video_meta = self.meta
54
-
55
- patient_first_name = video_meta['patient_first_name']
56
- patient_last_name = video_meta['patient_last_name']
57
- patient_dob = video_meta['patient_dob']
58
-
59
- # assert that we got all the necessary information
60
- assert patient_first_name and patient_last_name and patient_dob, "Missing patient information"
61
-
62
- patient, created = Patient.objects.get_or_create(
63
- first_name=patient_first_name,
64
- last_name=patient_last_name,
65
- dob=patient_dob
66
- )
67
-
68
- return patient, created
69
-
70
- def get_frame_model(self):
71
- assert 1 == 2, "This method should be overridden in derived classes"
72
-
73
- def get_video_model(self):
74
- assert 1 == 2, "This method should be overridden in derived classes"
75
-
76
- def get_frame_number(self):
77
- """
78
- Get the number of frames in the video.
79
- """
80
- frame_model = self.get_frame_model()
81
- framecount = frame_model.objects.filter(video=self).count()
82
- return framecount
83
-
84
- def set_frames_extracted(self, value:bool=True):
85
- self.frames_extracted = value
86
- self.save()
87
-
88
- def get_frames(self):
89
- """
90
- Retrieve all frames for this video in the correct order.
91
- """
92
- frame_model = self.get_frame_model()
93
- return frame_model.objects.filter(video=self).order_by('frame_number')
94
-
95
- def get_frame(self, frame_number):
96
- """
97
- Retrieve a specific frame for this video.
98
- """
99
- frame_model = self.get_frame_model()
100
- return frame_model.objects.get(video=self, frame_number=frame_number)
101
-
102
- def get_frame_range(self, start_frame_number:int, end_frame_number:int):
103
- """
104
- Expects numbers of start and stop frame.
105
- Returns all frames of this video within the given range in ascending order.
106
- """
107
- frame_model = self.get_frame_model()
108
- return frame_model.objects.filter(video=self, frame_number__gte=start_frame_number, frame_number__lte=end_frame_number).order_by('frame_number')
109
-
110
- def _create_frame_object(self, frame_number, image_file):
111
- frame_model = self.get_frame_model()
112
- frame = frame_model(
113
- video=self,
114
- frame_number=frame_number,
115
- suffix='jpg',
116
- )
117
- frame.image_file = image_file # Temporary store the file-like object
118
-
119
- return frame
120
-
121
- def _bulk_create_frames(self, frames_to_create):
122
- frame_model = self.get_frame_model()
123
- with transaction.atomic():
124
- frame_model.objects.bulk_create(frames_to_create)
125
-
126
- # After the DB operation, save the ImageField for each object
127
- for frame in frames_to_create:
128
- frame_name = f"video_{self.id}_frame_{str(frame.frame_number).zfill(7)}.jpg"
129
- frame.image.save(frame_name, frame.image_file)
130
-
131
- # Clear the list for the next batch
132
- frames_to_create = []
133
-
134
- def set_examination_date_from_video_meta(self, video_meta=None):
135
- if not video_meta:
136
- video_meta = self.meta
137
- date_str = video_meta['examination_date'] # e.g. 2020-01-01
138
- if date_str:
139
- self.date = date.fromisoformat(date_str)
140
- self.save()
141
-
142
- def extract_all_frames(self):
143
- """
144
- Extract all frames from the video and store them in the database.
145
- Uses Django's bulk_create for more efficient database operations.
146
- """
147
- # Open the video file
148
- video = cv2.VideoCapture(self.file.path)
149
-
150
- # Initialize video properties
151
- self.initialize_video_specs(video)
152
-
153
- # Prepare for batch operation
154
- frames_to_create = []
155
-
156
- # Extract frames
157
- for frame_number in tqdm(range(int(self.duration * self.fps))):
158
- # Read the frame
159
- success, image = video.read()
160
- if not success:
161
- break
162
-
163
- # Convert the numpy array to a PIL Image object
164
- pil_image = Image.fromarray(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
165
-
166
- # Save the PIL Image to a buffer
167
- buffer = io.BytesIO()
168
- pil_image.save(buffer, format='JPEG')
169
-
170
- # Create a file-like object from the byte data in the buffer
171
- image_file = ContentFile(buffer.getvalue())
172
-
173
- # Prepare Frame instance (don't save yet)
174
- frame = self._create_frame_object(frame_number, image_file)
175
- frames_to_create.append(frame)
176
-
177
- # Perform bulk create when reaching BATCH_SIZE
178
- if len(frames_to_create) >= BATCH_SIZE:
179
- self._bulk_create_frames(frames_to_create)
180
- frames_to_create = []
181
-
182
-
183
- # Handle remaining frames
184
- if frames_to_create:
185
- self._bulk_create_frames(frames_to_create)
186
- frames_to_create = []
187
-
188
- # Close the video file
189
- video.release()
190
- self.set_frames_extracted(True)
191
-
192
-
193
- def initialize_video_specs(self, video):
194
- """
195
- Initialize and save video metadata like framerate, dimensions, and duration.
196
- """
197
- self.fps = video.get(cv2.CAP_PROP_FPS)
198
- self.width = int(video.get(cv2.CAP_PROP_FRAME_WIDTH))
199
- self.height = int(video.get(cv2.CAP_PROP_FRAME_HEIGHT))
200
- self.duration = video.get(cv2.CAP_PROP_FRAME_COUNT) / self.fps
201
- self.save()
@@ -1,45 +0,0 @@
1
- from endoreg_db.models.annotation.image_classification import ImageClassificationAnnotation
2
- from endoreg_db.models.label.label import Label
3
- from .base_classes import AbstractFrame
4
- from django.db import models
5
-
6
- class Frame(AbstractFrame):
7
- video = models.ForeignKey("Video", on_delete=models.CASCADE, related_name="frames")
8
-
9
- class LegacyFrame(AbstractFrame):
10
- video = models.ForeignKey("LegacyVideo", on_delete=models.CASCADE, related_name='frames')
11
- image = models.ImageField(upload_to="legacy_frames", blank=True, null=True)
12
- suffix = models.CharField(max_length=255)
13
- # ImageClassificationAnnotation has a foreign key to this model (related name: image_classification_annotations)
14
-
15
- class Meta:
16
- unique_together = ('video', 'frame_number')
17
- indexes = [
18
- models.Index(fields=['video', 'frame_number']),
19
- ]
20
-
21
- def get_classification_annotations(self):
22
- """
23
- Get all image classification annotations for this frame.
24
- """
25
- return ImageClassificationAnnotation.objects.filter(legacy_frame=self)
26
-
27
- def get_classification_annotations_by_label(self, label:Label):
28
- """
29
- Get all image classification annotations for this frame with the given label.
30
- """
31
- return ImageClassificationAnnotation.objects.filter(legacy_frame=self, label=label)
32
-
33
- def get_classification_annotations_by_value(self, value:bool):
34
- """
35
- Get all image classification annotations for this frame with the given value.
36
- """
37
- return ImageClassificationAnnotation.objects.filter(legacy_frame=self, value=value)
38
-
39
- def get_classification_annotations_by_label_and_value(self, label:Label, value:bool):
40
- """
41
- Get all image classification annotations for this frame with the given label and value.
42
- """
43
- return ImageClassificationAnnotation.objects.filter(legacy_frame=self, label=label, value=value)
44
-
45
-
@@ -1,32 +0,0 @@
1
- import os
2
- from pathlib import Path
3
-
4
- from .raw_video import RawVideoFile
5
- from .raw_pdf import RawPdfFile
6
-
7
- # FileImporter class
8
- # This class is used to import data from a file into the database.
9
- # Expects a directory containing files to import.
10
- # creates correct import file object depending on file type
11
-
12
- # FileImporter class
13
- # This class is used to import data from a file into the database by creating objects for the files.
14
- # main method is import_files which expects a path to a directory containing files to import.
15
- # creates correct import file object depending on file type by checking the file extension
16
-
17
- class FileImporter:
18
- def __init__(self, directory):
19
- self.directory = directory
20
-
21
- def import_files(self):
22
- directory_path = Path(self.directory)
23
- for file in directory_path.iterdir():
24
- if file.is_file():
25
- if file.suffix.lower() in ['.mov', '.mp4']:
26
- RawVideoFile.create_from_file(file)
27
- else:
28
- raise ValueError(f"File type {file.suffix} not supported")
29
- else:
30
- raise ValueError(f"{file} is not a file")
31
-
32
-
@@ -1,35 +0,0 @@
1
- from .video import (
2
- get_videos_scheduled_for_frame_extraction,
3
- extract_frames_from_video,
4
- extract_frames_from_videos,
5
-
6
- get_videos_scheduled_for_ocr,
7
- videos_scheduled_for_ocr_preflight,
8
- perform_ocr_on_video,
9
- perform_ocr_on_videos,
10
-
11
- videos_scheduled_for_initial_prediction_preflight,
12
- get_videos_scheduled_for_initial_prediction,
13
- get_multilabel_model,
14
- get_multilabel_classifier,
15
- get_crops,
16
- perform_initial_prediction_on_video,
17
- perform_initial_prediction_on_videos,
18
-
19
- videos_scheduled_for_prediction_import_preflight,
20
- get_videos_scheduled_for_prediction_import,
21
- import_predictions_for_video,
22
- import_predictions_for_videos,
23
-
24
-
25
- delete_frames_preflight,
26
- get_videos_scheduled_for_frame_deletion,
27
- delete_frames_for_video,
28
- delete_frames,
29
- )
30
-
31
- from .pdf import (
32
- get_pdf_files_scheduled_for_processing,
33
- process_pdf_file,
34
- process_pdf_files,
35
- )
@@ -1,28 +0,0 @@
1
- from ..raw_pdf import RawPdfFile
2
- from logging import getLogger
3
- #
4
- # # setup logging to pdf_import.log
5
- logger = getLogger('examination_pdf_import')
6
-
7
- def get_pdf_files_scheduled_for_processing():
8
- reports = RawPdfFile.objects.filter(
9
- state_report_processing_required=True
10
- )
11
- return reports
12
-
13
- def process_pdf_file(report:RawPdfFile):
14
- if report.update(save=True, verbose=True):
15
- logger.info(f"Report {report} processed successfully")
16
- return True
17
- else:
18
- logger.error(f"Report {report} processing failed")
19
- return False
20
-
21
-
22
- def process_pdf_files():
23
- reports = get_pdf_files_scheduled_for_processing()
24
- for report in reports:
25
- process_pdf_file(report)
26
-
27
-
28
-
@@ -1,260 +0,0 @@
1
- from ..raw_video import RawVideoFile
2
- import json
3
-
4
- # # Starting point
5
- # Automated tasks generate RawVideoFile objects in our db.
6
- # Each object has state_{NAME} attributes.
7
- # We will create functions which query the db for RawVideoFile
8
- # objects with specific state_{NAME} attributes.
9
- # Then, we perform the necessary operations on the RawVideoFile and
10
- # update the state_{NAME} attributes accordingly.
11
-
12
- # # Step 1 - Frame Extraction
13
- # function to query for videos scheduled for frame extraction,
14
- # these have state_frames_required and state_frames_extracted
15
- def get_videos_scheduled_for_frame_extraction():
16
- return RawVideoFile.objects.filter(
17
- state_frames_required=True,
18
- state_frames_extracted=False
19
- )
20
-
21
- def extract_frames_from_video(video:RawVideoFile):
22
- # extract frames from video
23
- video.extract_frames()
24
-
25
- # update state_frames_extracted
26
- video.state_frames_extracted = True
27
- video.save()
28
-
29
- return video
30
-
31
- def extract_frames_from_videos():
32
- videos = get_videos_scheduled_for_frame_extraction()
33
- for video in videos:
34
- extract_frames_from_video(video)
35
-
36
- # # Step 2 - OCR
37
- # function to query for videos scheduled for OCR,
38
- # these have
39
- # state_ocr_required = True and state_ocr_completed = False and state_frames_extracted = True
40
- def get_videos_scheduled_for_ocr():
41
- return RawVideoFile.objects.filter(
42
- state_ocr_required=True,
43
- state_ocr_completed=False,
44
- state_frames_extracted=True
45
- )
46
-
47
- # function to set state_frames_required to True for videos
48
- # which are scheduled for OCR but have not had frames extracted
49
- def videos_scheduled_for_ocr_preflight():
50
- videos = RawVideoFile.objects.filter(
51
- state_ocr_required=True,
52
- state_ocr_completed=False,
53
- state_frames_extracted=False
54
- )
55
- for video in videos:
56
- video.state_frames_required = True
57
- video.save()
58
-
59
- def perform_ocr_on_video(video:RawVideoFile):
60
- # perform OCR on video
61
- video.update_text_metadata()
62
-
63
- # update state_ocr_completed
64
- video.state_ocr_completed = True
65
- video.save()
66
-
67
- return video
68
-
69
- def perform_ocr_on_videos():
70
- videos = get_videos_scheduled_for_ocr()
71
- for video in videos:
72
- perform_ocr_on_video(video)
73
-
74
-
75
- # # Step 3 - initial Prediction
76
- # function to query for videos scheduled for initial prediction,
77
- # these have
78
- # state_initial_prediction_required = True and state_initial_prediction_completed = False and state_frames_extracted = True
79
- def videos_scheduled_for_initial_prediction_preflight():
80
- videos = RawVideoFile.objects.filter(
81
- state_initial_prediction_required=True,
82
- state_initial_prediction_completed=False,
83
- state_frames_extracted=False
84
- )
85
- for video in videos:
86
- video.state_frames_required = True
87
- video.save()
88
-
89
- def get_videos_scheduled_for_initial_prediction():
90
- return RawVideoFile.objects.filter(
91
- state_initial_prediction_required=True,
92
- state_initial_prediction_completed=False,
93
- state_frames_extracted=True
94
- )
95
-
96
- from pathlib import Path
97
- def get_multilabel_model(model_path:Path):
98
- from agl_predict_endo_frame.model_loader import MultiLabelClassificationNet
99
- model_path_str = model_path.resolve().as_posix()
100
- model = MultiLabelClassificationNet.load_from_checkpoint(model_path_str)
101
- model.cuda()
102
- model.eval()
103
- return model
104
-
105
- def get_multilabel_classifier(model, verbose:bool=False):
106
- from agl_predict_endo_frame.predict import Classifier
107
- classifier = Classifier(model, verbose = verbose)
108
- return classifier
109
-
110
- def get_crops(video, paths):
111
- endo_roi_dict = video.get_endo_roi()
112
- # dict with x, y, width height
113
- # crops is list of touples with (y_min, y_max, x_min, x_max)
114
- crop_tuple = (
115
- endo_roi_dict["y"],
116
- endo_roi_dict["y"] + endo_roi_dict["height"],
117
- endo_roi_dict["x"],
118
- endo_roi_dict["x"] + endo_roi_dict["width"],
119
- )
120
- crops = [crop_tuple for _ in paths]
121
- return crops
122
-
123
- # model = MultiLabelClassificationNet.load_from_checkpoint("model/colo_segmentation_RegNetX800MF_6.ckpt")
124
- def perform_initial_prediction_on_video(
125
- video:RawVideoFile, model_path,
126
- window_size_s, min_seq_len_s
127
- ):
128
-
129
- model = get_multilabel_model(model_path)
130
- classifier = get_multilabel_classifier(model, verbose = True)
131
-
132
- paths = video.get_frame_paths()
133
- string_paths = [p.resolve().as_posix() for p in paths]
134
- crops = get_crops(video, string_paths)
135
- fps = video.get_fps()
136
-
137
- predictions = classifier.pipe(string_paths, crops)
138
- readable_predictions = [classifier.readable(p) for p in predictions]
139
- result_dict = classifier.post_process_predictions_serializable(
140
- readable_predictions,
141
- window_size_s = window_size_s,
142
- min_seq_len_s = min_seq_len_s,
143
- fps = fps
144
- )
145
-
146
-
147
- # Predictions
148
- _path = video.get_predictions_path()
149
- with open(_path, "w") as f:
150
- json.dump(result_dict["predictions"], f, indent = 4)
151
-
152
- # smooth_predictions
153
- _path = video.get_smooth_predictions_path()
154
- with open(_path, "w") as f:
155
- json.dump(result_dict["smooth_predictions"], f, indent = 4)
156
-
157
- # binary_predictions
158
- _path = video.get_binary_predictions_path()
159
- with open(_path, "w") as f:
160
- json.dump(result_dict["binary_predictions"], f, indent = 4)
161
-
162
- # Raw Sequences
163
- _path = video.get_raw_sequences_path()
164
- with open(_path, "w") as f:
165
- json.dump(result_dict["raw_sequences"], f, indent = 4)
166
-
167
- # filtered_sequences
168
- _path = video.get_filtered_sequences_path()
169
- with open(_path, "w") as f:
170
- json.dump(result_dict["filtered_sequences"], f, indent = 4)
171
-
172
-
173
- # update state_initial_prediction_completed
174
- video.state_initial_prediction_required = False
175
- video.state_initial_prediction_completed = True
176
- video.state_initial_prediction_import_required = True
177
- video.state_initial_prediction_import_completed = False
178
- video.save()
179
-
180
- return video
181
-
182
- def perform_initial_prediction_on_videos(
183
- model_path,
184
- window_size_s, min_seq_len_s
185
- ):
186
- videos = get_videos_scheduled_for_initial_prediction()
187
- for video in videos:
188
- perform_initial_prediction_on_video(
189
- video,
190
- model_path, window_size_s, min_seq_len_s
191
- )
192
-
193
- def videos_scheduled_for_prediction_import_preflight():
194
- videos = RawVideoFile.objects.filter(
195
- state_initial_prediction_completed=True,
196
- state_initial_prediction_import_completed=False
197
- )
198
- for video in videos:
199
- video.state_initial_prediction_required = True
200
- video.save()
201
-
202
- def get_videos_scheduled_for_prediction_import():
203
- return RawVideoFile.objects.filter(
204
- state_initial_prediction_import_required=True,
205
- state_initial_prediction_import_completed=False,
206
- state_initial_prediction_completed=True
207
- )
208
-
209
- def import_predictions_for_video(video:RawVideoFile):
210
- # import predictions for video
211
- pass
212
-
213
- # update state_prediction_import_completed
214
- # video.state_initial_prediction_import_required = False
215
- # video.state_initial_prediction_import_completed = True
216
- # video.save()
217
-
218
- return video
219
-
220
- def import_predictions_for_videos():
221
- videos = get_videos_scheduled_for_prediction_import()
222
- for video in videos:
223
- import_predictions_for_video(video)
224
-
225
- # # Step 4 - Delete Frames if not needed anymore
226
- # function to query for videos scheduled for frame deletion,
227
- # first we need to set state_frames_required = False for videos with:
228
- # state_ocr_required = False and state_ocr_completed = True and
229
- # state_initial_prediction_required = False and state_initial_prediction_completed = True
230
- def delete_frames_preflight():
231
- videos = RawVideoFile.objects.filter(
232
- state_ocr_required=False,
233
- state_ocr_completed=True,
234
- state_initial_prediction_required=False,
235
- state_initial_prediction_completed=True
236
- )
237
- for video in videos:
238
- video.state_frames_required = False
239
- video.save()
240
-
241
- # function to query for videos scheduled for frame deletion,
242
- # frames should be deleted if state_frames_required = False
243
- def get_videos_scheduled_for_frame_deletion():
244
- return RawVideoFile.objects.filter(
245
- state_frames_required=False
246
- )
247
-
248
- def delete_frames_for_video(video:RawVideoFile):
249
- # delete frames for video
250
-
251
- # update state_frames_deleted
252
- video.state_frames_extracted = False
253
- video.save()
254
-
255
- return video
256
-
257
- def delete_frames():
258
- videos = get_videos_scheduled_for_frame_deletion()
259
- for video in videos:
260
- delete_frames_for_video(video)