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.
- endoreg_db/admin.py +90 -1
- endoreg_db/urls.py +173 -0
- endoreg_db/views.py +0 -3
- endoreg_db-0.6.0.dist-info/METADATA +151 -0
- endoreg_db-0.6.0.dist-info/RECORD +11 -0
- {endoreg_db-0.5.2.dist-info → endoreg_db-0.6.0.dist-info}/WHEEL +2 -1
- endoreg_db-0.6.0.dist-info/top_level.txt +1 -0
- endoreg_db/data/__init__.py +0 -72
- endoreg_db/data/active_model/data.yaml +0 -3
- endoreg_db/data/agl_service/data.yaml +0 -19
- endoreg_db/data/case_template/rule/00_patient_lab_sample_add_default_value.yaml +0 -167
- endoreg_db/data/case_template/rule/01_patient-set-age.yaml +0 -8
- endoreg_db/data/case_template/rule/01_patient-set-gender.yaml +0 -9
- endoreg_db/data/case_template/rule/11_create_patient_lab_sample.yaml +0 -23
- endoreg_db/data/case_template/rule/12_create-patient_medication-anticoagulation.yaml +0 -19
- endoreg_db/data/case_template/rule/13_create-patient_medication_schedule-anticoagulation.yaml +0 -19
- endoreg_db/data/case_template/rule/19_create_patient.yaml +0 -17
- endoreg_db/data/case_template/rule_type/base_types.yaml +0 -35
- endoreg_db/data/case_template/rule_value/.init +0 -0
- endoreg_db/data/case_template/rule_value_type/base_types.yaml +0 -59
- endoreg_db/data/case_template/template/base.yaml +0 -8
- endoreg_db/data/case_template/template_type/pre_endoscopy.yaml +0 -3
- endoreg_db/data/case_template/tmp/_rule_value +0 -13
- endoreg_db/data/case_template/tmp/rule/01_atrial_fibrillation.yaml +0 -21
- endoreg_db/data/case_template/tmp/rule/02_create_object.yaml +0 -10
- endoreg_db/data/case_template/tmp/template/atrial_fibrillation_low_risk.yaml +0 -7
- endoreg_db/data/center/data.yaml +0 -60
- endoreg_db/data/center_resource/green_endoscopy_dashboard_CenterResource.yaml +0 -144
- endoreg_db/data/center_waste/green_endoscopy_dashboard_CenterWaste.yaml +0 -48
- endoreg_db/data/disease/cardiovascular.yaml +0 -37
- endoreg_db/data/disease/hepatology.yaml +0 -5
- endoreg_db/data/disease/misc.yaml +0 -6
- endoreg_db/data/disease/renal.yaml +0 -5
- endoreg_db/data/disease_classification/chronic_kidney_disease.yaml +0 -6
- endoreg_db/data/disease_classification/coronary_vessel_disease.yaml +0 -6
- endoreg_db/data/disease_classification_choice/chronic_kidney_disease.yaml +0 -41
- endoreg_db/data/disease_classification_choice/coronary_vessel_disease.yaml +0 -20
- endoreg_db/data/distribution/date/patient.yaml +0 -7
- endoreg_db/data/distribution/multiple_categorical/.init +0 -0
- endoreg_db/data/distribution/numeric/.init +0 -0
- endoreg_db/data/distribution/single_categorical/patient.yaml +0 -7
- endoreg_db/data/emission_factor/green_endoscopy_dashboard_EmissionFactor.yaml +0 -132
- endoreg_db/data/endoscope_type/data.yaml +0 -11
- endoreg_db/data/endoscopy_processor/data.yaml +0 -47
- endoreg_db/data/event/cardiology.yaml +0 -28
- endoreg_db/data/event/neurology.yaml +0 -14
- endoreg_db/data/event/surgery.yaml +0 -13
- endoreg_db/data/event/thrombembolism.yaml +0 -20
- endoreg_db/data/examination/examinations/data.yaml +0 -66
- endoreg_db/data/examination/time/data.yaml +0 -48
- endoreg_db/data/examination/time-type/data.yaml +0 -8
- endoreg_db/data/examination/type/data.yaml +0 -5
- endoreg_db/data/gender/data.yaml +0 -18
- endoreg_db/data/information_source/data.yaml +0 -30
- endoreg_db/data/information_source/medication.yaml +0 -6
- endoreg_db/data/lab_value/cardiac_enzymes.yaml +0 -31
- endoreg_db/data/lab_value/coagulation.yaml +0 -49
- endoreg_db/data/lab_value/electrolytes.yaml +0 -190
- endoreg_db/data/lab_value/gastrointestinal_function.yaml +0 -121
- endoreg_db/data/lab_value/hematology.yaml +0 -169
- endoreg_db/data/lab_value/hormones.yaml +0 -53
- endoreg_db/data/lab_value/lipids.yaml +0 -44
- endoreg_db/data/lab_value/misc.yaml +0 -30
- endoreg_db/data/lab_value/renal_function.yaml +0 -11
- endoreg_db/data/label/label/data.yaml +0 -62
- endoreg_db/data/label/label-set/data.yaml +0 -18
- endoreg_db/data/label/label-type/data.yaml +0 -7
- endoreg_db/data/log_type/data.yaml +0 -57
- endoreg_db/data/material/material.yaml +0 -91
- endoreg_db/data/medication/anticoagulation.yaml +0 -65
- endoreg_db/data/medication/tah.yaml +0 -70
- endoreg_db/data/medication_indication/anticoagulation.yaml +0 -120
- endoreg_db/data/medication_indication_type/data.yaml +0 -11
- endoreg_db/data/medication_indication_type/thrombembolism.yaml +0 -41
- endoreg_db/data/medication_intake_time/base.yaml +0 -31
- endoreg_db/data/medication_schedule/apixaban.yaml +0 -95
- endoreg_db/data/medication_schedule/ass.yaml +0 -12
- endoreg_db/data/medication_schedule/enoxaparin.yaml +0 -26
- endoreg_db/data/model_type/data.yaml +0 -7
- endoreg_db/data/network_device/data.yaml +0 -29
- endoreg_db/data/network_device_type/data.yaml +0 -12
- endoreg_db/data/patient_lab_sample_type/generic.yaml +0 -6
- endoreg_db/data/pdf_type/data.yaml +0 -28
- endoreg_db/data/product/green_endoscopy_dashboard_Product.yaml +0 -66
- endoreg_db/data/product_group/green_endoscopy_dashboard_ProductGroup.yaml +0 -33
- endoreg_db/data/product_material/green_endoscopy_dashboard_ProductMaterial.yaml +0 -308
- endoreg_db/data/product_weight/green_endoscopy_dashboard_ProductWeight.yaml +0 -88
- endoreg_db/data/profession/data.yaml +0 -70
- endoreg_db/data/reference_product/green_endoscopy_dashboard_ReferenceProduct.yaml +0 -55
- endoreg_db/data/report_reader_flag/ukw-examination-generic.yaml +0 -26
- endoreg_db/data/report_reader_flag/ukw-histology-generic.yaml +0 -19
- endoreg_db/data/resource/green_endoscopy_dashboard_Resource.yaml +0 -15
- endoreg_db/data/tmp/chronic_kidney_disease.yaml +0 -0
- endoreg_db/data/tmp/congestive_heart_failure.yaml +0 -0
- endoreg_db/data/transport_route/green_endoscopy_dashboard_TransportRoute.yaml +0 -12
- endoreg_db/data/unit/concentration.yaml +0 -92
- endoreg_db/data/unit/data.yaml +0 -17
- endoreg_db/data/unit/length.yaml +0 -31
- endoreg_db/data/unit/misc.yaml +0 -20
- endoreg_db/data/unit/rate.yaml +0 -6
- endoreg_db/data/unit/time.yaml +0 -13
- endoreg_db/data/unit/volume.yaml +0 -35
- endoreg_db/data/unit/weight.yaml +0 -38
- endoreg_db/data/waste/data.yaml +0 -12
- endoreg_db/forms/__init__.py +0 -3
- endoreg_db/forms/questionnaires/__init__.py +0 -1
- endoreg_db/forms/questionnaires/tto_questionnaire.py +0 -23
- endoreg_db/forms/settings/__init__.py +0 -8
- endoreg_db/forms/unit.py +0 -6
- endoreg_db/management/commands/_load_model_template.py +0 -41
- endoreg_db/management/commands/delete_all.py +0 -18
- endoreg_db/management/commands/delete_legacy_images.py +0 -19
- endoreg_db/management/commands/delete_legacy_videos.py +0 -17
- endoreg_db/management/commands/extract_legacy_video_frames.py +0 -18
- endoreg_db/management/commands/fetch_legacy_image_dataset.py +0 -32
- endoreg_db/management/commands/fix_auth_permission.py +0 -20
- endoreg_db/management/commands/import_legacy_images.py +0 -94
- endoreg_db/management/commands/import_legacy_videos.py +0 -76
- endoreg_db/management/commands/load_active_model_data.py +0 -45
- endoreg_db/management/commands/load_ai_model_data.py +0 -45
- endoreg_db/management/commands/load_base_db_data.py +0 -136
- endoreg_db/management/commands/load_center_data.py +0 -43
- endoreg_db/management/commands/load_disease_classification_choices_data.py +0 -41
- endoreg_db/management/commands/load_disease_classification_data.py +0 -41
- endoreg_db/management/commands/load_disease_data.py +0 -40
- endoreg_db/management/commands/load_distribution_data.py +0 -66
- endoreg_db/management/commands/load_endoscope_type_data.py +0 -45
- endoreg_db/management/commands/load_endoscopy_processor_data.py +0 -45
- endoreg_db/management/commands/load_event_data.py +0 -41
- endoreg_db/management/commands/load_examination_data.py +0 -75
- endoreg_db/management/commands/load_g_play_data.py +0 -113
- endoreg_db/management/commands/load_gender_data.py +0 -44
- endoreg_db/management/commands/load_green_endoscopy_wuerzburg_data.py +0 -133
- endoreg_db/management/commands/load_information_source.py +0 -45
- endoreg_db/management/commands/load_lab_value_data.py +0 -50
- endoreg_db/management/commands/load_label_data.py +0 -67
- endoreg_db/management/commands/load_logging_data.py +0 -39
- endoreg_db/management/commands/load_medication_data.py +0 -41
- endoreg_db/management/commands/load_medication_indication_data.py +0 -63
- endoreg_db/management/commands/load_medication_indication_type_data.py +0 -41
- endoreg_db/management/commands/load_medication_intake_time_data.py +0 -41
- endoreg_db/management/commands/load_medication_schedule_data.py +0 -55
- endoreg_db/management/commands/load_network_data.py +0 -57
- endoreg_db/management/commands/load_pdf_type_data.py +0 -61
- endoreg_db/management/commands/load_profession_data.py +0 -44
- endoreg_db/management/commands/load_report_reader_flag.py +0 -46
- endoreg_db/management/commands/load_unit_data.py +0 -46
- endoreg_db/management/commands/load_user_groups.py +0 -28
- endoreg_db/management/commands/register_ai_model.py +0 -64
- endoreg_db/management/commands/reset_celery_schedule.py +0 -9
- endoreg_db/migrations/0001_initial.py +0 -1567
- endoreg_db/migrations/0002_anonymizedimagelabel_anonymousimageannotation_and_more.py +0 -55
- endoreg_db/migrations/0003_anonymousimageannotation_original_image_url_and_more.py +0 -39
- endoreg_db/migrations/0004_alter_rawpdffile_file.py +0 -20
- endoreg_db/migrations/0005_uploadedfile_alter_rawpdffile_file_anonymizedfile.py +0 -40
- endoreg_db/migrations/0006_alter_rawpdffile_file.py +0 -20
- endoreg_db/migrations/0007_networkdevicelogentry_datetime_and_more.py +0 -43
- endoreg_db/migrations/0008_networkdevicelogentry_aglnet_ip_and_more.py +0 -28
- endoreg_db/migrations/0009_alter_networkdevicelogentry_vpn_service_status.py +0 -18
- endoreg_db/migrations/0010_remove_networkdevicelogentry_hostname.py +0 -17
- endoreg_db/migrations/__init__.py +0 -0
- endoreg_db/models/__init__.py +0 -73
- endoreg_db/models/ai_model/__init__.py +0 -3
- endoreg_db/models/ai_model/active_model.py +0 -9
- endoreg_db/models/ai_model/model_meta.py +0 -24
- endoreg_db/models/ai_model/model_type.py +0 -26
- endoreg_db/models/ai_model/utils.py +0 -8
- endoreg_db/models/annotation/__init__.py +0 -3
- endoreg_db/models/annotation/anonymized_image_annotation.py +0 -60
- endoreg_db/models/annotation/binary_classification_annotation_task.py +0 -80
- endoreg_db/models/annotation/image_classification.py +0 -27
- endoreg_db/models/case_template/__init__.py +0 -6
- endoreg_db/models/case_template/case_template.py +0 -81
- endoreg_db/models/case_template/case_template_rule.py +0 -276
- endoreg_db/models/case_template/case_template_rule_value.py +0 -73
- endoreg_db/models/case_template/case_template_type.py +0 -28
- endoreg_db/models/center/__init__.py +0 -4
- endoreg_db/models/center/center.py +0 -25
- endoreg_db/models/center/center_product.py +0 -34
- endoreg_db/models/center/center_resource.py +0 -19
- endoreg_db/models/center/center_waste.py +0 -11
- endoreg_db/models/data_file/__init__.py +0 -6
- endoreg_db/models/data_file/base_classes/__init__.py +0 -2
- endoreg_db/models/data_file/base_classes/abstract_frame.py +0 -51
- endoreg_db/models/data_file/base_classes/abstract_video.py +0 -201
- endoreg_db/models/data_file/frame.py +0 -45
- endoreg_db/models/data_file/import_classes/__init__.py +0 -32
- endoreg_db/models/data_file/import_classes/processing_functions/__init__.py +0 -35
- endoreg_db/models/data_file/import_classes/processing_functions/pdf.py +0 -28
- endoreg_db/models/data_file/import_classes/processing_functions/video.py +0 -260
- endoreg_db/models/data_file/import_classes/raw_pdf.py +0 -188
- endoreg_db/models/data_file/import_classes/raw_video.py +0 -343
- endoreg_db/models/data_file/metadata/__init__.py +0 -3
- endoreg_db/models/data_file/metadata/pdf_meta.py +0 -70
- endoreg_db/models/data_file/metadata/sensitive_meta.py +0 -31
- endoreg_db/models/data_file/metadata/video_meta.py +0 -133
- endoreg_db/models/data_file/report_file.py +0 -89
- endoreg_db/models/data_file/video/__init__.py +0 -7
- endoreg_db/models/data_file/video/import_meta.py +0 -25
- endoreg_db/models/data_file/video/video.py +0 -25
- endoreg_db/models/data_file/video_segment.py +0 -107
- endoreg_db/models/disease.py +0 -56
- endoreg_db/models/emission/__init__.py +0 -1
- endoreg_db/models/emission/emission_factor.py +0 -20
- endoreg_db/models/event.py +0 -22
- endoreg_db/models/examination/__init__.py +0 -4
- endoreg_db/models/examination/examination.py +0 -26
- endoreg_db/models/examination/examination_time.py +0 -27
- endoreg_db/models/examination/examination_time_type.py +0 -24
- endoreg_db/models/examination/examination_type.py +0 -18
- endoreg_db/models/hardware/__init__.py +0 -2
- endoreg_db/models/hardware/endoscope.py +0 -44
- endoreg_db/models/hardware/endoscopy_processor.py +0 -143
- endoreg_db/models/information_source.py +0 -29
- endoreg_db/models/label/__init__.py +0 -1
- endoreg_db/models/label/label.py +0 -84
- endoreg_db/models/laboratory/__init__.py +0 -1
- endoreg_db/models/laboratory/lab_value.py +0 -102
- endoreg_db/models/legacy_data/__init__.py +0 -3
- endoreg_db/models/legacy_data/image.py +0 -34
- endoreg_db/models/logging/__init__.py +0 -4
- endoreg_db/models/logging/agl_service.py +0 -19
- endoreg_db/models/logging/base.py +0 -22
- endoreg_db/models/logging/log_type.py +0 -23
- endoreg_db/models/logging/network_device.py +0 -27
- endoreg_db/models/medication/__init__.py +0 -1
- endoreg_db/models/medication/medication.py +0 -148
- endoreg_db/models/network/__init__.py +0 -3
- endoreg_db/models/network/agl_service.py +0 -38
- endoreg_db/models/network/network_device.py +0 -53
- endoreg_db/models/network/network_device_type.py +0 -23
- endoreg_db/models/other/__init__.py +0 -5
- endoreg_db/models/other/distribution.py +0 -215
- endoreg_db/models/other/material.py +0 -16
- endoreg_db/models/other/resource.py +0 -18
- endoreg_db/models/other/transport_route.py +0 -21
- endoreg_db/models/other/waste.py +0 -20
- endoreg_db/models/patient_examination/__init__.py +0 -35
- endoreg_db/models/permissions/__init__.py +0 -44
- endoreg_db/models/persons/__init__.py +0 -7
- endoreg_db/models/persons/examiner/__init__.py +0 -2
- endoreg_db/models/persons/examiner/examiner.py +0 -16
- endoreg_db/models/persons/examiner/examiner_type.py +0 -2
- endoreg_db/models/persons/first_name.py +0 -18
- endoreg_db/models/persons/gender.py +0 -22
- endoreg_db/models/persons/last_name.py +0 -20
- endoreg_db/models/persons/patient/__init__.py +0 -8
- endoreg_db/models/persons/patient/case/__init__.py +0 -0
- endoreg_db/models/persons/patient/case/case.py +0 -30
- endoreg_db/models/persons/patient/patient.py +0 -216
- endoreg_db/models/persons/patient/patient_disease.py +0 -16
- endoreg_db/models/persons/patient/patient_event.py +0 -22
- endoreg_db/models/persons/patient/patient_lab_sample.py +0 -106
- endoreg_db/models/persons/patient/patient_lab_value.py +0 -176
- endoreg_db/models/persons/patient/patient_medication.py +0 -44
- endoreg_db/models/persons/patient/patient_medication_schedule.py +0 -28
- endoreg_db/models/persons/person.py +0 -31
- endoreg_db/models/persons/portal_user_information.py +0 -27
- endoreg_db/models/prediction/__init__.py +0 -2
- endoreg_db/models/prediction/image_classification.py +0 -37
- endoreg_db/models/prediction/video_prediction_meta.py +0 -244
- endoreg_db/models/product/__init__.py +0 -5
- endoreg_db/models/product/product.py +0 -97
- endoreg_db/models/product/product_group.py +0 -19
- endoreg_db/models/product/product_material.py +0 -24
- endoreg_db/models/product/product_weight.py +0 -26
- endoreg_db/models/product/reference_product.py +0 -99
- endoreg_db/models/questionnaires/__init__.py +0 -114
- endoreg_db/models/quiz/__init__.py +0 -2
- endoreg_db/models/quiz/quiz_answer.py +0 -41
- endoreg_db/models/quiz/quiz_question.py +0 -54
- endoreg_db/models/report_reader/__init__.py +0 -2
- endoreg_db/models/report_reader/report_reader_config.py +0 -53
- endoreg_db/models/report_reader/report_reader_flag.py +0 -20
- endoreg_db/models/rules/__init__.py +0 -5
- endoreg_db/models/rules/rule.py +0 -24
- endoreg_db/models/rules/rule_applicator.py +0 -224
- endoreg_db/models/rules/rule_attribute_dtype.py +0 -19
- endoreg_db/models/rules/rule_type.py +0 -22
- endoreg_db/models/rules/ruleset.py +0 -19
- endoreg_db/models/unit.py +0 -22
- endoreg_db/queries/__init__.py +0 -5
- endoreg_db/queries/annotations/__init__.py +0 -3
- endoreg_db/queries/annotations/legacy.py +0 -158
- endoreg_db/queries/get/__init__.py +0 -6
- endoreg_db/queries/get/annotation.py +0 -0
- endoreg_db/queries/get/center.py +0 -42
- endoreg_db/queries/get/model.py +0 -13
- endoreg_db/queries/get/patient.py +0 -14
- endoreg_db/queries/get/patient_examination.py +0 -20
- endoreg_db/queries/get/prediction.py +0 -0
- endoreg_db/queries/get/report_file.py +0 -33
- endoreg_db/queries/get/video.py +0 -31
- endoreg_db/queries/get/video_import_meta.py +0 -0
- endoreg_db/queries/get/video_prediction_meta.py +0 -0
- endoreg_db/queries/sanity/__init_.py +0 -0
- endoreg_db/serializers/__init__.py +0 -10
- endoreg_db/serializers/ai_model.py +0 -19
- endoreg_db/serializers/annotation.py +0 -17
- endoreg_db/serializers/center.py +0 -11
- endoreg_db/serializers/examination.py +0 -33
- endoreg_db/serializers/frame.py +0 -13
- endoreg_db/serializers/hardware.py +0 -21
- endoreg_db/serializers/label.py +0 -22
- endoreg_db/serializers/patient.py +0 -10
- endoreg_db/serializers/prediction.py +0 -15
- endoreg_db/serializers/report_file.py +0 -7
- endoreg_db/serializers/video.py +0 -27
- endoreg_db/utils/__init__.py +0 -1
- endoreg_db/utils/cropping.py +0 -29
- endoreg_db/utils/dataloader.py +0 -92
- endoreg_db/utils/file_operations.py +0 -30
- endoreg_db/utils/hashs.py +0 -34
- endoreg_db/utils/legacy_ocr.py +0 -201
- endoreg_db/utils/ocr.py +0 -190
- endoreg_db/utils/uuid.py +0 -4
- endoreg_db/utils/video_metadata.py +0 -87
- endoreg_db-0.5.2.dist-info/METADATA +0 -27
- endoreg_db-0.5.2.dist-info/RECORD +0 -319
- {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)
|