Some checks failed
deploy / build-n-publish (push) Has been cancelled
lint / lint (push) Has been cancelled
build / build_cpu (3.7, 1.5.1, torch1.5, 0.6.1) (push) Has been cancelled
build / build_cpu (3.7, 1.6.0, torch1.6, 0.7.0) (push) Has been cancelled
build / build_cpu (3.7, 1.7.0, torch1.7, 0.8.1) (push) Has been cancelled
build / build_cpu (3.7, 1.8.0, torch1.8, 0.9.0) (push) Has been cancelled
build / build_cpu (3.7, 1.9.0, torch1.9, 0.10.0) (push) Has been cancelled
build / build_cuda101 (3.7, 1.5.1+cu101, torch1.5, 0.6.1+cu101) (push) Has been cancelled
build / build_cuda101 (3.7, 1.6.0+cu101, torch1.6, 0.7.0+cu101) (push) Has been cancelled
build / build_cuda101 (3.7, 1.7.0+cu101, torch1.7, 0.8.1+cu101) (push) Has been cancelled
build / build_cuda101 (3.7, 1.8.0+cu101, torch1.8, 0.9.0+cu101) (push) Has been cancelled
build / build_cuda102 (3.6, 1.9.0+cu102, torch1.9, 0.10.0+cu102) (push) Has been cancelled
build / build_cuda102 (3.7, 1.9.0+cu102, torch1.9, 0.10.0+cu102) (push) Has been cancelled
build / build_cuda102 (3.8, 1.9.0+cu102, torch1.9, 0.10.0+cu102) (push) Has been cancelled
build / build_cuda102 (3.9, 1.9.0+cu102, torch1.9, 0.10.0+cu102) (push) Has been cancelled
build / test_windows (windows-2022, cpu, 3.8) (push) Has been cancelled
build / test_windows (windows-2022, cu111, 3.8) (push) Has been cancelled
- Add golf1/2/4/7/8 dataset classes for semantic segmentation - Add kneron-specific configs (meconfig series, kn_stdc1_golf4class) - Organize scripts into tools/check/ and tools/kneron/ - Add kneron_preprocessing module - Update README with quick-start guide - Update .gitignore to exclude data dirs, onnx, nef outputs Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
81 lines
2.9 KiB
Python
81 lines
2.9 KiB
Python
# Copyright (c) OpenMMLab. All rights reserved.
|
|
import os.path as osp
|
|
import mmcv
|
|
import numpy as np
|
|
from mmcv.utils import print_log
|
|
from PIL import Image
|
|
|
|
from .builder import DATASETS
|
|
from .custom import CustomDataset
|
|
|
|
@DATASETS.register_module()
|
|
class GrassOnlyDataset(CustomDataset):
|
|
"""GrassOnlyDataset for semantic segmentation with only one valid class: grass."""
|
|
|
|
CLASSES = ('grass',)
|
|
|
|
PALETTE = [
|
|
[0, 128, 0], # grass - green
|
|
]
|
|
|
|
def __init__(self,
|
|
img_suffix='_leftImg8bit.png',
|
|
seg_map_suffix='_gtFine_labelIds.png',
|
|
**kwargs):
|
|
super(GrassOnlyDataset, self).__init__(
|
|
img_suffix=img_suffix,
|
|
seg_map_suffix=seg_map_suffix,
|
|
**kwargs)
|
|
|
|
print("✅ [GrassOnlyDataset] 初始化完成")
|
|
print(f" ➤ CLASSES: {self.CLASSES}")
|
|
print(f" ➤ PALETTE: {self.PALETTE}")
|
|
print(f" ➤ img_suffix: {img_suffix}")
|
|
print(f" ➤ seg_map_suffix: {seg_map_suffix}")
|
|
print(f" ➤ img_dir: {self.img_dir}")
|
|
print(f" ➤ ann_dir: {self.ann_dir}")
|
|
print(f" ➤ dataset length: {len(self)}")
|
|
|
|
def results2img(self, results, imgfile_prefix, indices=None):
|
|
"""Write the segmentation results to images."""
|
|
if indices is None:
|
|
indices = list(range(len(self)))
|
|
|
|
mmcv.mkdir_or_exist(imgfile_prefix)
|
|
result_files = []
|
|
for result, idx in zip(results, indices):
|
|
filename = self.img_infos[idx]['filename']
|
|
basename = osp.splitext(osp.basename(filename))[0]
|
|
png_filename = osp.join(imgfile_prefix, f'{basename}.png')
|
|
|
|
output = Image.fromarray(result.astype(np.uint8)).convert('P')
|
|
palette = np.zeros((len(self.PALETTE), 3), dtype=np.uint8)
|
|
for label_id, color in enumerate(self.PALETTE):
|
|
palette[label_id] = color
|
|
output.putpalette(palette)
|
|
output.save(png_filename)
|
|
result_files.append(png_filename)
|
|
|
|
return result_files
|
|
|
|
def format_results(self, results, imgfile_prefix, indices=None):
|
|
"""Format the results into dir (for evaluation or visualization)."""
|
|
return self.results2img(results, imgfile_prefix, indices)
|
|
|
|
def evaluate(self,
|
|
results,
|
|
metric='mIoU',
|
|
logger=None,
|
|
imgfile_prefix=None):
|
|
"""Evaluate the results with the given metric."""
|
|
print("🧪 [GrassOnlyDataset.evaluate] 被呼叫")
|
|
print(f" ➤ 當前 CLASSES: {self.CLASSES}")
|
|
print(f" ➤ 評估 metric: {metric}")
|
|
print(f" ➤ 結果數量: {len(results)}")
|
|
|
|
metrics = metric if isinstance(metric, list) else [metric]
|
|
eval_results = super(GrassOnlyDataset, self).evaluate(results, metrics, logger)
|
|
|
|
print(f" ➤ 返回評估指標: {list(eval_results.keys())}")
|
|
return eval_results
|