NamedTuple을 이용한 가독성 개선 목적의 리팩토링

NamedTuple을 이용한 가독성 개선 목적의 리팩토링
Photo by Kevin Canlas / Unsplash

Tuple Unpacking 이란

  • 하나의 튜플(tuple)을 여러 개의 변수로 분해하여 사용하는 것
a, b, c = (1, 2, 3)

문제점

  • 변수 갯수가 맞지 않을 때
# 예시 코드: 변수 갯수 불일치
result = (0.8, 0.1)
accuracy, loss, precision = result  # ValueError 발생
  • 의미없는 변수 이름을 사용시 → 이후에 가독성 이슈
# 예시 코드: 의미 없는 변수 이름
a, b, c = model.predict(X_test)

리팩토링

  • 명시적인 변수 명 사용
# 리팩토링 코드: 명시적인 변수 이름 사용
accuracy, loss = model.predict(X_test)[:2]
precision = model.predict(X_test)[2]  # precision을 나중에 따로 할당

  • NamedTuple 사용
  • Dict를 써도 되나, 아래의 경우를 고려시 Named Tuple이 더 나을 수 있음
    • 데이터가 고정된 구조를 가지고 있으며, 데이터가 불변이어야 할 때
    • 성능(특히 메모리 사용량 및 접근 속도)이 중요한 경우
    • 코드의 가독성과 명확성이 중요한 경우
from collections import namedtuple

# NamedTuple 사용 예시
Prediction = namedtuple('Prediction', ['accuracy', 'loss', 'precision'])
result = Prediction(accuracy=0.8, loss=0.1, precision=0.85)

print(result.accuracy)  # 0.8
print(result.loss)      # 0.1
print(result.precision) # 0.85

  • Dictionary 사용
  • Dict를 사용하는게 더 나을 경우
    • 데이터 구조가 유연하게 변경될 가능성이 있을 때
    • 키-값 쌍을 동적으로 추가, 수정, 삭제할 필요가 있을 때
    • Python의 다른 라이브러리 및 함수와의 통합이 중요한 경우
# 딕셔너리 사용 예시
result = {'accuracy': 0.8, 'loss': 0.1, 'precision': 0.85}

print(result['accuracy'])  # 0.8
print(result['loss'])      # 0.1
print(result['precision']) # 0.85

Read more

DataFrame은 Pandera로, 모델은 Pydantic으로 데이터를 검증한다.

DataFrame은 Pandera로, 모델은 Pydantic으로 데이터를 검증한다.

Pandera: 데이터프레임 검증에 최적화된 도구 주요 장점 * Pandas와 통합: Pandas 데이터프레임에 대해 스키마 기반 검증을 수행합니다. * 유연한 검증 조건: 열 데이터 타입, 값 범위, Null 여부 등 다양한 검증 조건을 정의할 수 있습니다. * 명확한 오류 메시지: 스키마 불일치에 대한 명확한 오류 메시지를 제공합니다. 단점 * 대용량 데이터 검증에서는 속도가 느릴 수

Tobit Regression은 Censored Data에 적합한 Regression이다.

Tobit Regression은 Censored Data에 적합한 Regression이다.

Tobit Regression * Tobit 회귀(Tobit Regression)는 종속 변수가 특정 값에서 절단(Censored)된 상황에서 데이터를 분석하기 위해 사용되는 통계 기법입니다. * James Tobin이 처음 제안한 이 모델은 경제학과 사회과학 분야에서 자주 사용되며, 일반 선형 회귀로는 설명할 수 없는 상황에서 효과적으로 적용할 수 있습니다. Tobit Regression 수식 1. 관측된 종속 변수