ultralytics 8.3.62__py3-none-any.whl → 8.3.63__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.
ultralytics/__init__.py CHANGED
@@ -1,6 +1,6 @@
1
1
  # Ultralytics 🚀 AGPL-3.0 License - https://ultralytics.com/license
2
2
 
3
- __version__ = "8.3.62"
3
+ __version__ = "8.3.63"
4
4
 
5
5
  import os
6
6
 
ultralytics/data/build.py CHANGED
@@ -49,10 +49,11 @@ class InfiniteDataLoader(dataloader.DataLoader):
49
49
 
50
50
  def __del__(self):
51
51
  """Ensure that workers are terminated."""
52
- for w in self.iterator._workers: # force terminate
53
- if w.is_alive():
54
- w.terminate()
55
- self.iterator._shutdown_workers() # cleanup
52
+ if hasattr(self.iterator, "_workers"):
53
+ for w in self.iterator._workers: # force terminate
54
+ if w.is_alive():
55
+ w.terminate()
56
+ self.iterator._shutdown_workers() # cleanup
56
57
 
57
58
  def reset(self):
58
59
  """
ultralytics/data/utils.py CHANGED
@@ -567,7 +567,7 @@ class HUBDatasetStats:
567
567
 
568
568
  # Get dataset statistics
569
569
  if self.task == "classify":
570
- from torchvision.datasets import ImageFolder
570
+ from torchvision.datasets import ImageFolder # scope for faster 'import ultralytics'
571
571
 
572
572
  dataset = ImageFolder(self.data[split])
573
573
 
@@ -91,7 +91,13 @@ from ultralytics.utils import (
91
91
  get_default_args,
92
92
  yaml_save,
93
93
  )
94
- from ultralytics.utils.checks import check_imgsz, check_is_path_safe, check_requirements, check_version
94
+ from ultralytics.utils.checks import (
95
+ check_imgsz,
96
+ check_is_path_safe,
97
+ check_requirements,
98
+ check_version,
99
+ is_sudo_available,
100
+ )
95
101
  from ultralytics.utils.downloads import attempt_download_asset, get_github_assets, safe_download
96
102
  from ultralytics.utils.files import file_size, spaces_in_path
97
103
  from ultralytics.utils.ops import Profile
@@ -1071,7 +1077,6 @@ class Exporter:
1071
1077
  assert LINUX, f"export only supported on Linux. See {help_url}"
1072
1078
  if subprocess.run(cmd, stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL, shell=True).returncode != 0:
1073
1079
  LOGGER.info(f"\n{prefix} export requires Edge TPU compiler. Attempting install from {help_url}")
1074
- sudo = subprocess.run("sudo --version >/dev/null", shell=True).returncode == 0 # sudo installed on system
1075
1080
  for c in (
1076
1081
  "curl https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -",
1077
1082
  'echo "deb https://packages.cloud.google.com/apt coral-edgetpu-stable main" | '
@@ -1079,7 +1084,7 @@ class Exporter:
1079
1084
  "sudo apt-get update",
1080
1085
  "sudo apt-get install edgetpu-compiler",
1081
1086
  ):
1082
- subprocess.run(c if sudo else c.replace("sudo ", ""), shell=True, check=True)
1087
+ subprocess.run(c if is_sudo_available() else c.replace("sudo ", ""), shell=True, check=True)
1083
1088
  ver = subprocess.run(cmd, shell=True, capture_output=True, check=True).stdout.decode().split()[-1]
1084
1089
 
1085
1090
  LOGGER.info(f"\n{prefix} starting export with Edge TPU compiler {ver}...")
@@ -1160,7 +1165,10 @@ class Exporter:
1160
1165
  if "openjdk 17" not in str(out.stdout):
1161
1166
  raise FileNotFoundError
1162
1167
  except FileNotFoundError:
1163
- subprocess.run(["sudo", "apt", "install", "-y", "openjdk-17-jdk", "openjdk-17-jre"], check=True)
1168
+ c = ["apt", "install", "-y", "openjdk-17-jdk", "openjdk-17-jre"]
1169
+ if is_sudo_available():
1170
+ c.insert(0, "sudo")
1171
+ subprocess.run(c, check=True)
1164
1172
 
1165
1173
  def representative_dataset_gen(dataloader=self.get_int8_calibration_dataloader(prefix)):
1166
1174
  for batch in dataloader:
@@ -839,7 +839,7 @@ class Results(SimpleClass):
839
839
  >>> df_result = results[0].to_df()
840
840
  >>> print(df_result)
841
841
  """
842
- import pandas as pd
842
+ import pandas as pd # scope for faster 'import ultralytics'
843
843
 
844
844
  return pd.DataFrame(self.summary(normalize=normalize, decimals=decimals))
845
845
 
@@ -271,6 +271,7 @@ class BaseTrainer:
271
271
  )
272
272
  if world_size > 1:
273
273
  self.model = nn.parallel.DistributedDataParallel(self.model, device_ids=[RANK], find_unused_parameters=True)
274
+ self.set_model_attributes() # set again after DDP wrapper
274
275
 
275
276
  # Check imgsz
276
277
  gs = max(int(self.model.stride.max() if hasattr(self.model, "stride") else 32), 32) # grid size (max stride)
@@ -1131,7 +1131,7 @@ class TorchVision(nn.Module):
1131
1131
 
1132
1132
  def __init__(self, c1, c2, model, weights="DEFAULT", unwrap=True, truncate=2, split=False):
1133
1133
  """Load the model and weights from torchvision."""
1134
- import torchvision
1134
+ import torchvision # scope for faster 'import ultralytics'
1135
1135
 
1136
1136
  super().__init__()
1137
1137
  if hasattr(torchvision.models, "get_model"):
ultralytics/nn/tasks.py CHANGED
@@ -7,6 +7,7 @@ import types
7
7
  from copy import deepcopy
8
8
  from pathlib import Path
9
9
 
10
+ import thop
10
11
  import torch
11
12
  import torch.nn as nn
12
13
 
@@ -86,11 +87,6 @@ from ultralytics.utils.torch_utils import (
86
87
  time_sync,
87
88
  )
88
89
 
89
- try:
90
- import thop
91
- except ImportError:
92
- thop = None
93
-
94
90
 
95
91
  class BaseModel(nn.Module):
96
92
  """The BaseModel class serves as a base class for all the models in the Ultralytics YOLO family."""
@@ -782,6 +782,18 @@ def cuda_is_available() -> bool:
782
782
  return cuda_device_count() > 0
783
783
 
784
784
 
785
+ def is_sudo_available() -> bool:
786
+ """
787
+ Check if the sudo command is available in the environment.
788
+
789
+ Returns:
790
+ bool: True if the sudo command is available, False otherwise.
791
+ """
792
+ if WINDOWS:
793
+ return False
794
+ return subprocess.run(["sudo", "--version"], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL).returncode == 0
795
+
796
+
785
797
  # Run checks and define constants
786
798
  check_python("3.8", hard=False, verbose=True) # check python version
787
799
  check_torchvision() # check torch-torchvision compatibility
@@ -12,6 +12,7 @@ from pathlib import Path
12
12
  from typing import Union
13
13
 
14
14
  import numpy as np
15
+ import thop
15
16
  import torch
16
17
  import torch.distributed as dist
17
18
  import torch.nn as nn
@@ -30,11 +31,6 @@ from ultralytics.utils import (
30
31
  )
31
32
  from ultralytics.utils.checks import check_version
32
33
 
33
- try:
34
- import thop
35
- except ImportError:
36
- thop = None
37
-
38
34
  # Version checks (all default to version>=min_version)
39
35
  TORCH_1_9 = check_version(torch.__version__, "1.9.0")
40
36
  TORCH_1_13 = check_version(torch.__version__, "1.13.0")
@@ -367,9 +363,6 @@ def model_info_for_loggers(trainer):
367
363
 
368
364
  def get_flops(model, imgsz=640):
369
365
  """Return a YOLO model's FLOPs."""
370
- if not thop:
371
- return 0.0 # if not installed return 0.0 GFLOPs
372
-
373
366
  try:
374
367
  model = de_parallel(model)
375
368
  p = next(model.parameters())
@@ -674,7 +667,7 @@ def profile(input, ops, n=10, device=None, max_num_obj=0):
674
667
  m = m.half() if hasattr(m, "half") and isinstance(x, torch.Tensor) and x.dtype is torch.float16 else m
675
668
  tf, tb, t = 0, 0, [0, 0, 0] # dt forward, backward
676
669
  try:
677
- flops = thop.profile(m, inputs=[x], verbose=False)[0] / 1e9 * 2 if thop else 0 # GFLOPs
670
+ flops = thop.profile(m, inputs=[x], verbose=False)[0] / 1e9 * 2 # GFLOPs
678
671
  except Exception:
679
672
  flops = 0
680
673
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: ultralytics
3
- Version: 8.3.62
3
+ Version: 8.3.63
4
4
  Summary: Ultralytics YOLO 🚀 for SOTA object detection, multi-object tracking, instance segmentation, pose estimation and image classification.
5
5
  Author-email: Glenn Jocher <glenn.jocher@ultralytics.com>, Jing Qiu <jing.qiu@ultralytics.com>
6
6
  Maintainer-email: Ultralytics <hello@ultralytics.com>
@@ -7,7 +7,7 @@ tests/test_exports.py,sha256=bvi2GgwxiAIpnAEQQ4iImffA7zke65_CDwoXOF7anuE,8797
7
7
  tests/test_integrations.py,sha256=p3DMnnPMKsV0Qm82JVJUIY1UZ67xRgF9E8AaL76TEHE,6154
8
8
  tests/test_python.py,sha256=tW-EFJC2rjl_DvAa8khXGWYdypseQjrLjGHhe2p9r9A,23238
9
9
  tests/test_solutions.py,sha256=aY0G3vNzXGCENG9FD76MfUp7jgzeESPsUvbvQYBUvH0,4205
10
- ultralytics/__init__.py,sha256=pEv-5OhALZ4K3_-5J8oYJDzOlz0DjKBjMdw_KS3erec,709
10
+ ultralytics/__init__.py,sha256=sEEOEjr5AbRIanmikSj9X77osBrjhBQkbM_yZAUJjFw,709
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=9xBYqfr4VxaDx3MkyK0ePIOr8iZ7BfCC2H1VNqfFInQ,39601
@@ -95,18 +95,18 @@ ultralytics/data/__init__.py,sha256=nAXaL1puCc7z_NjzQNlJnhbVhT9Fla2u7Dsqo7q1dAc,
95
95
  ultralytics/data/annotator.py,sha256=jbKHB5l5IYOG1YOgCxA6czU_ivb3NPAACrtPe6-bVn4,3145
96
96
  ultralytics/data/augment.py,sha256=A9yBpNU0JkHMNTYdsN1gYPwmXFjb2S23i7HU99Bsqlk,120719
97
97
  ultralytics/data/base.py,sha256=NTNdn-Emgx3Z2vats8i8oEe-9yosPmHd53v1A0xz0EU,15196
98
- ultralytics/data/build.py,sha256=QJoGCkIwoRgwUhLBq9db1_ZfYRDEemKVEgQUr3_yU88,7535
98
+ ultralytics/data/build.py,sha256=TsDx_rNzREtSPs07_qtQALNdZ5w7OV9SJ4I1JXY9wcY,7598
99
99
  ultralytics/data/converter.py,sha256=89E44LBCpbn5hMF03Kdts6DaTP8Oei5iCra5enFCt5I,24467
100
100
  ultralytics/data/dataset.py,sha256=lxtH3JytNu6nsiPAIhe0uGuGGpkZ4ZRqvXM6eJw9rXU,23244
101
101
  ultralytics/data/loaders.py,sha256=JOwXbz-dxgG2bx0_cQHp-olz5FleoCX8EzrUvZ77vvg,28534
102
102
  ultralytics/data/split_dota.py,sha256=NgnGcEJE2iVfGCoJUIeKUxhu_kGg6dln6UTajUqT-_k,10720
103
- ultralytics/data/utils.py,sha256=9b9RDQGw-XZFHpFCrNWLQJdgBJg8fQJalYS7r1GNUKU,33801
103
+ ultralytics/data/utils.py,sha256=EoSlxcz5orjChBZbtzgIyddKuO3DFcuKVRBUWvpEk_4,33842
104
104
  ultralytics/engine/__init__.py,sha256=lm6MckFYCPTbqIoX7w0s_daxdjNeBeKW6DXppv1-QUM,70
105
- ultralytics/engine/exporter.py,sha256=uazRrAa65xI5xT2c_Ez3vkEvCDrinhXn-pvYMf085n8,69133
105
+ ultralytics/engine/exporter.py,sha256=tijlUOzhJHs6IUExYLGMLPDdxVpruPb9BmPmTRZ8s24,69155
106
106
  ultralytics/engine/model.py,sha256=tgzwnspighsesavuOEpirHS_5VPukQinj9sBAUnXpUE,53110
107
107
  ultralytics/engine/predictor.py,sha256=I66hWs-SV6Yu8QTsrr9ZEWqfDblKdQkJaIqyHoFHgeQ,17740
108
- ultralytics/engine/results.py,sha256=3sU3n2WkGhx4GNSVGLRSrWuSoKn31DEBQ9cV_PMmUzU,75073
109
- ultralytics/engine/trainer.py,sha256=QizL2LbsHDN6GozL36I0Nw-2dTzvgIcDhGc8dmlgSJ0,37363
108
+ ultralytics/engine/results.py,sha256=sf_JPDTp9lCrcjdloTsZOBbSfzX5oVW9CL6PYf-uW8U,75114
109
+ ultralytics/engine/trainer.py,sha256=1zT-C9YeByROTO8nEq38fzGYMt15sizkAuDHcRYEcu8,37434
110
110
  ultralytics/engine/tuner.py,sha256=IQcKuaCaJ-Toe5xA2DUvlFN577PiS2NGDU8YFbWLqO0,11886
111
111
  ultralytics/engine/validator.py,sha256=snmE1O0wJIX610bvSOk6pV_jf2pXEQ8IdvKVkX8_agI,14901
112
112
  ultralytics/hub/__init__.py,sha256=1ifzSYV0PIT4ZWOm2V7HnpGyY3G3hCz0malw3AXHFlY,5660
@@ -173,10 +173,10 @@ ultralytics/models/yolo/world/train.py,sha256=6PVmQ0G-22OOPPwP_rqSobe2LM6e2b_lC7
173
173
  ultralytics/models/yolo/world/train_world.py,sha256=sCtg4Hnq9Y7amYjlQsdvTHXH8cKSooipvcXu_1Iyb2k,4885
174
174
  ultralytics/nn/__init__.py,sha256=rjociYD9lo_K-d-1s6TbdWklPLjTcEHk7OIlRDJstIE,615
175
175
  ultralytics/nn/autobackend.py,sha256=ONLwYlT8tu6_U0ghXfcNmG6eH9UWH-HDwnBQH2mbYWs,35540
176
- ultralytics/nn/tasks.py,sha256=WtyNUOMk7tg-Cmw7EyrKrWk2LKqVg53J-Jo_2W6ikLQ,48605
176
+ ultralytics/nn/tasks.py,sha256=KRmrjqWcCPgZEnb3O6Nj8Gutl-LUsWwxY_l-cIotS5o,48559
177
177
  ultralytics/nn/modules/__init__.py,sha256=02dPoAMtpPNQdHXHmvJeWZvJ_WG6eqwH8atLdFWgcuY,2713
178
178
  ultralytics/nn/modules/activation.py,sha256=oRkhMdqlNpIxQb35pTSUeHV-h0VyLl96GOqvIZ4OvT8,923
179
- ultralytics/nn/modules/block.py,sha256=_kM3ifWv7COi_18_47bQ_zRPV0Jfe61LiqTcBR8WQWI,43947
179
+ ultralytics/nn/modules/block.py,sha256=HauBQiSIH9JFmT-gnk_8FNJfYfhW2heoY3iU6AdIjv0,43988
180
180
  ultralytics/nn/modules/conv.py,sha256=P3R8xTuE7GMJ2DJ_ye7D54Gh56tfh4ykNnIXBG2QcNQ,13140
181
181
  ultralytics/nn/modules/head.py,sha256=RYT31wplr64yDSHLpEZy3fyqg9W8HWlXWKrltwpqGiQ,27962
182
182
  ultralytics/nn/modules/transformer.py,sha256=fdc4xam82Dk8etahkhlc5RHW6dfY00klKj2od4QpdQo,18097
@@ -207,7 +207,7 @@ ultralytics/trackers/utils/matching.py,sha256=jOGfDMaWUOGHy3e_SF-vn7m0t8nUgLNsiB
207
207
  ultralytics/utils/__init__.py,sha256=2bVRKAmCrlTYigV51YI0wXM4U4sHPWXcyjTxiuhBVxw,49330
208
208
  ultralytics/utils/autobatch.py,sha256=zc81HlAMArPASEbExty0E_zpITF8PVwin7w-xBFFZ5w,5048
209
209
  ultralytics/utils/benchmarks.py,sha256=Njv__APyz_q39wpwVBPC7qTbFBLEWNx_72arkPxo_6U,25671
210
- ultralytics/utils/checks.py,sha256=FC0r80cUNzDnxJByiohIrvSo-k4iCa197lwwf3IwM4I,30152
210
+ ultralytics/utils/checks.py,sha256=BbOVv3aJLhjFiS2F1Dgq3ztAvc5fcQTCqJ_B1Sb-8xc,30506
211
211
  ultralytics/utils/dist.py,sha256=fuiJQEnyyL-SighlI3hUlZPaaSreUl4Q39snF6OhQtI,2386
212
212
  ultralytics/utils/downloads.py,sha256=n5htu7rIp6izCeObZLjwaIz8t4RqoivmC2pYEa63KJo,21999
213
213
  ultralytics/utils/errors.py,sha256=sXKDEd8ws3L-yIfG_-P_h86axbm37sJNha7kFBJbQMQ,844
@@ -219,7 +219,7 @@ ultralytics/utils/ops.py,sha256=6nERPkmssU1I2RykKF5jKdadiHgCeD7qHXOld6bOfXI,3357
219
219
  ultralytics/utils/patches.py,sha256=ARR89dP4YKq7Dd3g2eU-ukbnc2lo3BELukL_1c_d854,3298
220
220
  ultralytics/utils/plotting.py,sha256=cl8mctrkBMMTE976yrqDn1I8dH6IPO3ROZl99t5fo9w,62987
221
221
  ultralytics/utils/tal.py,sha256=DO-c006HEI62pcrNRpmt4lpqJPC5yu3veRDOvUuExno,18498
222
- ultralytics/utils/torch_utils.py,sha256=f8B8vXxl36nesoWqm3KnCyojmjriDX71q1jBOS3vEHg,33291
222
+ ultralytics/utils/torch_utils.py,sha256=JQ8HvqIVD-iL640vPBD4e9uOihhVhMuFL2G-BR-AxSM,33155
223
223
  ultralytics/utils/triton.py,sha256=2L1_rZ8xCJEjexRVj75g9YU-u4tQln_DJ5N1Yr_0bSs,4071
224
224
  ultralytics/utils/tuner.py,sha256=zhYAvVlUO4Bkijoscwlf_IKyE2FSJpFep_esuFLrG0c,6226
225
225
  ultralytics/utils/callbacks/__init__.py,sha256=hzL63Rce6VkZhP4Lcim9LKjadixaQG86nKqPhk7IkS0,242
@@ -233,9 +233,9 @@ ultralytics/utils/callbacks/neptune.py,sha256=waZ_bRu0-qBKujTLuqonC2gx2DkgBuVnfq
233
233
  ultralytics/utils/callbacks/raytune.py,sha256=TbuZlDb721aIkh-nMozZcP2g_ttUh2cG5LUaXmept6g,728
234
234
  ultralytics/utils/callbacks/tensorboard.py,sha256=JHOEVlNQ5dYJPd4Z-EvqbXowuK5uA0p8wPgyyaIUQs0,4194
235
235
  ultralytics/utils/callbacks/wb.py,sha256=ayhT2y62AcSOacnawshATU0rWrlSFQ77mrGgBdRl3W4,7086
236
- ultralytics-8.3.62.dist-info/LICENSE,sha256=DZak_2itbUtvHzD3E7GNUYSRK6jdOJ-GqncQ2weavLA,34523
237
- ultralytics-8.3.62.dist-info/METADATA,sha256=wsCGKfKBKG8oIe0Lt_obELU70mPY67jp9UpNaLuudsM,35284
238
- ultralytics-8.3.62.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
239
- ultralytics-8.3.62.dist-info/entry_points.txt,sha256=YM_wiKyTe9yRrsEfqvYolNO5ngwfoL4-NwgKzc8_7sI,93
240
- ultralytics-8.3.62.dist-info/top_level.txt,sha256=XP49TwiMw4QGsvTLSYiJhz1xF_k7ev5mQ8jJXaXi45Q,12
241
- ultralytics-8.3.62.dist-info/RECORD,,
236
+ ultralytics-8.3.63.dist-info/LICENSE,sha256=DZak_2itbUtvHzD3E7GNUYSRK6jdOJ-GqncQ2weavLA,34523
237
+ ultralytics-8.3.63.dist-info/METADATA,sha256=H2F-IYlnZkUf_fpdzSXQS76dTk0Jkld2FdRiVPqgvFo,35284
238
+ ultralytics-8.3.63.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
239
+ ultralytics-8.3.63.dist-info/entry_points.txt,sha256=YM_wiKyTe9yRrsEfqvYolNO5ngwfoL4-NwgKzc8_7sI,93
240
+ ultralytics-8.3.63.dist-info/top_level.txt,sha256=XP49TwiMw4QGsvTLSYiJhz1xF_k7ev5mQ8jJXaXi45Q,12
241
+ ultralytics-8.3.63.dist-info/RECORD,,