- prediction/image/ FastAPI 서버 Docker 환경 구성 - Dockerfile: PyTorch 2.1 + CUDA 12.1 기반 GPU 이미지 - docker-compose.yml: GPU 할당 + 데이터 볼륨 마운트 - requirements.txt: 서버 의존성 목록 - .env.example: 환경변수 템플릿 - DOCKER_USAGE.md: 빌드/실행/API 사용법 문서 - Dockerfile에 .dockerignore 제외 폴더 mkdir -p 추가 - .gitignore: prediction/image 결과물 및 모델 가중치(.pth) 제외 추가 - dbInsert_csv.py, dbInsert_shp.py 삭제 (미사용 DB 로직) - api.py: dbInsert import 및 주석 처리된 DB 호출 코드 제거 - aerialRouter.ts: req.params 타입 오류 수정
53 lines
1.5 KiB
Python
53 lines
1.5 KiB
Python
# Copyright (c) OpenMMLab. All rights reserved.
|
|
import collections
|
|
|
|
from mmcv.utils import build_from_cfg
|
|
|
|
from ..builder import PIPELINES
|
|
|
|
|
|
@PIPELINES.register_module()
|
|
class Compose(object):
|
|
"""Compose multiple transforms sequentially.
|
|
|
|
Args:
|
|
transforms (Sequence[dict | callable]): Sequence of transform object or
|
|
config dict to be composed.
|
|
"""
|
|
|
|
def __init__(self, transforms):
|
|
assert isinstance(transforms, collections.abc.Sequence)
|
|
self.transforms = []
|
|
for transform in transforms:
|
|
if isinstance(transform, dict):
|
|
transform = build_from_cfg(transform, PIPELINES)
|
|
self.transforms.append(transform)
|
|
elif callable(transform):
|
|
self.transforms.append(transform)
|
|
else:
|
|
raise TypeError('transform must be callable or a dict')
|
|
|
|
def __call__(self, data):
|
|
"""Call function to apply transforms sequentially.
|
|
|
|
Args:
|
|
data (dict): A result dict contains the data to transform.
|
|
|
|
Returns:
|
|
dict: Transformed data.
|
|
"""
|
|
|
|
for t in self.transforms:
|
|
data = t(data)
|
|
if data is None:
|
|
return None
|
|
return data
|
|
|
|
def __repr__(self):
|
|
format_string = self.__class__.__name__ + '('
|
|
for t in self.transforms:
|
|
format_string += '\n'
|
|
format_string += f' {t}'
|
|
format_string += '\n)'
|
|
return format_string
|