Neck-Organ-Seg.yaml 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. # Train/val/test sets as 1) dir: path/to/imgs, 2) file: path/to/imgs.txt, or 3) list: [path/to/imgs1, path/to/imgs2, ..]
  2. path: organ-seg # dataset root dir
  3. train: images/train # train images (relative to 'path') 128 images
  4. val: images/val # val images (relative to 'path') 128 images
  5. test: # test images (optional)
  6. # 平台训练需要给到下面的参数
  7. platform_data_args:
  8. token: 4925EC4929684AA0ABB0173B03CFC8FF # 39829c10d79745c6aaac35df80811966 4925EC4929684AA0ABB0173B03CFC8FF
  9. # 错误文件
  10. wrong_file: ''
  11. # "segment"生成分割的数据 "detection"生成检测的数据
  12. data_type: "segment"
  13. # 有些项目需要裁图,给到相应的裁图参数,
  14. # 如果不需要裁图,直接给 "" 即可
  15. extra_contours_args: ""
  16. # 所需的图像标签字典,从0开始,都是背景
  17. # 如果为空,给 "" 即可
  18. needed_image_results_dict:
  19. "颈部图像":
  20. "无可标项": 0
  21. # 所需的ROI标签字典,从1开始都是需要的标签(取到的标签最终都会减1,yolo那边默认从0开始作为第一类)
  22. # 从部位标签开始取,如果不同部位标签内,相同名字的作为一类,则给相同的数字;不作为一类,则给不同的数字
  23. needed_rois_dict:
  24. "颈部图像":
  25. "甲状腺横切": 1
  26. "甲状腺纵切": 1
  27. "颈动脉短轴": 2
  28. "颈动脉长轴": 2
  29. "颈部气管": 3
  30. # 一张图有多个ROI标签和图像标签时,后续采用谁的类别作为该图的扩充比例,给到相应的强弱等级
  31. # 该等级只用来比较多标签时,选择哪个作为扩充比例
  32. # 如果有多个相同的强弱等级的话,则按最后一个取到的标签的强弱等级计算
  33. # 该参数的键跟 needed_image_results_dict 和 needed_rois_dict一致
  34. label_aug_level:
  35. "颈部图像":
  36. "无可标项": 1
  37. "甲状腺横切": 1
  38. "甲状腺纵切": 1
  39. "颈动脉短轴": 1
  40. "颈动脉长轴": 1
  41. "颈部气管": 1
  42. # 所需标签在训练时的扩充比例,根据原有的数量*扩充比例
  43. # 所需标签的扩充比例都来自于needed_image_results_dict 和 needed_rois_dict
  44. # 额外添加了一个空字符:如果出现一张图有roi标签,但是没有所需的roi标签,则该图像也会作为背景进行训练,该图像的扩充比例即为空字符对应的数字
  45. # 需要注意:1.不裁图时,如果出现一张图只有图像标签,没有roi标签,但是没有所需的图像标签,则该图像直接舍弃。
  46. # 需要注意:2.裁图时,如果出现一张图没有额外轮廓,则该图像直接舍弃。
  47. class_aug_times:
  48. '': 1
  49. "颈部图像":
  50. "无可标项": 1
  51. "甲状腺横切": 1
  52. "甲状腺纵切": 1
  53. "颈动脉短轴": 1
  54. "颈动脉长轴": 1
  55. "颈部气管": 1
  56. # 评价指标计算时,各类别最终输出计算的标签字典
  57. # 可能设置多种参数,比如:甲状腺、乳腺疾病,计算分级、良恶性、检出病灶 三种输出的评价指标
  58. # 0为背景,其他都是类别
  59. class_id_map_list: [
  60. {0: 0, 1: 1, 2: 2, 3: 3},
  61. ]
  62. # c++后处理的dll
  63. dll_file: 'vinno_files/depends/YOLOInstanceSegOutputPostProcessUtil.dll'
  64. # 该resize方式只针对后续调用c++后处理时,图像的resize方式,不影响yolo本身训练的resize方式
  65. # resize方式跟c#中EnumResizeMode一致,会影响MoldedImageMetas的数值,从而影响c++后处理时返回原图的坐标
  66. # FitLargeSizeAndPad:以长边为准,将原始图像等比例缩放,短边用固定灰度值填充,暂时固定灰度值没有给到参数设置,默认给的128,128,128,后续需要改成和c#那边一致
  67. # FitSmallSizeAndCrop:以短边为准,将原始图像等比例缩放,长边直接裁切掉不要
  68. # Warp:非等比例缩放,长短边各自伸缩到模型所需的尺寸
  69. resize_mode: Warp
  70. # yolo后处理需要的参数
  71. yolo_inst_seg_metas:
  72. yolo_type: yolov8
  73. box_conf_thres: 0.8
  74. cls_conf_thres: 0.8
  75. batch_size: 1
  76. max_det: 5
  77. min_box_ratio: 0.001
  78. post_process_top_k: 6400
  79. iou_fltth: 0.3
  80. ios_fltth: 0.5
  81. enable_iou_filt: true
  82. enable_ios_filt: true
  83. iou_fltth_diff_cls: 0.3
  84. ios_fltth_diff_cls: 0.3
  85. enable_iou_filt_diff_cls: false
  86. enable_ios_filt_diff_cls: false
  87. mask_thres: 0.5
  88. # 用于c++的后处理参数,跟c#那边一致即可
  89. seg_post_process_param:
  90. 1:
  91. max_lesion_count: 2
  92. lesion_area_requirements:
  93. # NoneType (不设面积阈值)
  94. # PixelInMask(面积阈值是在mask上的像素数)
  95. # RatioInMask(面积阈值是病灶面积占mask的比例)
  96. # PixelInOrigImg(面积阈值是在原图上的像素数)
  97. # RatioInOrigImg(面积阈值是病灶面积占原图的比例)
  98. - lesion_area_threshold_type: RatioInMask
  99. lesion_min_area: 0.04
  100. lesion_max_area: 1.0
  101. 2:
  102. max_lesion_count: 1
  103. lesion_area_requirements:
  104. - lesion_area_threshold_type: RatioInMask
  105. lesion_min_area: 0.01
  106. lesion_max_area: 1.0
  107. 3:
  108. max_lesion_count: 1
  109. lesion_area_requirements:
  110. - lesion_area_threshold_type: RatioInMask
  111. lesion_min_area: 0.04
  112. lesion_max_area: 1.0
  113. # 评价指标
  114. metrics_type:
  115. - pascal:
  116. iou_threshold: 0.5
  117. method_average_precision: EVERY_POINT_INTERPOLATION # EVERY_POINT_INTERPOLATION 或者 ELEVEN_POINT_INTERPOLATION
  118. generate_table: false
  119. # fn错误的有两种,一种是iou低于设置(也就是fp),一种是没有检测出来,为了方便查看,此时统计的fn将fp排除
  120. generate_fp_fn_image_names: true # 是否记录fp和fn所在图像的名称,用于可能后续画gt和dt看结果
  121. - coco:
  122. # coco默认计算0.5-0.95的mAP,这边给到值可以设置,所需要的范围
  123. lower_iou_threshold_limit: 0.50
  124. upper_iou_threshold_limit: 0.95
  125. # 默认前100个检测的结果,可以进行设置
  126. max_dets: 100
  127. # 根据面积区分 small medium large,计算时取 值的平方 作为界限
  128. lower_area_limit: 32
  129. upper_area_limit: 96
  130. # 最终训练的类别,目标从零开始,背景没有标签,对应的名称只是为了最终结果的显示
  131. names:
  132. 0: thyroid
  133. 1: carotidArtery
  134. 2: trachea