ultralytics 8.2.21__py3-none-any.whl → 8.2.22__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 ultralytics might be problematic. Click here for more details.

ultralytics/__init__.py CHANGED
@@ -1,6 +1,6 @@
1
1
  # Ultralytics YOLO 🚀, AGPL-3.0 license
2
2
 
3
- __version__ = "8.2.21"
3
+ __version__ = "8.2.22"
4
4
 
5
5
  from ultralytics.data.explorer.explorer import Explorer
6
6
  from ultralytics.models import RTDETR, SAM, YOLO, YOLOWorld
@@ -874,11 +874,56 @@ class Albumentations:
874
874
  self.p = p
875
875
  self.transform = None
876
876
  prefix = colorstr("albumentations: ")
877
+
877
878
  try:
878
879
  import albumentations as A
879
880
 
880
881
  check_version(A.__version__, "1.0.3", hard=True) # version requirement
881
882
 
883
+ # List of possible spatial transforms
884
+ spatial_transforms = {
885
+ "Affine",
886
+ "BBoxSafeRandomCrop",
887
+ "CenterCrop",
888
+ "CoarseDropout",
889
+ "Crop",
890
+ "CropAndPad",
891
+ "CropNonEmptyMaskIfExists",
892
+ "D4",
893
+ "ElasticTransform",
894
+ "Flip",
895
+ "GridDistortion",
896
+ "GridDropout",
897
+ "HorizontalFlip",
898
+ "Lambda",
899
+ "LongestMaxSize",
900
+ "MaskDropout",
901
+ "MixUp",
902
+ "Morphological",
903
+ "NoOp",
904
+ "OpticalDistortion",
905
+ "PadIfNeeded",
906
+ "Perspective",
907
+ "PiecewiseAffine",
908
+ "PixelDropout",
909
+ "RandomCrop",
910
+ "RandomCropFromBorders",
911
+ "RandomGridShuffle",
912
+ "RandomResizedCrop",
913
+ "RandomRotate90",
914
+ "RandomScale",
915
+ "RandomSizedBBoxSafeCrop",
916
+ "RandomSizedCrop",
917
+ "Resize",
918
+ "Rotate",
919
+ "SafeRotate",
920
+ "ShiftScaleRotate",
921
+ "SmallestMaxSize",
922
+ "Transpose",
923
+ "VerticalFlip",
924
+ "XYMasking",
925
+ } # from https://albumentations.ai/docs/getting_started/transforms_and_targets/#spatial-level-transforms
926
+
882
927
  # Transforms
883
928
  T = [
884
929
  A.Blur(p=0.01),
@@ -889,8 +934,14 @@ class Albumentations:
889
934
  A.RandomGamma(p=0.0),
890
935
  A.ImageCompression(quality_lower=75, p=0.0),
891
936
  ]
892
- self.transform = A.Compose(T, bbox_params=A.BboxParams(format="yolo", label_fields=["class_labels"]))
893
937
 
938
+ # Compose transforms
939
+ self.contains_spatial = any(transform.__class__.__name__ in spatial_transforms for transform in T)
940
+ self.transform = (
941
+ A.Compose(T, bbox_params=A.BboxParams(format="yolo", label_fields=["class_labels"]))
942
+ if self.contains_spatial
943
+ else A.Compose(T)
944
+ )
894
945
  LOGGER.info(prefix + ", ".join(f"{x}".replace("always_apply=False, ", "") for x in T if x.p))
895
946
  except ImportError: # package not installed, skip
896
947
  pass
@@ -899,20 +950,26 @@ class Albumentations:
899
950
 
900
951
  def __call__(self, labels):
901
952
  """Generates object detections and returns a dictionary with detection results."""
902
- im = labels["img"]
903
- cls = labels["cls"]
904
- if len(cls):
905
- labels["instances"].convert_bbox("xywh")
906
- labels["instances"].normalize(*im.shape[:2][::-1])
907
- bboxes = labels["instances"].bboxes
908
- # TODO: add supports of segments and keypoints
909
- if self.transform and random.random() < self.p:
953
+ if self.transform is None or random.random() > self.p:
954
+ return labels
955
+
956
+ if self.contains_spatial:
957
+ cls = labels["cls"]
958
+ if len(cls):
959
+ im = labels["img"]
960
+ labels["instances"].convert_bbox("xywh")
961
+ labels["instances"].normalize(*im.shape[:2][::-1])
962
+ bboxes = labels["instances"].bboxes
963
+ # TODO: add supports of segments and keypoints
910
964
  new = self.transform(image=im, bboxes=bboxes, class_labels=cls) # transformed
911
965
  if len(new["class_labels"]) > 0: # skip update if no bbox in new im
912
966
  labels["img"] = new["image"]
913
967
  labels["cls"] = np.array(new["class_labels"])
914
968
  bboxes = np.array(new["bboxes"], dtype=np.float32)
915
- labels["instances"].update(bboxes=bboxes)
969
+ labels["instances"].update(bboxes=bboxes)
970
+ else:
971
+ labels["img"] = self.transform(image=labels["img"])["image"] # transformed
972
+
916
973
  return labels
917
974
 
918
975
 
@@ -5,7 +5,7 @@ from .analytics import Analytics
5
5
  from .distance_calculation import DistanceCalculation
6
6
  from .heatmap import Heatmap
7
7
  from .object_counter import ObjectCounter
8
- from .parking_management import ParkingManagement
8
+ from .parking_management import ParkingManagement, ParkingPtsSelection
9
9
  from .queue_management import QueueManager
10
10
  from .speed_estimation import SpeedEstimator
11
11
 
@@ -1,3 +1,5 @@
1
+ # Ultralytics YOLO 🚀, AGPL-3.0 license
2
+
1
3
  from itertools import cycle
2
4
 
3
5
  import cv2
@@ -1,3 +1,5 @@
1
+ # Ultralytics YOLO 🚀, AGPL-3.0 license
2
+
1
3
  import json
2
4
  from tkinter import filedialog, messagebox
3
5
 
@@ -10,32 +12,31 @@ from ultralytics.utils.plotting import Annotator
10
12
 
11
13
 
12
14
  class ParkingPtsSelection:
13
- def __init__(self, master):
14
- """
15
- Initializes the UI for selecting parking zone points in a tkinter window.
16
-
17
- Args:
18
- master (tk.Tk): The main tkinter window object.
19
- """
15
+ def __init__(self):
16
+ """Initializes the UI for selecting parking zone points in a tkinter window."""
20
17
  check_requirements("tkinter")
18
+
21
19
  import tkinter as tk
22
20
 
23
- self.master = master
24
- master.title("Ultralytics Parking Zones Points Selector")
21
+ self.tk = tk
22
+ self.master = tk.Tk()
23
+ self.master.title("Ultralytics Parking Zones Points Selector")
25
24
 
26
25
  # Disable window resizing
27
- master.resizable(False, False)
26
+ self.master.resizable(False, False)
28
27
 
29
28
  # Setup canvas for image display
30
- self.canvas = tk.Canvas(master, bg="white")
29
+ self.canvas = self.tk.Canvas(self.master, bg="white")
31
30
 
32
31
  # Setup buttons
33
- button_frame = tk.Frame(master)
34
- button_frame.pack(side=tk.TOP)
32
+ button_frame = self.tk.Frame(self.master)
33
+ button_frame.pack(side=self.tk.TOP)
35
34
 
36
- tk.Button(button_frame, text="Upload Image", command=self.upload_image).grid(row=0, column=0)
37
- tk.Button(button_frame, text="Remove Last BBox", command=self.remove_last_bounding_box).grid(row=0, column=1)
38
- tk.Button(button_frame, text="Save", command=self.save_to_json).grid(row=0, column=2)
35
+ self.tk.Button(button_frame, text="Upload Image", command=self.upload_image).grid(row=0, column=0)
36
+ self.tk.Button(button_frame, text="Remove Last BBox", command=self.remove_last_bounding_box).grid(
37
+ row=0, column=1
38
+ )
39
+ self.tk.Button(button_frame, text="Save", command=self.save_to_json).grid(row=0, column=2)
39
40
 
40
41
  # Initialize properties
41
42
  self.image_path = None
@@ -50,6 +51,8 @@ class ParkingPtsSelection:
50
51
  self.canvas_max_width = 1280
51
52
  self.canvas_max_height = 720
52
53
 
54
+ self.master.mainloop()
55
+
53
56
  def upload_image(self):
54
57
  """Upload an image and resize it to fit canvas."""
55
58
  self.image_path = filedialog.askopenfilename(filetypes=[("Image Files", "*.png;*.jpg;*.jpeg")])
@@ -74,12 +77,12 @@ class ParkingPtsSelection:
74
77
  if self.canvas:
75
78
  self.canvas.destroy() # Destroy previous canvas
76
79
 
77
- self.canvas = tk.Canvas(self.master, bg="white", width=canvas_width, height=canvas_height)
80
+ self.canvas = self.tk.Canvas(self.master, bg="white", width=canvas_width, height=canvas_height)
78
81
  resized_image = self.image.resize((canvas_width, canvas_height), Image.LANCZOS)
79
82
  self.canvas_image = ImageTk.PhotoImage(resized_image)
80
- self.canvas.create_image(0, 0, anchor=tk.NW, image=self.canvas_image)
83
+ self.canvas.create_image(0, 0, anchor=self.tk.NW, image=self.canvas_image)
81
84
 
82
- self.canvas.pack(side=tk.BOTTOM)
85
+ self.canvas.pack(side=self.tk.BOTTOM)
83
86
  self.canvas.bind("<Button-1>", self.on_canvas_click)
84
87
 
85
88
  # Reset bounding boxes and current box
@@ -115,7 +118,7 @@ class ParkingPtsSelection:
115
118
  if self.bounding_boxes:
116
119
  self.bounding_boxes.pop() # Remove the last bounding box
117
120
  self.canvas.delete("all") # Clear the canvas
118
- self.canvas.create_image(0, 0, anchor=tk.NW, image=self.canvas_image) # Redraw the image
121
+ self.canvas.create_image(0, 0, anchor=self.tk.NW, image=self.canvas_image) # Redraw the image
119
122
 
120
123
  # Redraw all bounding boxes
121
124
  for box in self.bounding_boxes:
@@ -210,6 +213,7 @@ class ParkingManagement:
210
213
  im0 (ndarray): inference image
211
214
  boxes (list): bounding boxes data
212
215
  clss (list): bounding boxes classes list
216
+
213
217
  Returns:
214
218
  filled_slots (int): total slots that are filled in parking lot
215
219
  empty_slots (int): total slots that are available in parking lot
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: ultralytics
3
- Version: 8.2.21
3
+ Version: 8.2.22
4
4
  Summary: Ultralytics YOLOv8 for SOTA object detection, multi-object tracking, instance segmentation, pose estimation and image classification.
5
5
  Author: Glenn Jocher, Ayush Chaurasia, Jing Qiu
6
6
  Maintainer: Glenn Jocher, Ayush Chaurasia, Jing Qiu
@@ -7,7 +7,7 @@ tests/test_explorer.py,sha256=r1pWer2y290Y0DqsM-La7egfEY0497YCdC4rwq3URV4,2178
7
7
  tests/test_exports.py,sha256=TTmwlY3FAcVPffUFP9La0vpzNnfKYjej5nKqurCbwZg,6863
8
8
  tests/test_integrations.py,sha256=J3D_LAy5gaawoLEMDrCj4HO8965o4kK1t4UBRot6EEw,5848
9
9
  tests/test_python.py,sha256=invyej59wozoSZV4Rb7zwkgyVkRZrL149e-xb-c7xew,20086
10
- ultralytics/__init__.py,sha256=t6lbjDI5WGi4FmWuecXODe58PRDP7YbTpDJlVIvyN_E,633
10
+ ultralytics/__init__.py,sha256=dfT25agEhxx4fmylSQF8MO-vmCllbHmQne6L3UMxsv0,633
11
11
  ultralytics/assets/bus.jpg,sha256=wCAZxJecGR63Od3ZRERe9Aja1Weayrb9Ug751DS_vGM,137419
12
12
  ultralytics/assets/zidane.jpg,sha256=Ftc4aeMmen1O0A3o6GCDO9FlfBslLpTAw0gnetx7bts,50427
13
13
  ultralytics/cfg/__init__.py,sha256=lR6jykSO_0cigsjrqSyFj_8JG_LvYi796viasyWhcfs,21358
@@ -74,7 +74,7 @@ ultralytics/cfg/trackers/botsort.yaml,sha256=YrPmj18p1UU40kJH5NRdL_4S8f7knggkk_q
74
74
  ultralytics/cfg/trackers/bytetrack.yaml,sha256=QvHmtuwulK4X6j3T5VEqtCm0sbWWBUVmWPcCcM20qe0,688
75
75
  ultralytics/data/__init__.py,sha256=VGe-ATG7j35F4A4r8Jmzffjlhve4JAJPgRa5ahKTU18,616
76
76
  ultralytics/data/annotator.py,sha256=evXQzARVerc0hb9ol-n_GrrHf-dlXO4lCMMWEZoJ2UM,2117
77
- ultralytics/data/augment.py,sha256=OyGg5Ltmhi6sH8ImEiolr6KaiJPPB7bPqqcd3OHo_fQ,57665
77
+ ultralytics/data/augment.py,sha256=XOcVRcc1qx3b98YdvrpwNPgNBeJAx2fpC06Y7XLAdkw,59600
78
78
  ultralytics/data/base.py,sha256=C3teLnw97ZTbpJHT9P7yYWosAKocMzgJjRe1rxgfpls,13524
79
79
  ultralytics/data/build.py,sha256=nFdshVSDqU-tY9luH1T-cYnWHEdh9PtxRkwrs2UahMo,7268
80
80
  ultralytics/data/converter.py,sha256=NLDiV67RshbKQnMJUiQQF11boVzEqgi2Hz39nKVAI4U,17528
@@ -163,13 +163,13 @@ ultralytics/nn/modules/conv.py,sha256=Ywe87IhuaS22mR2JJ9xjnW8Sb-m7WTjxuqIxV_Dv8l
163
163
  ultralytics/nn/modules/head.py,sha256=3N_4zW1UvhI1jCrIxIkNYxQDdiW6HxtxpaNAAudq6NU,22236
164
164
  ultralytics/nn/modules/transformer.py,sha256=AxD9uURpCl-EqvXe3DiG6JW-pBzB16G-AahLdZ7yayo,17909
165
165
  ultralytics/nn/modules/utils.py,sha256=779QnnKp9v8jv251ESduTXJ0ol8HkIOLbGQWwEGQjhU,3196
166
- ultralytics/solutions/__init__.py,sha256=ZeIPizmm2SM0e7KZ7nmh9WWNYChSszWwDmHB-WAfaAY,540
166
+ ultralytics/solutions/__init__.py,sha256=S4m7p_rpg2pk9PdnqqD-6Sk--wDHxZSo7cUZjSwj_iQ,561
167
167
  ultralytics/solutions/ai_gym.py,sha256=HDzzvBVFqWgQw2IgtEx5Eo3tEKbFRY3gkiVqax-4j2w,4683
168
- ultralytics/solutions/analytics.py,sha256=ddv-5ertQAzZmhfIi9G6PK3Z1mK8mCKWUwRVgJACves,7050
168
+ ultralytics/solutions/analytics.py,sha256=qJihaifoNLGKEq_6kpMzkz_6a2tvzbO9WlYPzYsZtuk,7093
169
169
  ultralytics/solutions/distance_calculation.py,sha256=pSIkyytHGRAaNzIrkkNkiOnSVWU1PYvURlCIV_jRORA,6505
170
170
  ultralytics/solutions/heatmap.py,sha256=AHXnmXhoQ95ph74zsdrvX_Lfy3wF0SsH0MIeTixE7Qg,10386
171
171
  ultralytics/solutions/object_counter.py,sha256=htcQGWJX1y-vXVV1yUiTDT3sm8ByItjSNfu2Rl2IEmk,10808
172
- ultralytics/solutions/parking_management.py,sha256=b0ZyIspCULKO0OIYHEi7x2BqMBQR-QPmOxDfcfuU2ho,9696
172
+ ultralytics/solutions/parking_management.py,sha256=Bd7FU3WZ8mRBWq81Z5c8jH5WloF4jPKo8TycqU_AcEI,9786
173
173
  ultralytics/solutions/queue_management.py,sha256=ECm6gLZplmE9Cm-zdOazHBBDcW-vvr8nx2M28fcPbts,6787
174
174
  ultralytics/solutions/speed_estimation.py,sha256=kjqMSHGTHMZaNgTKNKWULxnJQNsvhq4WMUphMVlBjsc,6768
175
175
  ultralytics/trackers/__init__.py,sha256=j72IgH2dZHQArMPK4YwcV5ieIw94fYvlGdQjB9cOQKw,227
@@ -210,9 +210,9 @@ ultralytics/utils/callbacks/neptune.py,sha256=5Z3ua5YBTUS56FH8VQKQG1aaIo9fH8GEyz
210
210
  ultralytics/utils/callbacks/raytune.py,sha256=ODVYzy-CoM4Uge0zjkh3Hnh9nF2M0vhDrSenXnvcizw,705
211
211
  ultralytics/utils/callbacks/tensorboard.py,sha256=Z1veCVcn9THPhdplWuIzwlsW2yF7y-On9IZIk3khM0Y,4135
212
212
  ultralytics/utils/callbacks/wb.py,sha256=DViD0KeXH_i3eVT_CLR4bZFs1TMMUZBVBBYIS3aUfp0,6745
213
- ultralytics-8.2.21.dist-info/LICENSE,sha256=DZak_2itbUtvHzD3E7GNUYSRK6jdOJ-GqncQ2weavLA,34523
214
- ultralytics-8.2.21.dist-info/METADATA,sha256=ghZ90c82ushTyA0ZcMQNYD8Gyb9sZpA05EWJRMsPKm8,40694
215
- ultralytics-8.2.21.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
216
- ultralytics-8.2.21.dist-info/entry_points.txt,sha256=YM_wiKyTe9yRrsEfqvYolNO5ngwfoL4-NwgKzc8_7sI,93
217
- ultralytics-8.2.21.dist-info/top_level.txt,sha256=XP49TwiMw4QGsvTLSYiJhz1xF_k7ev5mQ8jJXaXi45Q,12
218
- ultralytics-8.2.21.dist-info/RECORD,,
213
+ ultralytics-8.2.22.dist-info/LICENSE,sha256=DZak_2itbUtvHzD3E7GNUYSRK6jdOJ-GqncQ2weavLA,34523
214
+ ultralytics-8.2.22.dist-info/METADATA,sha256=yGRHf0twNJq8pZiVky6jN2QLl01kpiRsc9p9o-YCuqI,40694
215
+ ultralytics-8.2.22.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
216
+ ultralytics-8.2.22.dist-info/entry_points.txt,sha256=YM_wiKyTe9yRrsEfqvYolNO5ngwfoL4-NwgKzc8_7sI,93
217
+ ultralytics-8.2.22.dist-info/top_level.txt,sha256=XP49TwiMw4QGsvTLSYiJhz1xF_k7ev5mQ8jJXaXi45Q,12
218
+ ultralytics-8.2.22.dist-info/RECORD,,