Ming's Life

머신러닝(이상탐지) 본문

머신러닝

머신러닝(이상탐지)

chamiii 2025. 7. 8. 20:03

1. 오늘 학습 키워드

  • 머신러닝 기초

 


 

2. 오늘 학습 한 내용을 나만의 언어로 정리하기

 

1. 이상 탐지(Anomaly Detection)란?

☑️ 왜 필요한가?

  • 금융 사기
    • 카드 사기, 계좌 해킹 등으로 인한 금전적 손실을 미리 막기 위해
  • 제조업
    • 생산 라인이나 기계 설비에서 발생하는 고장을 사전에 예측하여 유지보수 비용 절감, 다운타임 최소화
  • 보안
    • 네트워크 침입 시도나 데이터 탈취 등을 빠르게 감지

 

☑️ 이상치 탐지(Outlier Detection)와의 차이

  • 이상치 탐지(Outlier Detection)는 단순히 통계적으로 극단값(Outlier)을 찾는 데 초점을 둔다. 예를 들어 평균에서 크게 벗어난 데이터 포인트를 찾는 방식
  • 이상 탐지(Anomaly Detection)는 단순 극단값 뿐 아니라, 맥락(Context)이나 시계열 상의 패턴을 함께 고려하여 ‘비정상’인지를 판단하는 것을 의미하는 경우가 많다.
    • ex) 시간적 흐름이나 주변 맥락, 다른 변수들과의 상관관계까지 고려하는 경우

 


2. 주요 이상 탐지 알고리즘

https://medium.com/@mail.garima7/one-class-svm-oc-svm-9ade87da6b10

  • 알고리즘 원리
    • SVM(Support Vector Machine)은 원래 이진 분류를 위해 고안된 알고리즘이지만, One-Class SVM은 ‘단 하나의 클래스(정상 클래스)’만을 학습해 해당 클래스 영역을 정의한다.
    • 정상 데이터가 분포하는 공간 주위에 경계를 형성(“decision boundary”)하고, 경계 밖에 있는 데이터는 ‘비정상’으로 분류한다.
  • 특징
    • 고차원 공간에서도 비교적 잘 동작할 수 있다(커널 함수의 사용).
    • 데이터 스케일링과 커널 파라미터 선택이 중요. (예: RBF 커널일 때 γ값, nu(ν) 값 등)

 

☑️ Isolation Forest

https://www.researchgate.net/figure/Isolation-Forest-learned-iForest-construction-for-toy-dataset_fig1_352017898

 

  • 알고리즘 원리
    • Isolation Forest는 랜덤 포레스트와 유사한 아이디어에 기반한다.
    • “이상치(이상 데이터)는 전체 데이터 중 상대적으로 적고, 특정 속성값에서 극단적인 위치를 차지하는 경우가 많다.”는 가정 하에,무작위로 특성과 분할값을 골라 데이터를 계속 나누어가는 과정에서 ‘쉽게 분리(또는 격리)되는’ 데이터는 이상일 가능성이 높다고 본다.
  • 특징
    • 랜덤 포레스트 방식으로 여러 개의 무작위 트리를 구성하고, 각 트리에서 한 데이터가 분리되는 “깊이(depth)”를 측정하여 이상 점수를 부여한다.
    • 대규모 데이터셋에서도 빠르게 동작하는 편이며, 구현이 간단하고 직관적이다.

 

 

☑️ 이상탐지 코드 예시

import numpy as np
import matplotlib.pyplot as plt
import pandas as pd

# 1. 데이터 로드: Iris 데이터셋
from sklearn.datasets import load_iris
data = load_iris()
X = data.data
y = data.target  # 여기서는 실제 라벨을 이용하지 않음

# 간단히 2개 특성만 사용 (예: 꽃받침 길이, 꽃받침 너비) --> 시각화 편의를 위해
X_2d = X[:, :2]  # shape: (150, 2)

# 2. One-Class SVM
from sklearn.svm import OneClassSVM

oc_svm = OneClassSVM(nu=0.05)  # 예시 파라미터
oc_svm.fit(X_2d)
# 예측: 1(정상), -1(이상치)
y_pred_oc = oc_svm.predict(X_2d)

# 3. Isolation Forest
from sklearn.ensemble import IsolationForest

iso_forest = IsolationForest(contamination=0.05, random_state=42)
iso_forest.fit(X_2d)
# 예측: 1(정상), -1(이상치)
y_pred_if = iso_forest.predict(X_2d)

# 4. 이상치로 예측된 샘플 인덱스 추출
outliers_oc = np.where(y_pred_oc == -1)[0]  # One-Class SVM이 예측한 이상치
outliers_if = np.where(y_pred_if == -1)[0]  # Isolation Forest가 예측한 이상치

print("=== One-Class SVM ===")
print("이상치로 탐지된 샘플 개수:", len(outliers_oc))
print("이상치 인덱스:", outliers_oc)

print("\n=== Isolation Forest ===")
print("이상치로 탐지된 샘플 개수:", len(outliers_if))
print("이상치 인덱스:", outliers_if)

# 5. 시각화
# 2차원 특성 공간에서 이상치로 판별된 점들을 빨간색으로 표시
fig, axes = plt.subplots(1, 2, figsize=(12, 5))

axes[0].scatter(X_2d[:, 0], X_2d[:, 1], label='Normal')
axes[0].scatter(X_2d[outliers_oc, 0], X_2d[outliers_oc, 1],
                color='red', edgecolors='k', label='Outliers')
axes[0].set_title("One-Class SVM")
axes[0].set_xlabel("Sepal Length")
axes[0].set_ylabel("Sepal Width")
axes[0].legend()

axes[1].scatter(X_2d[:, 0], X_2d[:, 1], label='Normal')
axes[1].scatter(X_2d[outliers_if, 0], X_2d[outliers_if, 1],
                color='red', edgecolors='k', label='Outliers')
axes[1].set_title("Isolation Forest")
axes[1].set_xlabel("Sepal Length")
axes[1].set_ylabel("Sepal Width")
axes[1].legend()

plt.tight_layout()
plt.show()

 

☑️ 코드 해설

  • 데이터 로드
    • load_iris()로 Iris 데이터셋을 불러온다.
    • 시각화를 위해 꽃받침 길이, 너비 2개 특성만(X[:, :2]) 사용한다.
  • One-Class SVM
    • OneClassSVM(nu=0.05)로 모델을 생성한다.
    • fit(X_2d)로 학습한 뒤, predict(X_2d) 결과로 1(정상), -1(이상치) 레이블을 받는다.
    • nu는 데이터 스케일이나 분포에 따라 조정 가능하며, nu=0.05는 전체 데이터 중 약 5% 정도를 이상치로 잡겠다는 것이다.
  • Isolation Forest
    • IsolationForest(contamination=0.05, random_state=42)로 모델을 생성한다.
    • fit(X_2d)로 학습 후, predict(X_2d) 결과로 1(정상), -1(이상치) 레이블을 받는다.
    • contamination=0.05로 이상치 비율(오염도)을 대략 5%로 가정한다.
  • 예측된 이상치 인덱스 확인
    • np.where(y_pred_oc == -1), np.where(y_pred_if == -1)로 각각 이상치로 분류된 샘플의 인덱스를 찾는다.
    • 이상치로 진단된 개수와 인덱스를 출력한다.
  • 시각화
    • 2개의 서브플롯을 만들어, 하나는 One-Class SVM 결과, 다른 하나는 Isolation Forest 결과를 표시한다.
    • 이상치로 분류된 점들을 빨간색으로 강조한다(scatter에서 다른 색상으로 표시).
    • 실제론 Iris 데이터는 극단 이상치가 별로 없으므로 결과가 다소 유사하거나 적을 수 있다.
    • 필요에 따라 인위적으로 이상 샘플을 삽입하거나, 다른 데이터셋을 사용하면 좀 더 극명한 차이를 볼 수 있다.

 

 


3. 산업별 사례

☑️ 금융 분야

  • 카드 사기 거래(Fraud Detection)
    • 수많은 정상 거래 데이터를 토대로 이상 탐지 모델을 학습한다.
    • 갑작스러운 해외 거래나, 큰 금액의 잦은 이체 등의 패턴이 감지되면 사기 가능성이 높은 것으로 표시.
  • 돈세탁 의심 거래(Money Laundering)
    • 고객의 거래 패턴(빈도, 금액, 거래처 등)을 종합적으로 분석하여, 비정상적으로 복잡한 자금 흐름을 포착.

 

☑️ 제조업 분야

  • 설비 고장 예측
    • 온도, 압력, 진동 센서 데이터를 장기간 축적해 정상 범위를 학습.
    • 특정 시점부터 갑작스럽게 진동 값이 크게 변한다면, 실제 고장 가능성이 있는 설비로 판단해 미리 점검.
  • 품질 이상 탐지
    • 생산 공정 중 수집되는 다양한 품질 지표(크기, 무게, 색상 등)를 통해 갑작스러운 편차가 발생하는 제품을 빠르게 걸러내어 불량률을 줄임.

 

 


총 정리

1. 이상 탐지(Anomaly Detection)는 정상 패턴과 다른 데이터를 찾아내는 기법이다.

 

2. 이상치 탐지(Outlier Detection)와 유사하지만, 맥락과 패턴 학습 측면에서 조금 더 넓은 범위를 다룬다.

 

3. 대표 알고리즘

  • One-Class SVM: 정상 데이터를 기준으로 경계를 형성
  • Isolation Forest: 무작위 분할을 통해 쉽게 분리되는 데이터를 이상으로 간주

4. 금융(카드 사기, 돈세탁)과 제조업(설비 고장 예측, 품질 관리) 등 다양한 분야에서 활용할 수 있다.

 

 

'머신러닝' 카테고리의 다른 글

머신러닝(차원축소)  (3) 2025.07.08
머신러닝(클러스터링)  (2) 2025.07.08
머신러닝(앙상블 기법)  (0) 2025.07.07
머신러닝(분류)  (1) 2025.07.04
머신러닝(회귀)  (2) 2025.07.03