[톺아보기] Pytorch를 이용한 Image Classifier 코드, Gradient Descent
AI, Deep Learning Basics/Computer Vision

[톺아보기] Pytorch를 이용한 Image Classifier 코드, Gradient Descent

본 글은 Gradient Descent의 Pytorch 코드에 대한 필자의 이해를 위해 번역된 글로, 원글은 여기서 보실 수 있습니다.

Pytorch 를 통해 이미지 분류기를 만들어보도록 하겠습니다. 흐름은 다음과 같습니다.

  1. 데이터셋 준비하기 - torchvision을 통해 CIFAR10 데이터셋 준비(Loading train/test dataset, normalization 포함)
  2. CNN 네트워크 준비하기
  3. Loss function 정의하기
  4. Train dataset을 CNN 네트워크 학습하기
  5. CNN 네트워크로 test dataset 예측하기

본 글은 이미지가 학습되는 전체 구조 중심으로 설명하기 보다는 gradient descent가 어떤 흐름으로 이루어져있는지 자세히 살펴보고자 만들어졌습니다. 그럼 시작하겠습니다.

1. 데이터셋 준비하기

데이터셋을 받아서 Tensor로 변환하고, 이를 최종적으로 dataloader에 올리는 일까지 모든 일을 통칭하여 이루어집니다.

transforms 라이브러리를 이용하여 Normalization뿐만 아니라 Crop, Rotation 등 여러 일이 가능합니다.

Output:

Downloading https://www.cs.toronto.edu/~kriz/cifar-10-python.tar.gz to ./data/cifar-10-python.tar.gz
Extracting ./data/cifar-10-python.tar.gz to ./data
Files already downloaded and verified

데이터셋을 한번 보여보도록 하겠습니다. train dataset의 Dataloader에서 이미지와 라벨을 하나씩 꺼내서 출력해보는 구조로 진행됩니다.

Output:

cat plane  bird  ship

2. CNN 네트워크 준비하기

앞선 데이터에 학습해야 할 모델이 필요합니다. 간단한 CNN 네트워크를 이용해서 구현을 해보려 합니다. 코드는 다음과 같고, 이번 글의 목표는 Gradient descent 부분에 더 치우쳐져 있으므로 자세한 설명은 생략하겠습니다.

CNN 네트워크인 class Net을 정의하였고, 그에 따른 객체인 net을 생성하게 됩니다.

3. Loss function, Optimizer 정의하기

이번 모델은 Cross-entropy loss와 SGD(Stochastic Gradient Descent) with momentum을 이용해서 구현해보겠습니다.

4. Train dataset을 CNN 네트워크 학습하기

train시에 Gradient Descent가 이루어집니다. 대략적인 개념을 살펴보겠습니다.

들어가기에 앞서, Gradient Descent 의 대략적 개념 살펴보기

Gradient descent는 딥러닝 모델의 최고 목표인 function approximation을 위해 모델 내의 Parameter들을 조금씩 조정하게 되며, 이를 Gradient descent라 일컫습니다. Gradient Descent가 이루어지기 위해서는 단계별로 process가 이루어지며, 다음과 같습니다.

0) Loss function, Optimizer 정의하기
Repeat{
    1) Loss function 계산하기    
    2) Derivation 계산하기
    3) Back-propagation 수행하기
}

하나하나 설명해보도록하겠습니다.
0) Loss function, Optimizer 정의하기: Gradient Descent는 모델들 내의 파라미터를 조금씩 조정하는 일이라고 하였습니다. 모델 파라미터를 조정하기 위해서는 어떤 프로세스가 이루어져야 할까요. 생각해보면 모델의 현재 성능을 파악하고, 이에 맞춰서 파라미터를 조금씩 수정하는 작업이 필요합니다. 모델의 현재 성능을 파악할 때 Loss function, 파라미터를 수정할 때 Optimizer가 필요합니다.

1) Loss function 계산하기: 가지고 있는 모델로 forward-propagation을 수행했습니다. 결과값들을 하나하나 비교하여 모델의 현재 성능을 파악합니다.
2) Derivation 계산하기: Gradient Descent는 모델 파라미터 값들을 Update할 때, Optimizer가 Derivation을 이용하여 조금씩 수정해서 Derivation이 필요합니다.
3) Back-propagation 수행하기: Optimizer의 기준과 2)에서 계산한 Derivation을 바탕으로 값을 수정하며, 이 과정을 Back-propagation 과정이라 부릅니다.

이런 개념으로 바라보면 다음 실행 코드를 더 수월하게 이해할 수 있습니다.

5. CNN 네트워크로 test dataset 예측하기

우선 위에서 학습된 모델을 저장하는게 중요하겠죠. 다음 코드로 저장합니다.

이제 train dataset 말고도 test dataset을 적용하여 모델의 진짜 성능을 확인해봐야합니다. 이 때 중요한 점은 test시에는 Gradient Descent를 의무적으로 꺼줘야 한다는 점입니다. pytorch가 gradient descent를 수행할 수도 있는 불상사를 미연에 방지하기 위해 다음과 같은 코드로 예측하게 되며 결과를 확인할 수 있습니다.

이제 결과를 확인해보면 다음과 같네요.

Accuracy of the network on the 10000 test images: 54 %

54% 정확도가 나온 것을 확인하실 수 있습니다.
딥러닝 모델의 꽃인 Gradient Descent가 Pytorch에서는 어떻게 작동되는지 일련의 과정들을 살펴보았습니다. 시간이 가능하다면 다음에는 Gradient Descent의 여러 모델을 정리해보도록 하겠습니다. 긴 글 읽어주셔서 감사합니다. =)