AI

머신러닝 - 선형회귀를 뉴런으로 만들어보자.

최데브 2021. 8. 29. 17:11

앞서 선형회귀에 대해서 만들어봤는데 이걸 뉴런으로 한번 만들어서 써보자.

 

 

class Neuron:
    
    def __init__(self):
        self.w = 1.0     # 가중치를 초기화합니다
        self.b = 1.0     # 절편을 초기화합니다
    
    def forpass(self, x):
        y_hat = x * self.w + self.b       # 직선 방정식을 계산합니다
        return y_hat
    
    def backprop(self, x, err):
        w_grad = x * err    # 가중치에 대한 그래디언트를 계산합니다
        b_grad = 1 * err    # 절편에 대한 그래디언트를 계산합니다
        return w_grad, b_grad

    def fit(self, x, y, epochs=100):
        for i in range(epochs):           # 에포크만큼 반복합니다
            for x_i, y_i in zip(x, y):    # 모든 샘플에 대해 반복합니다
                y_hat = self.forpass(x_i) # 정방향 계산
                err = -(y_i - y_hat)      # 오차 계산
                w_grad, b_grad = self.backprop(x_i, err)  # 역방향 계산
                self.w -= w_grad          # 가중치 업데이트
                self.b -= b_grad          # 절편 업데이트

 

neuron = Neuron()
neuron.fit(x, y)

 

앞에서 배운 내용과 거의 비슷하다. 그냥 클래스와 함수화 해준거라고 볼 수 있다.

 

 

반응형

'AI' 카테고리의 다른 글

머신러닝 - 선형회귀의 경사하강법 메모  (0) 2021.08.29