일반적인 YOLO 문제 해결
소개
이 가이드는 Ultralytics 프로젝트에서 YOLO26을 작업할 때 발생하는 일반적인 문제를 해결하기 위한 포괄적인 도움말을 제공합니다. 올바른 지침을 따르면 이러한 문제를 쉽게 해결하여 프로젝트가 불필요한 지연 없이 원활하게 진행되도록 할 수 있습니다.
Watch: Ultralytics YOLO26 Common Issues | Installation Errors, Model Training Issues
일반적인 문제
설치 오류
설치 오류는 호환되지 않는 버전, 누락된 종속성 또는 잘못된 환경 설정 등 다양한 이유로 발생할 수 있습니다. 먼저 다음 사항을 확인하십시오.
- 권장 사양인 Python 3.8 이상을 사용하고 있습니다.
- 올바른 버전의 PyTorch (1.8 이상)가 설치되어 있는지 확인하십시오.
- 충돌을 피하기 위해 가상 환경 사용을 고려하십시오.
- 공식 설치 가이드를 단계별로 따르십시오.
또한 사용자가 자주 겪는 일반적인 설치 문제와 그에 따른 해결 방법은 다음과 같습니다.
-
Import 오류 또는 종속성 문제 - YOLO26을 가져오는(import) 중에 오류가 발생하거나 종속성 관련 문제가 있는 경우 다음 문제 해결 단계를 고려하십시오.
-
새로 설치: 때로는 새로 설치하는 것만으로 예상치 못한 문제가 해결될 수 있습니다. 특히 Ultralytics와 같이 업데이트를 통해 파일 트리 구조나 기능이 변경될 수 있는 라이브러리의 경우 더욱 그렇습니다.
-
정기 업데이트: 최신 버전의 라이브러리를 사용하고 있는지 확인하십시오. 이전 버전은 최신 업데이트와 호환되지 않아 잠재적인 충돌이나 문제가 발생할 수 있습니다.
-
종속성 확인: 필요한 모든 종속성이 올바르게 설치되었으며 호환되는 버전인지 확인하십시오.
-
변경 사항 검토: 초기 버전의 라이브러리를 복제하거나 설치한 경우, 중요한 업데이트가 라이브러리 구조나 기능에 영향을 줄 수 있음을 유의하십시오. 중요한 변경 사항을 이해하려면 항상 공식 문서나 변경 로그를 참조하십시오.
-
라이브러리와 종속성을 최신 상태로 유지하는 것이 원활하고 오류 없는 환경을 위해 매우 중요함을 기억하십시오.
-
-
GPU에서 YOLO26 실행하기 - GPU에서 YOLO26을 실행하는 데 어려움이 있는 경우 다음 문제 해결 단계를 고려하십시오.
-
CUDA 호환성 및 설치 확인: GPU가 CUDA와 호환되는지, CUDA가 올바르게 설치되었는지 확인하십시오.
nvidia-smi명령을 사용하여 NVIDIA GPU 상태와 CUDA 버전을 확인하십시오. -
PyTorch와 CUDA 통합 확인: Python 터미널에서
import torch; print(torch.cuda.is_available())을 실행하여 PyTorch가 CUDA를 사용할 수 있는지 확인하십시오. 'True'가 반환되면 PyTorch가 CUDA를 사용하도록 설정된 것입니다. -
GPU 호환성 확인: Turing 이전의 GPU 아키텍처 및 컴퓨팅 성능(SM) < 7.5에 대한 지원은 cuDNN 9.11.0부터 중단되었습니다. 따라서 1080Ti와 같은 구형 GPU를 사용하는 경우 이전 버전의 CUDA/cuDNN으로 빌드된 PyTorch 버전을 사용해야 할 수 있습니다.
import torch; cap = torch.cuda.get_device_capability(0) if torch.cuda.is_available() else (0, 0); cudnn = torch.backends.cudnn.version() or 0; ok = "not compatible" if cudnn >= 91100 and (cap[0] < 7 or (cap[0] == 7 and cap[1] < 5)) else "should be ok"; print(f"Compute capability: SM {cap[0]}.{cap[1]}, cuDNN: {cudnn} => {ok}")를 실행하여 확인할 수 있습니다. -
환경 활성화: 필요한 모든 패키지가 설치된 올바른 환경에 있는지 확인하십시오.
-
패키지 업데이트: 오래된 패키지는 GPU와 호환되지 않을 수 있습니다. 패키지를 항상 최신 상태로 유지하십시오.
-
프로그램 구성: 프로그램이나 코드가 GPU 사용을 지정하고 있는지 확인하십시오. YOLO26의 경우 설정이나 구성 파일에 있을 수 있습니다.
-
모델 학습 문제
이 섹션에서는 학습 중에 발생하는 일반적인 문제와 그에 대한 설명 및 해결 방법을 다룹니다.
구성 설정 확인
문제: 모델 학습 중에 .yaml 파일의 구성 설정이 올바르게 적용되고 있는지 확신할 수 없습니다.
해결 방법: .yaml 파일의 구성 설정은 model.train() 함수를 사용할 때 적용되어야 합니다. 이러한 설정이 올바르게 적용되었는지 확인하려면 다음 단계를 따르십시오.
-
.yaml구성 파일의 경로가 올바른지 확인하십시오. -
Make sure you pass the path to your
.yamlfile as thedataargument when callingmodel.train(), as shown below:model.train(data="/path/to/your/data.yaml", batch=4)
다중 GPU를 사용한 학습 가속화
문제: 단일 GPU에서 학습 속도가 느려 여러 GPU를 사용하여 프로세스 속도를 높이고 싶습니다.
해결 방법: batch size를 늘리면 학습 속도를 높일 수 있지만, GPU 메모리 용량을 고려하는 것이 필수적입니다. 여러 GPU로 학습 속도를 높이려면 다음 단계를 따르십시오.
-
여러 개의 GPU를 사용할 수 있는지 확인하십시오.
-
사용할 GPU 수를 지정하도록
.yaml구성 파일을 수정하십시오 (예:gpus: 4). -
메모리 제한을 초과하지 않으면서 여러 GPU를 최대한 활용할 수 있도록 배치 크기를 적절히 늘리십시오.
-
여러 GPU를 활용하도록 학습 명령을 수정하십시오.
# Adjust the batch size and other settings as needed to optimize training speed model.train(data="/path/to/your/data.yaml", batch=32)
지속적인 모니터링 매개변수
문제: 손실(loss) 외에 학습 중에 지속적으로 모니터링해야 하는 매개변수가 무엇인지 알고 싶습니다.
해결 방법: 손실은 모니터링해야 할 중요한 지표이지만, 모델 성능 최적화를 위해 다른 지표를 추적하는 것도 필수적입니다. 학습 중에 모니터링해야 할 주요 지표는 다음과 같습니다.
- 정밀도
- 재현율
- Mean Average Precision (mAP)
학습 로그에서 이러한 지표에 액세스하거나 TensorBoard 또는 wandb와 같은 도구를 사용하여 시각화할 수 있습니다. 이러한 지표를 기반으로 조기 종료(early stopping)를 구현하면 더 나은 결과를 얻는 데 도움이 될 수 있습니다.
학습 진행 상황 추적 도구
문제: 학습 진행 상황을 추적하기 위한 도구 추천을 찾고 있습니다.
해결 방법: 학습 진행 상황을 추적하고 시각화하려면 다음 도구 사용을 고려하십시오.
- TensorBoard: TensorBoard는 손실, 정확도 등을 포함한 학습 지표를 시각화하는 데 널리 사용되는 도구입니다. YOLO26 학습 프로세스와 통합할 수 있습니다.
- Comet: Comet은 실험 추적 및 비교를 위한 광범위한 툴킷을 제공합니다. 지표, 하이퍼파라미터 및 모델 가중치까지 추적할 수 있습니다. YOLO 모델과의 통합도 간편하여 실험 주기에 대한 완벽한 개요를 제공합니다.
- Ultralytics Platform: Ultralytics Platform은 YOLO 모델 추적을 위한 전문화된 환경을 제공하여 지표, 데이터셋 관리 및 팀 협업을 위한 원스톱 플랫폼을 제공합니다. YOLO에 최적화되어 있어 보다 맞춤화된 추적 옵션을 제공합니다.
이러한 각 도구는 고유한 장점이 있으므로 선택할 때 프로젝트의 특정 요구 사항을 고려하는 것이 좋습니다.
학습이 GPU에서 진행되는지 확인하는 방법
문제: 학습 로그의 'device' 값이 'null'로 표시되며 학습이 GPU에서 진행 중인지 확실하지 않습니다.
해결 방법: 'device' 값이 'null'이라는 것은 기본 설정에 따라 학습 프로세스가 사용 가능한 GPU를 자동으로 사용하도록 설정되었음을 의미합니다. 특정 GPU에서 학습이 발생하도록 하려면 .yaml 구성 파일에서 'device' 값을 GPU 인덱스(예: 첫 번째 GPU의 경우 '0')로 수동 설정할 수 있습니다.
device: 0이렇게 하면 학습 프로세스가 지정된 GPU에 명시적으로 할당됩니다. CPU에서 학습하려면 'device'를 'cpu'로 설정하십시오.
학습 진행 상황을 효과적으로 모니터링하기 위해 'runs' 폴더의 로그와 지표를 계속 확인하십시오.
효과적인 모델 학습을 위한 주요 고려 사항
모델 학습과 관련된 문제를 겪고 있는 경우 다음 사항을 염두에 두십시오.
데이터셋 형식 및 레이블
- 중요성: 모든 머신 러닝 모델의 기초는 학습 데이터의 품질과 형식에 있습니다.
- 권장 사항: 사용자 정의 데이터셋과 관련 레이블이 예상되는 형식을 따르는지 확인하십시오. 주석이 정확하고 품질이 높은지 검증하는 것이 매우 중요합니다. 잘못되었거나 수준 낮은 주석은 모델의 학습 과정을 방해하여 예측 불가능한 결과를 초래할 수 있습니다.
모델 수렴(Convergence)
- 중요성: 모델 수렴을 달성하면 모델이 학습 데이터로부터 충분히 학습했음을 보장합니다.
- 권장 사항: '처음부터(from scratch)' 모델을 학습할 때는 모델이 만족스러운 수준의 수렴에 도달하도록 하는 것이 필수적입니다. 이는 기존 모델을 미세 조정할 때보다 더 많은 에포크(epochs)를 사용하여 더 긴 학습 시간이 필요할 수 있습니다.
학습률(Learning Rate) 및 배치 크기
- 중요성: 이 하이퍼파라미터들은 학습 중에 모델이 가중치를 업데이트하는 방식을 결정하는 핵심적인 역할을 합니다.
- 권장 사항: 선택한 학습률과 배치 크기가 특정 데이터셋에 최적인지 정기적으로 평가하십시오. 데이터셋의 특성과 조화를 이루지 못하는 매개변수는 모델 성능을 저하시킬 수 있습니다.
클래스 분포
- 중요성: 데이터셋의 클래스 분포는 모델의 예측 경향에 영향을 줄 수 있습니다.
- 권장 사항: 데이터셋 내 클래스 분포를 정기적으로 평가하십시오. 클래스 불균형이 발생하면 모델이 더 빈번한 클래스 쪽으로 편향될 위험이 있습니다. 이 편향은 혼동 행렬(confusion matrix)에서 명확하게 나타날 수 있으며, 모델이 주로 다수 클래스를 예측하게 될 수 있습니다.
사전 학습된 가중치와 교차 검증
- 중요성: 사전 학습된 가중치를 활용하면 특히 데이터가 제한적일 때 모델 학습의 확실한 시작점을 제공할 수 있습니다.
- 권장 사항: 진단 단계로서 동일한 데이터를 사용하여 모델을 학습하되 사전 학습된 가중치로 초기화해보십시오. 이 접근 방식이 잘 구성된 혼동 행렬을 생성한다면, '처음부터(from scratch)' 학습한 모델에 추가 학습이나 조정이 필요할 수 있음을 시사합니다.
모델 예측 관련 문제
이 섹션에서는 모델 예측 중에 발생하는 일반적인 문제를 다룹니다.
YOLO26 사용자 정의 모델로 바운딩 박스 예측 얻기
문제: 사용자 정의 YOLO26 모델로 예측을 실행할 때 바운딩 박스 좌표의 형식 및 시각화와 관련된 문제가 발생합니다.
해결 방법:
-
좌표 형식: YOLO26은 절대 픽셀 값으로 바운딩 박스 좌표를 제공합니다. 이를 상대 좌표(0에서 1 사이)로 변환하려면 이미지 크기로 나누어야 합니다. 예를 들어 이미지 크기가 640x640이라고 가정하면 다음을 수행합니다:
# Convert absolute coordinates to relative coordinates x1 = x1 / 640 # Divide x-coordinates by image width x2 = x2 / 640 y1 = y1 / 640 # Divide y-coordinates by image height y2 = y2 / 640 -
파일 이름: 예측 대상 이미지의 파일 이름을 얻으려면 예측 루프 내에서 결과 객체로부터 이미지 파일 경로에 직접 액세스하십시오.
YOLO26 예측에서 객체 필터링하기
문제: Ultralytics 라이브러리를 사용하여 YOLO26을 실행할 때 예측 결과에서 특정 객체만 필터링하고 표시하는 방법에 어려움이 있습니다.
Solution: To detect specific classes use the classes argument to specify the classes you want to include in the output. For instance, to detect only cars (assuming 'cars' have class index 2):
yolo task=detect mode=segment model=yolo26n-seg.pt source='path/to/car.mp4' show=True classes=2YOLO26의 정밀도(Precision) 지표 이해하기
문제: YOLO26에서 박스 정밀도, 마스크 정밀도 및 혼동 행렬 정밀도 간의 차이에 대한 혼란이 있습니다.
해결 방법: 박스 정밀도는 IoU(Intersection over Union)를 지표로 사용하여 예측된 바운딩 박스를 실제 정답 박스와 비교하여 정확도를 측정합니다. 마스크 정밀도는 픽셀 단위의 객체 분류에서 예측된 세그멘테이션 마스크와 정답 마스크 간의 일치도를 평가합니다. 반면 혼동 행렬 정밀도는 모든 클래스에 걸친 전반적인 분류 정확도에 초점을 맞추며 예측의 기하학적 정확도는 고려하지 않습니다. 바운딩 박스는 클래스 예측이 틀려도 기하학적으로 정확(true positive)할 수 있으며, 이로 인해 박스 정밀도와 혼동 행렬 정밀도 사이에 차이가 발생할 수 있음을 유의하십시오. 이러한 지표들은 모델 성능의 서로 다른 측면을 평가하므로 다양한 작업에서 각기 다른 평가 지표가 필요합니다.
YOLO26에서 객체 치수 추출하기
문제: 특히 이미지에서 여러 객체가 감지되었을 때 YOLO26에서 감지된 객체의 길이와 높이를 검색하는 데 어려움이 있습니다.
해결 방법: 바운딩 박스 치수를 검색하려면 먼저 Ultralytics YOLO26 모델을 사용하여 이미지에서 객체를 예측하십시오. 그런 다음 예측 결과에서 바운딩 박스의 너비와 높이 정보를 추출하십시오.
from ultralytics import YOLO
# Load a pretrained YOLO26 model
model = YOLO("yolo26n.pt")
# Specify the source image
source = "https://ultralytics.com/images/bus.jpg"
# Make predictions
results = model.predict(source, save=True, imgsz=320, conf=0.25)
# Extract bounding box dimensions
boxes = results[0].boxes.xywh.cpu()
for box in boxes:
x, y, w, h = box
print(f"Width of Box: {w}, Height of Box: {h}")배포 문제
GPU 배포 문제
문제: 다중 GPU 환경에서 모델을 배포하면 예상치 못한 메모리 사용량, GPU 간 일관되지 않은 결과 등 예상치 못한 동작이 발생할 수 있습니다.
해결 방법: 기본 GPU 초기화를 확인하십시오. PyTorch와 같은 일부 프레임워크는 지정된 GPU로 전환하기 전에 기본 GPU에서 CUDA 작업을 초기화할 수 있습니다. 예상치 못한 기본 초기화를 우회하려면 배포 및 예측 중에 GPU를 직접 지정하십시오. 그런 다음 도구를 사용하여 GPU 활용률 및 메모리 사용량을 모니터링하여 실시간으로 이상 징후를 식별하십시오. 또한 프레임워크나 라이브러리의 최신 버전을 사용하고 있는지 확인하십시오.
모델 변환/내보내기 문제
문제: 머신 러닝 모델을 다른 형식이나 플랫폼으로 변환하거나 내보내는 과정에서 사용자가 오류나 예상치 못한 동작을 겪을 수 있습니다.
해결 방법:
- 호환성 확인: 라이브러리와 프레임워크가 서로 호환되는 버전을 사용하고 있는지 확인하십시오. 버전이 일치하지 않으면 변환 중에 예상치 못한 오류가 발생할 수 있습니다.
- 환경 재설정: Jupyter나 Colab 같은 대화형 환경을 사용하는 경우 중요한 변경 사항이나 설치를 수행한 후 환경을 다시 시작하는 것을 고려하십시오. 때로는 처음부터 새로 시작하는 것이 근본적인 문제를 해결할 수 있습니다.
- 공식 문서: 변환에 사용하는 도구나 라이브러리의 공식 문서를 항상 참조하십시오. 모델 내보내기에 대한 특정 지침과 모범 사례가 포함되어 있는 경우가 많습니다.
- 커뮤니티 지원: 라이브러리나 프레임워크의 공식 저장소에서 다른 사용자가 보고한 유사한 문제를 확인하십시오. 유지 관리자나 커뮤니티가 토론 스레드에서 해결책이나 우회 방법을 제공했을 수 있습니다.
- 정기 업데이트: 도구나 라이브러리의 최신 버전을 사용하고 있는지 확인하십시오. 개발자들은 알려진 버그를 수정하거나 기능을 개선하는 업데이트를 자주 출시합니다.
- 증분 테스트: 전체 변환을 수행하기 전에 더 작은 모델이나 데이터셋으로 프로세스를 테스트하여 잠재적인 문제를 조기에 파악하십시오.
커뮤니티 및 지원
비슷한 생각을 가진 사람들과의 커뮤니티 참여는 YOLO26을 사용하는 경험과 성공을 크게 향상시킬 수 있습니다. 다음은 도움이 될 만한 채널과 리소스입니다.
도움을 얻을 수 있는 포럼 및 채널
GitHub Issues: GitHub의 YOLO26 저장소에는 Issues 탭이 있어 질문을 하거나 버그를 보고하고, 새로운 기능을 제안할 수 있습니다. 커뮤니티와 관리자가 이곳에서 활발히 활동하고 있으며, 특정 문제에 대한 도움을 받기에 매우 좋은 곳입니다.
Ultralytics Discord 서버: Ultralytics에는 다른 사용자 및 개발자들과 소통할 수 있는 Discord 서버가 있습니다.
공식 문서 및 리소스
Ultralytics YOLO26 문서: 공식 문서는 YOLO26에 대한 포괄적인 개요와 설치, 사용법 및 문제 해결에 관한 가이드를 제공합니다.
이러한 리소스는 YOLO26 프로젝트를 문제 해결하고 개선하며, YOLO26 커뮤니티의 다른 사람들과 연결하는 데 탄탄한 기반을 제공할 것입니다.
결론
문제 해결은 모든 개발 과정의 필수적인 부분이며, 올바른 지식을 갖추면 문제를 해결하는 데 드는 시간과 노력을 크게 줄일 수 있습니다. 이 가이드는 Ultralytics 생태계 내에서 YOLO26 모델 사용자가 직면하는 가장 일반적인 문제들을 다루는 것을 목표로 했습니다. 이러한 일반적인 문제들을 이해하고 해결함으로써 프로젝트 진행을 원활하게 하고 컴퓨터 비전 작업에서 더 나은 결과를 얻을 수 있습니다.
Ultralytics 커뮤니티는 귀중한 자원임을 기억하십시오. 동료 개발자 및 전문가들과 교류하면 표준 문서에서 다루지 않는 추가적인 통찰력과 해결책을 얻을 수 있습니다. 커뮤니티의 집단 지성에 기여할 수 있도록 항상 배우고, 실험하고, 경험을 공유하십시오.
FAQ
YOLO26 설치 오류를 어떻게 해결하나요?
설치 오류는 종종 호환성 문제나 누락된 종속성으로 인해 발생합니다. Python 3.8 이상을 사용하고 PyTorch 1.8 이상이 설치되어 있는지 확인하십시오. 충돌을 피하기 위해 가상 환경을 사용하는 것이 좋습니다. 단계별 설치 가이드는 공식 설치 가이드를 따르십시오. 가져오기(import) 오류가 발생하면 새로 설치하거나 라이브러리를 최신 버전으로 업데이트해 보십시오.
단일 GPU에서 YOLO26 모델 학습이 느린 이유는 무엇인가요?
단일 GPU에서의 학습은 큰 배치 크기나 부족한 메모리로 인해 느려질 수 있습니다. 학습 속도를 높이려면 다중 GPU를 사용하십시오. 시스템에 다중 GPU를 사용할 수 있는지 확인하고 .yaml 구성 파일을 조정하여 gpus: 4와 같이 GPU 수를 지정하십시오. 메모리 한도를 초과하지 않으면서 GPU를 최대한 활용할 수 있도록 배치 크기를 그에 맞춰 늘리십시오. 명령어 예시:
model.train(data="/path/to/your/data.yaml", batch=32)YOLO26 모델이 GPU에서 학습되고 있는지 어떻게 확인할 수 있나요?
학습 로그에서 'device' 값이 'null'로 표시되면, 일반적으로 학습 프로세스가 자동으로 사용 가능한 GPU를 사용하도록 설정된 것입니다. 특정 GPU를 명시적으로 할당하려면 .yaml 구성 파일에서 'device' 값을 설정하십시오. 예를 들면 다음과 같습니다:
device: 0이렇게 하면 학습 프로세스가 첫 번째 GPU로 설정됩니다. CUDA 설정을 확인하려면 nvidia-smi 명령어를 참조하십시오.
YOLO26 모델 학습 진행 상황을 어떻게 모니터링하고 추적할 수 있나요?
학습 진행 상황 추적 및 시각화는 TensorBoard, Comet, Ultralytics Platform과 같은 도구를 통해 효율적으로 관리할 수 있습니다. 이러한 도구를 사용하면 손실(loss), 정밀도(precision), 재현율(recall) 및 mAP와 같은 지표를 기록하고 시각화할 수 있습니다. 이러한 지표를 기반으로 조기 종료(early stopping)를 구현하면 더 나은 학습 결과를 얻는 데 도움이 될 수 있습니다.
YOLO26이 내 데이터셋 형식을 인식하지 못하면 어떻게 해야 하나요?
데이터셋과 라벨이 예상되는 형식에 부합하는지 확인하십시오. 주석이 정확하고 품질이 높은지 검증하십시오. 문제가 발생하면 모범 사례에 관한 데이터 수집 및 주석(Data Collection and Annotation) 가이드를 참조하십시오. 데이터셋별 지침은 문서의 데이터셋(Datasets) 섹션을 확인하십시오.