__init__.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. # ------------------ Dataset Config ------------------
  2. from .data_config.dataset_config import dataset_cfg
  3. def build_dataset_config(args):
  4. if args.dataset in ['coco', 'coco-val', 'coco-test']:
  5. cfg = dataset_cfg['coco']
  6. else:
  7. cfg = dataset_cfg[args.dataset]
  8. print('==============================')
  9. print('Dataset Config: {} \n'.format(cfg))
  10. return cfg
  11. # ------------------ Transform Config ------------------
  12. from .data_config.transform_config import (
  13. # YOLOv5-Style
  14. yolov5_pico_trans_config,
  15. yolov5_nano_trans_config,
  16. yolov5_small_trans_config,
  17. yolov5_medium_trans_config,
  18. yolov5_large_trans_config,
  19. yolov5_huge_trans_config,
  20. # YOLOX-Style
  21. yolox_pico_trans_config,
  22. yolox_nano_trans_config,
  23. yolox_small_trans_config,
  24. yolox_medium_trans_config,
  25. yolox_large_trans_config,
  26. yolox_huge_trans_config,
  27. # SSD-Style
  28. ssd_trans_config,
  29. )
  30. def build_trans_config(trans_config='ssd'):
  31. print('==============================')
  32. print('Transform: {}-Style ...'.format(trans_config))
  33. # SSD-style transform
  34. if trans_config == 'ssd':
  35. cfg = ssd_trans_config
  36. # YOLOv5-style transform
  37. elif trans_config == 'yolov5_pico':
  38. cfg = yolov5_pico_trans_config
  39. elif trans_config == 'yolov5_nano':
  40. cfg = yolov5_nano_trans_config
  41. elif trans_config == 'yolov5_small':
  42. cfg = yolov5_small_trans_config
  43. elif trans_config == 'yolov5_medium':
  44. cfg = yolov5_medium_trans_config
  45. elif trans_config == 'yolov5_large':
  46. cfg = yolov5_large_trans_config
  47. elif trans_config == 'yolov5_huge':
  48. cfg = yolov5_huge_trans_config
  49. # YOLOX-style transform
  50. elif trans_config == 'yolox_pico':
  51. cfg = yolox_pico_trans_config
  52. elif trans_config == 'yolox_nano':
  53. cfg = yolox_nano_trans_config
  54. elif trans_config == 'yolox_small':
  55. cfg = yolox_small_trans_config
  56. elif trans_config == 'yolox_medium':
  57. cfg = yolox_medium_trans_config
  58. elif trans_config == 'yolox_large':
  59. cfg = yolox_large_trans_config
  60. elif trans_config == 'yolox_huge':
  61. cfg = yolox_huge_trans_config
  62. print('Transform Config: {} \n'.format(cfg))
  63. return cfg
  64. # ------------------ Model Config ------------------
  65. ## YOLO series
  66. from .model_config.yolov1_config import yolov1_cfg
  67. from .model_config.yolov2_config import yolov2_cfg
  68. from .model_config.yolov3_config import yolov3_cfg
  69. from .model_config.yolov4_config import yolov4_cfg
  70. from .model_config.yolov5_config import yolov5_cfg
  71. from .model_config.yolov7_config import yolov7_cfg
  72. from .model_config.yolox_config import yolox_cfg
  73. ## My RTMDet series
  74. from .model_config.rtcdet_config import rtcdet_cfg
  75. def build_model_config(args):
  76. print('==============================')
  77. print('Model: {} ...'.format(args.model.upper()))
  78. # YOLOv1
  79. if args.model == 'yolov1':
  80. cfg = yolov1_cfg
  81. # YOLOv2
  82. elif args.model == 'yolov2':
  83. cfg = yolov2_cfg
  84. # YOLOv3
  85. elif args.model in ['yolov3', 'yolov3_tiny']:
  86. cfg = yolov3_cfg[args.model]
  87. # YOLOv4
  88. elif args.model in ['yolov4', 'yolov4_tiny']:
  89. cfg = yolov4_cfg[args.model]
  90. # YOLOv5
  91. elif args.model in ['yolov5_n', 'yolov5_s', 'yolov5_m', 'yolov5_l', 'yolov5_x']:
  92. cfg = yolov5_cfg[args.model]
  93. # YOLOv7
  94. elif args.model in ['yolov7_tiny', 'yolov7', 'yolov7_x']:
  95. cfg = yolov7_cfg[args.model]
  96. # YOLOX
  97. elif args.model in ['yolox_n', 'yolox_s', 'yolox_m', 'yolox_l', 'yolox_x']:
  98. cfg = yolox_cfg[args.model]
  99. # RTCDet
  100. elif args.model in ['rtcdet_p', 'rtcdet_n', 'rtcdet_t', 'rtcdet_s', 'rtcdet_m', 'rtcdet_l', 'rtcdet_x']:
  101. cfg = rtcdet_cfg[args.model]
  102. return cfg