ultralytics-opencv-headless 8.3.246__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.
Files changed (298) hide show
  1. tests/__init__.py +23 -0
  2. tests/conftest.py +59 -0
  3. tests/test_cli.py +131 -0
  4. tests/test_cuda.py +216 -0
  5. tests/test_engine.py +157 -0
  6. tests/test_exports.py +309 -0
  7. tests/test_integrations.py +151 -0
  8. tests/test_python.py +777 -0
  9. tests/test_solutions.py +371 -0
  10. ultralytics/__init__.py +48 -0
  11. ultralytics/assets/bus.jpg +0 -0
  12. ultralytics/assets/zidane.jpg +0 -0
  13. ultralytics/cfg/__init__.py +1026 -0
  14. ultralytics/cfg/datasets/Argoverse.yaml +78 -0
  15. ultralytics/cfg/datasets/DOTAv1.5.yaml +37 -0
  16. ultralytics/cfg/datasets/DOTAv1.yaml +36 -0
  17. ultralytics/cfg/datasets/GlobalWheat2020.yaml +68 -0
  18. ultralytics/cfg/datasets/HomeObjects-3K.yaml +32 -0
  19. ultralytics/cfg/datasets/ImageNet.yaml +2025 -0
  20. ultralytics/cfg/datasets/Objects365.yaml +447 -0
  21. ultralytics/cfg/datasets/SKU-110K.yaml +58 -0
  22. ultralytics/cfg/datasets/VOC.yaml +102 -0
  23. ultralytics/cfg/datasets/VisDrone.yaml +87 -0
  24. ultralytics/cfg/datasets/african-wildlife.yaml +25 -0
  25. ultralytics/cfg/datasets/brain-tumor.yaml +22 -0
  26. ultralytics/cfg/datasets/carparts-seg.yaml +44 -0
  27. ultralytics/cfg/datasets/coco-pose.yaml +64 -0
  28. ultralytics/cfg/datasets/coco.yaml +118 -0
  29. ultralytics/cfg/datasets/coco128-seg.yaml +101 -0
  30. ultralytics/cfg/datasets/coco128.yaml +101 -0
  31. ultralytics/cfg/datasets/coco8-grayscale.yaml +103 -0
  32. ultralytics/cfg/datasets/coco8-multispectral.yaml +104 -0
  33. ultralytics/cfg/datasets/coco8-pose.yaml +47 -0
  34. ultralytics/cfg/datasets/coco8-seg.yaml +101 -0
  35. ultralytics/cfg/datasets/coco8.yaml +101 -0
  36. ultralytics/cfg/datasets/construction-ppe.yaml +32 -0
  37. ultralytics/cfg/datasets/crack-seg.yaml +22 -0
  38. ultralytics/cfg/datasets/dog-pose.yaml +52 -0
  39. ultralytics/cfg/datasets/dota8-multispectral.yaml +38 -0
  40. ultralytics/cfg/datasets/dota8.yaml +35 -0
  41. ultralytics/cfg/datasets/hand-keypoints.yaml +50 -0
  42. ultralytics/cfg/datasets/kitti.yaml +27 -0
  43. ultralytics/cfg/datasets/lvis.yaml +1240 -0
  44. ultralytics/cfg/datasets/medical-pills.yaml +21 -0
  45. ultralytics/cfg/datasets/open-images-v7.yaml +663 -0
  46. ultralytics/cfg/datasets/package-seg.yaml +22 -0
  47. ultralytics/cfg/datasets/signature.yaml +21 -0
  48. ultralytics/cfg/datasets/tiger-pose.yaml +41 -0
  49. ultralytics/cfg/datasets/xView.yaml +155 -0
  50. ultralytics/cfg/default.yaml +130 -0
  51. ultralytics/cfg/models/11/yolo11-cls-resnet18.yaml +17 -0
  52. ultralytics/cfg/models/11/yolo11-cls.yaml +33 -0
  53. ultralytics/cfg/models/11/yolo11-obb.yaml +50 -0
  54. ultralytics/cfg/models/11/yolo11-pose.yaml +51 -0
  55. ultralytics/cfg/models/11/yolo11-seg.yaml +50 -0
  56. ultralytics/cfg/models/11/yolo11.yaml +50 -0
  57. ultralytics/cfg/models/11/yoloe-11-seg.yaml +48 -0
  58. ultralytics/cfg/models/11/yoloe-11.yaml +48 -0
  59. ultralytics/cfg/models/12/yolo12-cls.yaml +32 -0
  60. ultralytics/cfg/models/12/yolo12-obb.yaml +48 -0
  61. ultralytics/cfg/models/12/yolo12-pose.yaml +49 -0
  62. ultralytics/cfg/models/12/yolo12-seg.yaml +48 -0
  63. ultralytics/cfg/models/12/yolo12.yaml +48 -0
  64. ultralytics/cfg/models/rt-detr/rtdetr-l.yaml +53 -0
  65. ultralytics/cfg/models/rt-detr/rtdetr-resnet101.yaml +45 -0
  66. ultralytics/cfg/models/rt-detr/rtdetr-resnet50.yaml +45 -0
  67. ultralytics/cfg/models/rt-detr/rtdetr-x.yaml +57 -0
  68. ultralytics/cfg/models/v10/yolov10b.yaml +45 -0
  69. ultralytics/cfg/models/v10/yolov10l.yaml +45 -0
  70. ultralytics/cfg/models/v10/yolov10m.yaml +45 -0
  71. ultralytics/cfg/models/v10/yolov10n.yaml +45 -0
  72. ultralytics/cfg/models/v10/yolov10s.yaml +45 -0
  73. ultralytics/cfg/models/v10/yolov10x.yaml +45 -0
  74. ultralytics/cfg/models/v3/yolov3-spp.yaml +49 -0
  75. ultralytics/cfg/models/v3/yolov3-tiny.yaml +40 -0
  76. ultralytics/cfg/models/v3/yolov3.yaml +49 -0
  77. ultralytics/cfg/models/v5/yolov5-p6.yaml +62 -0
  78. ultralytics/cfg/models/v5/yolov5.yaml +51 -0
  79. ultralytics/cfg/models/v6/yolov6.yaml +56 -0
  80. ultralytics/cfg/models/v8/yoloe-v8-seg.yaml +48 -0
  81. ultralytics/cfg/models/v8/yoloe-v8.yaml +48 -0
  82. ultralytics/cfg/models/v8/yolov8-cls-resnet101.yaml +28 -0
  83. ultralytics/cfg/models/v8/yolov8-cls-resnet50.yaml +28 -0
  84. ultralytics/cfg/models/v8/yolov8-cls.yaml +32 -0
  85. ultralytics/cfg/models/v8/yolov8-ghost-p2.yaml +58 -0
  86. ultralytics/cfg/models/v8/yolov8-ghost-p6.yaml +60 -0
  87. ultralytics/cfg/models/v8/yolov8-ghost.yaml +50 -0
  88. ultralytics/cfg/models/v8/yolov8-obb.yaml +49 -0
  89. ultralytics/cfg/models/v8/yolov8-p2.yaml +57 -0
  90. ultralytics/cfg/models/v8/yolov8-p6.yaml +59 -0
  91. ultralytics/cfg/models/v8/yolov8-pose-p6.yaml +60 -0
  92. ultralytics/cfg/models/v8/yolov8-pose.yaml +50 -0
  93. ultralytics/cfg/models/v8/yolov8-rtdetr.yaml +49 -0
  94. ultralytics/cfg/models/v8/yolov8-seg-p6.yaml +59 -0
  95. ultralytics/cfg/models/v8/yolov8-seg.yaml +49 -0
  96. ultralytics/cfg/models/v8/yolov8-world.yaml +51 -0
  97. ultralytics/cfg/models/v8/yolov8-worldv2.yaml +49 -0
  98. ultralytics/cfg/models/v8/yolov8.yaml +49 -0
  99. ultralytics/cfg/models/v9/yolov9c-seg.yaml +41 -0
  100. ultralytics/cfg/models/v9/yolov9c.yaml +41 -0
  101. ultralytics/cfg/models/v9/yolov9e-seg.yaml +64 -0
  102. ultralytics/cfg/models/v9/yolov9e.yaml +64 -0
  103. ultralytics/cfg/models/v9/yolov9m.yaml +41 -0
  104. ultralytics/cfg/models/v9/yolov9s.yaml +41 -0
  105. ultralytics/cfg/models/v9/yolov9t.yaml +41 -0
  106. ultralytics/cfg/trackers/botsort.yaml +21 -0
  107. ultralytics/cfg/trackers/bytetrack.yaml +12 -0
  108. ultralytics/data/__init__.py +26 -0
  109. ultralytics/data/annotator.py +66 -0
  110. ultralytics/data/augment.py +2801 -0
  111. ultralytics/data/base.py +435 -0
  112. ultralytics/data/build.py +437 -0
  113. ultralytics/data/converter.py +855 -0
  114. ultralytics/data/dataset.py +834 -0
  115. ultralytics/data/loaders.py +704 -0
  116. ultralytics/data/scripts/download_weights.sh +18 -0
  117. ultralytics/data/scripts/get_coco.sh +61 -0
  118. ultralytics/data/scripts/get_coco128.sh +18 -0
  119. ultralytics/data/scripts/get_imagenet.sh +52 -0
  120. ultralytics/data/split.py +138 -0
  121. ultralytics/data/split_dota.py +344 -0
  122. ultralytics/data/utils.py +798 -0
  123. ultralytics/engine/__init__.py +1 -0
  124. ultralytics/engine/exporter.py +1578 -0
  125. ultralytics/engine/model.py +1124 -0
  126. ultralytics/engine/predictor.py +508 -0
  127. ultralytics/engine/results.py +1522 -0
  128. ultralytics/engine/trainer.py +974 -0
  129. ultralytics/engine/tuner.py +448 -0
  130. ultralytics/engine/validator.py +384 -0
  131. ultralytics/hub/__init__.py +166 -0
  132. ultralytics/hub/auth.py +151 -0
  133. ultralytics/hub/google/__init__.py +174 -0
  134. ultralytics/hub/session.py +422 -0
  135. ultralytics/hub/utils.py +162 -0
  136. ultralytics/models/__init__.py +9 -0
  137. ultralytics/models/fastsam/__init__.py +7 -0
  138. ultralytics/models/fastsam/model.py +79 -0
  139. ultralytics/models/fastsam/predict.py +169 -0
  140. ultralytics/models/fastsam/utils.py +23 -0
  141. ultralytics/models/fastsam/val.py +38 -0
  142. ultralytics/models/nas/__init__.py +7 -0
  143. ultralytics/models/nas/model.py +98 -0
  144. ultralytics/models/nas/predict.py +56 -0
  145. ultralytics/models/nas/val.py +38 -0
  146. ultralytics/models/rtdetr/__init__.py +7 -0
  147. ultralytics/models/rtdetr/model.py +63 -0
  148. ultralytics/models/rtdetr/predict.py +88 -0
  149. ultralytics/models/rtdetr/train.py +89 -0
  150. ultralytics/models/rtdetr/val.py +216 -0
  151. ultralytics/models/sam/__init__.py +25 -0
  152. ultralytics/models/sam/amg.py +275 -0
  153. ultralytics/models/sam/build.py +365 -0
  154. ultralytics/models/sam/build_sam3.py +377 -0
  155. ultralytics/models/sam/model.py +169 -0
  156. ultralytics/models/sam/modules/__init__.py +1 -0
  157. ultralytics/models/sam/modules/blocks.py +1067 -0
  158. ultralytics/models/sam/modules/decoders.py +495 -0
  159. ultralytics/models/sam/modules/encoders.py +794 -0
  160. ultralytics/models/sam/modules/memory_attention.py +298 -0
  161. ultralytics/models/sam/modules/sam.py +1160 -0
  162. ultralytics/models/sam/modules/tiny_encoder.py +979 -0
  163. ultralytics/models/sam/modules/transformer.py +344 -0
  164. ultralytics/models/sam/modules/utils.py +512 -0
  165. ultralytics/models/sam/predict.py +3940 -0
  166. ultralytics/models/sam/sam3/__init__.py +3 -0
  167. ultralytics/models/sam/sam3/decoder.py +546 -0
  168. ultralytics/models/sam/sam3/encoder.py +529 -0
  169. ultralytics/models/sam/sam3/geometry_encoders.py +415 -0
  170. ultralytics/models/sam/sam3/maskformer_segmentation.py +286 -0
  171. ultralytics/models/sam/sam3/model_misc.py +199 -0
  172. ultralytics/models/sam/sam3/necks.py +129 -0
  173. ultralytics/models/sam/sam3/sam3_image.py +339 -0
  174. ultralytics/models/sam/sam3/text_encoder_ve.py +307 -0
  175. ultralytics/models/sam/sam3/vitdet.py +547 -0
  176. ultralytics/models/sam/sam3/vl_combiner.py +160 -0
  177. ultralytics/models/utils/__init__.py +1 -0
  178. ultralytics/models/utils/loss.py +466 -0
  179. ultralytics/models/utils/ops.py +315 -0
  180. ultralytics/models/yolo/__init__.py +7 -0
  181. ultralytics/models/yolo/classify/__init__.py +7 -0
  182. ultralytics/models/yolo/classify/predict.py +90 -0
  183. ultralytics/models/yolo/classify/train.py +202 -0
  184. ultralytics/models/yolo/classify/val.py +216 -0
  185. ultralytics/models/yolo/detect/__init__.py +7 -0
  186. ultralytics/models/yolo/detect/predict.py +122 -0
  187. ultralytics/models/yolo/detect/train.py +227 -0
  188. ultralytics/models/yolo/detect/val.py +507 -0
  189. ultralytics/models/yolo/model.py +430 -0
  190. ultralytics/models/yolo/obb/__init__.py +7 -0
  191. ultralytics/models/yolo/obb/predict.py +56 -0
  192. ultralytics/models/yolo/obb/train.py +79 -0
  193. ultralytics/models/yolo/obb/val.py +302 -0
  194. ultralytics/models/yolo/pose/__init__.py +7 -0
  195. ultralytics/models/yolo/pose/predict.py +65 -0
  196. ultralytics/models/yolo/pose/train.py +110 -0
  197. ultralytics/models/yolo/pose/val.py +248 -0
  198. ultralytics/models/yolo/segment/__init__.py +7 -0
  199. ultralytics/models/yolo/segment/predict.py +109 -0
  200. ultralytics/models/yolo/segment/train.py +69 -0
  201. ultralytics/models/yolo/segment/val.py +307 -0
  202. ultralytics/models/yolo/world/__init__.py +5 -0
  203. ultralytics/models/yolo/world/train.py +173 -0
  204. ultralytics/models/yolo/world/train_world.py +178 -0
  205. ultralytics/models/yolo/yoloe/__init__.py +22 -0
  206. ultralytics/models/yolo/yoloe/predict.py +162 -0
  207. ultralytics/models/yolo/yoloe/train.py +287 -0
  208. ultralytics/models/yolo/yoloe/train_seg.py +122 -0
  209. ultralytics/models/yolo/yoloe/val.py +206 -0
  210. ultralytics/nn/__init__.py +27 -0
  211. ultralytics/nn/autobackend.py +958 -0
  212. ultralytics/nn/modules/__init__.py +182 -0
  213. ultralytics/nn/modules/activation.py +54 -0
  214. ultralytics/nn/modules/block.py +1947 -0
  215. ultralytics/nn/modules/conv.py +669 -0
  216. ultralytics/nn/modules/head.py +1183 -0
  217. ultralytics/nn/modules/transformer.py +793 -0
  218. ultralytics/nn/modules/utils.py +159 -0
  219. ultralytics/nn/tasks.py +1768 -0
  220. ultralytics/nn/text_model.py +356 -0
  221. ultralytics/py.typed +1 -0
  222. ultralytics/solutions/__init__.py +41 -0
  223. ultralytics/solutions/ai_gym.py +108 -0
  224. ultralytics/solutions/analytics.py +264 -0
  225. ultralytics/solutions/config.py +107 -0
  226. ultralytics/solutions/distance_calculation.py +123 -0
  227. ultralytics/solutions/heatmap.py +125 -0
  228. ultralytics/solutions/instance_segmentation.py +86 -0
  229. ultralytics/solutions/object_blurrer.py +89 -0
  230. ultralytics/solutions/object_counter.py +190 -0
  231. ultralytics/solutions/object_cropper.py +87 -0
  232. ultralytics/solutions/parking_management.py +280 -0
  233. ultralytics/solutions/queue_management.py +93 -0
  234. ultralytics/solutions/region_counter.py +133 -0
  235. ultralytics/solutions/security_alarm.py +151 -0
  236. ultralytics/solutions/similarity_search.py +219 -0
  237. ultralytics/solutions/solutions.py +828 -0
  238. ultralytics/solutions/speed_estimation.py +114 -0
  239. ultralytics/solutions/streamlit_inference.py +260 -0
  240. ultralytics/solutions/templates/similarity-search.html +156 -0
  241. ultralytics/solutions/trackzone.py +88 -0
  242. ultralytics/solutions/vision_eye.py +67 -0
  243. ultralytics/trackers/__init__.py +7 -0
  244. ultralytics/trackers/basetrack.py +115 -0
  245. ultralytics/trackers/bot_sort.py +257 -0
  246. ultralytics/trackers/byte_tracker.py +469 -0
  247. ultralytics/trackers/track.py +116 -0
  248. ultralytics/trackers/utils/__init__.py +1 -0
  249. ultralytics/trackers/utils/gmc.py +339 -0
  250. ultralytics/trackers/utils/kalman_filter.py +482 -0
  251. ultralytics/trackers/utils/matching.py +154 -0
  252. ultralytics/utils/__init__.py +1450 -0
  253. ultralytics/utils/autobatch.py +118 -0
  254. ultralytics/utils/autodevice.py +205 -0
  255. ultralytics/utils/benchmarks.py +728 -0
  256. ultralytics/utils/callbacks/__init__.py +5 -0
  257. ultralytics/utils/callbacks/base.py +233 -0
  258. ultralytics/utils/callbacks/clearml.py +146 -0
  259. ultralytics/utils/callbacks/comet.py +625 -0
  260. ultralytics/utils/callbacks/dvc.py +197 -0
  261. ultralytics/utils/callbacks/hub.py +110 -0
  262. ultralytics/utils/callbacks/mlflow.py +134 -0
  263. ultralytics/utils/callbacks/neptune.py +126 -0
  264. ultralytics/utils/callbacks/platform.py +313 -0
  265. ultralytics/utils/callbacks/raytune.py +42 -0
  266. ultralytics/utils/callbacks/tensorboard.py +123 -0
  267. ultralytics/utils/callbacks/wb.py +188 -0
  268. ultralytics/utils/checks.py +1006 -0
  269. ultralytics/utils/cpu.py +85 -0
  270. ultralytics/utils/dist.py +123 -0
  271. ultralytics/utils/downloads.py +529 -0
  272. ultralytics/utils/errors.py +35 -0
  273. ultralytics/utils/events.py +113 -0
  274. ultralytics/utils/export/__init__.py +7 -0
  275. ultralytics/utils/export/engine.py +237 -0
  276. ultralytics/utils/export/imx.py +315 -0
  277. ultralytics/utils/export/tensorflow.py +231 -0
  278. ultralytics/utils/files.py +219 -0
  279. ultralytics/utils/git.py +137 -0
  280. ultralytics/utils/instance.py +484 -0
  281. ultralytics/utils/logger.py +501 -0
  282. ultralytics/utils/loss.py +849 -0
  283. ultralytics/utils/metrics.py +1563 -0
  284. ultralytics/utils/nms.py +337 -0
  285. ultralytics/utils/ops.py +664 -0
  286. ultralytics/utils/patches.py +201 -0
  287. ultralytics/utils/plotting.py +1045 -0
  288. ultralytics/utils/tal.py +403 -0
  289. ultralytics/utils/torch_utils.py +984 -0
  290. ultralytics/utils/tqdm.py +440 -0
  291. ultralytics/utils/triton.py +112 -0
  292. ultralytics/utils/tuner.py +160 -0
  293. ultralytics_opencv_headless-8.3.246.dist-info/METADATA +374 -0
  294. ultralytics_opencv_headless-8.3.246.dist-info/RECORD +298 -0
  295. ultralytics_opencv_headless-8.3.246.dist-info/WHEEL +5 -0
  296. ultralytics_opencv_headless-8.3.246.dist-info/entry_points.txt +3 -0
  297. ultralytics_opencv_headless-8.3.246.dist-info/licenses/LICENSE +661 -0
  298. ultralytics_opencv_headless-8.3.246.dist-info/top_level.txt +1 -0
@@ -0,0 +1,5 @@
1
+ # Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license
2
+
3
+ from .base import add_integration_callbacks, default_callbacks, get_default_callbacks
4
+
5
+ __all__ = "add_integration_callbacks", "default_callbacks", "get_default_callbacks"
@@ -0,0 +1,233 @@
1
+ # Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license
2
+ """Base callbacks for Ultralytics training, validation, prediction, and export processes."""
3
+
4
+ from collections import defaultdict
5
+ from copy import deepcopy
6
+
7
+ # Trainer callbacks ----------------------------------------------------------------------------------------------------
8
+
9
+
10
+ def on_pretrain_routine_start(trainer):
11
+ """Called before the pretraining routine starts."""
12
+ pass
13
+
14
+
15
+ def on_pretrain_routine_end(trainer):
16
+ """Called after the pretraining routine ends."""
17
+ pass
18
+
19
+
20
+ def on_train_start(trainer):
21
+ """Called when the training starts."""
22
+ pass
23
+
24
+
25
+ def on_train_epoch_start(trainer):
26
+ """Called at the start of each training epoch."""
27
+ pass
28
+
29
+
30
+ def on_train_batch_start(trainer):
31
+ """Called at the start of each training batch."""
32
+ pass
33
+
34
+
35
+ def optimizer_step(trainer):
36
+ """Called when the optimizer takes a step."""
37
+ pass
38
+
39
+
40
+ def on_before_zero_grad(trainer):
41
+ """Called before the gradients are set to zero."""
42
+ pass
43
+
44
+
45
+ def on_train_batch_end(trainer):
46
+ """Called at the end of each training batch."""
47
+ pass
48
+
49
+
50
+ def on_train_epoch_end(trainer):
51
+ """Called at the end of each training epoch."""
52
+ pass
53
+
54
+
55
+ def on_fit_epoch_end(trainer):
56
+ """Called at the end of each fit epoch (train + val)."""
57
+ pass
58
+
59
+
60
+ def on_model_save(trainer):
61
+ """Called when the model is saved."""
62
+ pass
63
+
64
+
65
+ def on_train_end(trainer):
66
+ """Called when the training ends."""
67
+ pass
68
+
69
+
70
+ def on_params_update(trainer):
71
+ """Called when the model parameters are updated."""
72
+ pass
73
+
74
+
75
+ def teardown(trainer):
76
+ """Called during the teardown of the training process."""
77
+ pass
78
+
79
+
80
+ # Validator callbacks --------------------------------------------------------------------------------------------------
81
+
82
+
83
+ def on_val_start(validator):
84
+ """Called when the validation starts."""
85
+ pass
86
+
87
+
88
+ def on_val_batch_start(validator):
89
+ """Called at the start of each validation batch."""
90
+ pass
91
+
92
+
93
+ def on_val_batch_end(validator):
94
+ """Called at the end of each validation batch."""
95
+ pass
96
+
97
+
98
+ def on_val_end(validator):
99
+ """Called when the validation ends."""
100
+ pass
101
+
102
+
103
+ # Predictor callbacks --------------------------------------------------------------------------------------------------
104
+
105
+
106
+ def on_predict_start(predictor):
107
+ """Called when the prediction starts."""
108
+ pass
109
+
110
+
111
+ def on_predict_batch_start(predictor):
112
+ """Called at the start of each prediction batch."""
113
+ pass
114
+
115
+
116
+ def on_predict_batch_end(predictor):
117
+ """Called at the end of each prediction batch."""
118
+ pass
119
+
120
+
121
+ def on_predict_postprocess_end(predictor):
122
+ """Called after the post-processing of the prediction ends."""
123
+ pass
124
+
125
+
126
+ def on_predict_end(predictor):
127
+ """Called when the prediction ends."""
128
+ pass
129
+
130
+
131
+ # Exporter callbacks ---------------------------------------------------------------------------------------------------
132
+
133
+
134
+ def on_export_start(exporter):
135
+ """Called when the model export starts."""
136
+ pass
137
+
138
+
139
+ def on_export_end(exporter):
140
+ """Called when the model export ends."""
141
+ pass
142
+
143
+
144
+ default_callbacks = {
145
+ # Run in trainer
146
+ "on_pretrain_routine_start": [on_pretrain_routine_start],
147
+ "on_pretrain_routine_end": [on_pretrain_routine_end],
148
+ "on_train_start": [on_train_start],
149
+ "on_train_epoch_start": [on_train_epoch_start],
150
+ "on_train_batch_start": [on_train_batch_start],
151
+ "optimizer_step": [optimizer_step],
152
+ "on_before_zero_grad": [on_before_zero_grad],
153
+ "on_train_batch_end": [on_train_batch_end],
154
+ "on_train_epoch_end": [on_train_epoch_end],
155
+ "on_fit_epoch_end": [on_fit_epoch_end], # fit = train + val
156
+ "on_model_save": [on_model_save],
157
+ "on_train_end": [on_train_end],
158
+ "on_params_update": [on_params_update],
159
+ "teardown": [teardown],
160
+ # Run in validator
161
+ "on_val_start": [on_val_start],
162
+ "on_val_batch_start": [on_val_batch_start],
163
+ "on_val_batch_end": [on_val_batch_end],
164
+ "on_val_end": [on_val_end],
165
+ # Run in predictor
166
+ "on_predict_start": [on_predict_start],
167
+ "on_predict_batch_start": [on_predict_batch_start],
168
+ "on_predict_postprocess_end": [on_predict_postprocess_end],
169
+ "on_predict_batch_end": [on_predict_batch_end],
170
+ "on_predict_end": [on_predict_end],
171
+ # Run in exporter
172
+ "on_export_start": [on_export_start],
173
+ "on_export_end": [on_export_end],
174
+ }
175
+
176
+
177
+ def get_default_callbacks():
178
+ """Get the default callbacks for Ultralytics training, validation, prediction, and export processes.
179
+
180
+ Returns:
181
+ (dict): Dictionary of default callbacks for various training events. Each key represents an event during the
182
+ training process, and the corresponding value is a list of callback functions executed when that
183
+ event occurs.
184
+
185
+ Examples:
186
+ >>> callbacks = get_default_callbacks()
187
+ >>> print(list(callbacks.keys())) # show all available callback events
188
+ ['on_pretrain_routine_start', 'on_pretrain_routine_end', ...]
189
+ """
190
+ return defaultdict(list, deepcopy(default_callbacks))
191
+
192
+
193
+ def add_integration_callbacks(instance):
194
+ """Add integration callbacks to the instance's callbacks dictionary.
195
+
196
+ This function loads and adds various integration callbacks to the provided instance. The specific callbacks added
197
+ depend on the type of instance provided. All instances receive HUB callbacks, while Trainer instances also receive
198
+ additional callbacks for various integrations like ClearML, Comet, DVC, MLflow, Neptune, Ray Tune, TensorBoard, and
199
+ Weights & Biases.
200
+
201
+ Args:
202
+ instance (Trainer | Predictor | Validator | Exporter): The object instance to which callbacks will be added. The
203
+ type of instance determines which callbacks are loaded.
204
+
205
+ Examples:
206
+ >>> from ultralytics.engine.trainer import BaseTrainer
207
+ >>> trainer = BaseTrainer()
208
+ >>> add_integration_callbacks(trainer)
209
+ """
210
+ from .hub import callbacks as hub_cb
211
+ from .platform import callbacks as platform_cb
212
+
213
+ # Load Ultralytics callbacks
214
+ callbacks_list = [hub_cb, platform_cb]
215
+
216
+ # Load training callbacks
217
+ if "Trainer" in instance.__class__.__name__:
218
+ from .clearml import callbacks as clear_cb
219
+ from .comet import callbacks as comet_cb
220
+ from .dvc import callbacks as dvc_cb
221
+ from .mlflow import callbacks as mlflow_cb
222
+ from .neptune import callbacks as neptune_cb
223
+ from .raytune import callbacks as tune_cb
224
+ from .tensorboard import callbacks as tb_cb
225
+ from .wb import callbacks as wb_cb
226
+
227
+ callbacks_list.extend([clear_cb, comet_cb, dvc_cb, mlflow_cb, neptune_cb, tune_cb, tb_cb, wb_cb])
228
+
229
+ # Add the callbacks to the callbacks dictionary
230
+ for callbacks in callbacks_list:
231
+ for k, v in callbacks.items():
232
+ if v not in instance.callbacks[k]:
233
+ instance.callbacks[k].append(v)
@@ -0,0 +1,146 @@
1
+ # Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license
2
+
3
+ from ultralytics.utils import LOGGER, SETTINGS, TESTS_RUNNING
4
+
5
+ try:
6
+ assert not TESTS_RUNNING # do not log pytest
7
+ assert SETTINGS["clearml"] is True # verify integration is enabled
8
+ import clearml
9
+ from clearml import Task
10
+
11
+ assert hasattr(clearml, "__version__") # verify package is not directory
12
+
13
+ except (ImportError, AssertionError):
14
+ clearml = None
15
+
16
+
17
+ def _log_debug_samples(files, title: str = "Debug Samples") -> None:
18
+ """Log files (images) as debug samples in the ClearML task.
19
+
20
+ Args:
21
+ files (list[Path]): A list of file paths in PosixPath format.
22
+ title (str): A title that groups together images with the same values.
23
+ """
24
+ import re
25
+
26
+ if task := Task.current_task():
27
+ for f in files:
28
+ if f.exists():
29
+ it = re.search(r"_batch(\d+)", f.name)
30
+ iteration = int(it.groups()[0]) if it else 0
31
+ task.get_logger().report_image(
32
+ title=title, series=f.name.replace(it.group(), ""), local_path=str(f), iteration=iteration
33
+ )
34
+
35
+
36
+ def _log_plot(title: str, plot_path: str) -> None:
37
+ """Log an image as a plot in the plot section of ClearML.
38
+
39
+ Args:
40
+ title (str): The title of the plot.
41
+ plot_path (str): The path to the saved image file.
42
+ """
43
+ import matplotlib.image as mpimg
44
+ import matplotlib.pyplot as plt
45
+
46
+ img = mpimg.imread(plot_path)
47
+ fig = plt.figure()
48
+ ax = fig.add_axes([0, 0, 1, 1], frameon=False, aspect="auto", xticks=[], yticks=[]) # no ticks
49
+ ax.imshow(img)
50
+
51
+ Task.current_task().get_logger().report_matplotlib_figure(
52
+ title=title, series="", figure=fig, report_interactive=False
53
+ )
54
+
55
+
56
+ def on_pretrain_routine_start(trainer) -> None:
57
+ """Initialize and connect ClearML task at the start of pretraining routine."""
58
+ try:
59
+ if task := Task.current_task():
60
+ # WARNING: make sure the automatic pytorch and matplotlib bindings are disabled!
61
+ # We are logging these plots and model files manually in the integration
62
+ from clearml.binding.frameworks.pytorch_bind import PatchPyTorchModelIO
63
+ from clearml.binding.matplotlib_bind import PatchedMatplotlib
64
+
65
+ PatchPyTorchModelIO.update_current_task(None)
66
+ PatchedMatplotlib.update_current_task(None)
67
+ else:
68
+ task = Task.init(
69
+ project_name=trainer.args.project or "Ultralytics",
70
+ task_name=trainer.args.name,
71
+ tags=["Ultralytics"],
72
+ output_uri=True,
73
+ reuse_last_task_id=False,
74
+ auto_connect_frameworks={"pytorch": False, "matplotlib": False},
75
+ )
76
+ LOGGER.warning(
77
+ "ClearML Initialized a new task. If you want to run remotely, "
78
+ "please add clearml-init and connect your arguments before initializing YOLO."
79
+ )
80
+ task.connect(vars(trainer.args), name="General")
81
+ except Exception as e:
82
+ LOGGER.warning(f"ClearML installed but not initialized correctly, not logging this run. {e}")
83
+
84
+
85
+ def on_train_epoch_end(trainer) -> None:
86
+ """Log debug samples for the first epoch and report current training progress."""
87
+ if task := Task.current_task():
88
+ # Log debug samples for first epoch only
89
+ if trainer.epoch == 1:
90
+ _log_debug_samples(sorted(trainer.save_dir.glob("train_batch*.jpg")), "Mosaic")
91
+ # Report the current training progress
92
+ for k, v in trainer.label_loss_items(trainer.tloss, prefix="train").items():
93
+ task.get_logger().report_scalar("train", k, v, iteration=trainer.epoch)
94
+ for k, v in trainer.lr.items():
95
+ task.get_logger().report_scalar("lr", k, v, iteration=trainer.epoch)
96
+
97
+
98
+ def on_fit_epoch_end(trainer) -> None:
99
+ """Report model information and metrics to logger at the end of an epoch."""
100
+ if task := Task.current_task():
101
+ # Report epoch time and validation metrics
102
+ task.get_logger().report_scalar(
103
+ title="Epoch Time", series="Epoch Time", value=trainer.epoch_time, iteration=trainer.epoch
104
+ )
105
+ for k, v in trainer.metrics.items():
106
+ title = k.split("/")[0]
107
+ task.get_logger().report_scalar(title, k, v, iteration=trainer.epoch)
108
+ if trainer.epoch == 0:
109
+ from ultralytics.utils.torch_utils import model_info_for_loggers
110
+
111
+ for k, v in model_info_for_loggers(trainer).items():
112
+ task.get_logger().report_single_value(k, v)
113
+
114
+
115
+ def on_val_end(validator) -> None:
116
+ """Log validation results including labels and predictions."""
117
+ if Task.current_task():
118
+ # Log validation labels and predictions
119
+ _log_debug_samples(sorted(validator.save_dir.glob("val*.jpg")), "Validation")
120
+
121
+
122
+ def on_train_end(trainer) -> None:
123
+ """Log final model and training results on training completion."""
124
+ if task := Task.current_task():
125
+ # Log final results, confusion matrix and PR plots
126
+ for f in [*trainer.plots.keys(), *trainer.validator.plots.keys()]:
127
+ if "batch" not in f.name:
128
+ _log_plot(title=f.stem, plot_path=f)
129
+ # Report final metrics
130
+ for k, v in trainer.validator.metrics.results_dict.items():
131
+ task.get_logger().report_single_value(k, v)
132
+ # Log the final model
133
+ task.update_output_model(model_path=str(trainer.best), model_name=trainer.args.name, auto_delete_file=False)
134
+
135
+
136
+ callbacks = (
137
+ {
138
+ "on_pretrain_routine_start": on_pretrain_routine_start,
139
+ "on_train_epoch_end": on_train_epoch_end,
140
+ "on_fit_epoch_end": on_fit_epoch_end,
141
+ "on_val_end": on_val_end,
142
+ "on_train_end": on_train_end,
143
+ }
144
+ if clearml
145
+ else {}
146
+ )