반응형

이전 포스팅에서 논리 회로 중 AND 게이트와 퍼셉트론(Perceptron)을 활용하는 방법에 대해 쉽게 설명했다.

아래 포스팅을 참조하면 된다.

2024.12.10 - [인공지능(AI)/딥러닝(DeepLearning)] - [딥러닝]인공지능 초보 개발자면 퍼셉트론과 AND 게이트 활용 방법은 알고 가자, 쉬운 설명.

 

[딥러닝]인공지능 초보 개발자면 퍼셉트론과 AND 게이트 활용 방법은 알고 가자, 쉬운 설명.

음식도 맛있고 양도 많은데 가격까지 저렴하다면 우리는 가성비가 좋다고 표현한다.음식과 가격 둘 다 만족해야 가성비라는 표현을 쓴다.이 중 하나라도 맘에 안들면 가성비가 좋다고 하지 않

tiboy.tistory.com

딥러닝을 공부하는 개발자라면 논리 연산이 AND 외 더 있다는 것을 알고 있다.

NAND, OR 그리고 XOR 게이트가 더 있다.

XOR 게이트는 인공지능에 한 걸음 더 나가가는 특별한 경우라 따로 설명하겠다.

 

AND 게이트와 퍼셉트론 활용에 이어 이번 포스팅은 NAND 게이트와 OR 게이트에 대해 쉽게 설명해 본다.

AI 개발자가 되기 위해  출발해 봅시다.

준비되었나요?

 

NAND 게이트와 퍼셉트론 활용

NAND는 무슨 의미일까?

낸드라고 읽는데 어디서 들어본 듯하다.

"낸드"로 검색하면 반도체 관련 뉴스를 볼 수 있다. 

그 뉴스에서 "낸드플래시"라는 용어를 많이 볼 수 있는데 그 낸드가 NAND다.

NAND는 "Not AND"다.

"Not"이 붙은 의미는 반대라고 생각하자.

AND 게이트의 값을 반대로 출력한다. 

AND 게이트 진리표를 표로 다시 확인해 보자.

x1 x2 y
0 0 0
1 0 0
0 1 0
1 1 1

NAND 게이트는 출력값이 반대로 나온다고 했다.

이제 NAND 게이트 진리표를 표로 정리해 보자.

x1 x2 y
0 0 1
1 0 1
0 1 1
1 1 0

x1과 x2가 하나 이상 0일 때 AND 게이트는 0이었지만 NAND는 1이다.

x1과 x2가 모두 1일 때 AND 게이트는 1이었지만 NAND는 0이다.

이제 가중치와 임계값을 정해보자.

(w1, w2, 𝞱)0 : x1w1 + x2w2 <= 𝞱 1: x1w1 + x2w2 > 𝞱

AND 게이트와 퍼셉트론에서 봤던 계산식과 기호들이다.

기억을 되살려보자.

w1 = 0.7, w2 = 0.3, 𝞱 = 0.9

AND 게이트의 x1, x2 값 (0, 0)인 경우부터 순서대로 식에 대입해 보자.

0 * 0.7 + 0 * 0.3 = 0 은 0.9보다 작거나 같은 조건이므로 (<=) 0.

1 * 0.7 + 0 * 0.3 = 0.7 은 0.9보다 작거나 같은 조건이므로 (<=) 0.

0 * 0.7 + 1 * 0.3 = 0.3 은 0.9보다 작거나 같은 조건이므로 (<=) 0.

1 * 0.7 + 1 * 0.3 = 1.0 은 0.9보다 크므로 (>) 1.

위 가중치와 임계값은 AND 게이트용이다.

NAND 출력값은 AND의 반대라고 했다.

위 가중치와 임계값에 마이너스 부호를 붙이면 NAND 게이트를 만족한다.

w1 = -0.7, w2 = -0.3, 𝞱 = -0.9

0 * -0.7 + 0 * -0.3 = 0 은 -0.9 보다 크므로 (>) 1.

1 * -0.7 + 0 * -0.3 = -0.7 은 -0.9 보다 크므로 (>) 1.

0 * -0.7 + 1 * -0.3 = -0.3 은 -0.9 보다 크므로 (>) 1.

1 * -0.7 + 1 * -0.3 = -1.0 은 -0.9보다 작거나 같은 조건이므로 (<=) 0.

 

OR 게이트와 퍼셉트론 활용

이제 OR 게이트도 같은 방식으로 알아보자.

우리말로 "또는, 둘 중 하나"로 해석하면 된다.

둘 중 하나 이상이 true(1) 면 1을 출력한다.

OR 게이트 진리표를 표로 정리해 보자.

x1 x2 y
0 0 0
1 0 1
0 1 1
1 1 1

x1과 x2가 둘 중 1개 이상 1일 때 OR는 1이다.

x1과 x2가 모두 0일 때 OR는 0이다.

OR 게이트 입력 매개변수는 다음처럼 설정하면 된다.

w1 = 0.7, w2 = 0.3, 𝞱 = 0.2 는 OR 게이트용 가중치와 임계값이다.

위 가중치와 임계값은 OR 게이트를 만족한다.

0 * 0.7 + 0 * 0.3 = 0 은 0.2 보다 작거나 같은 조건이므로 (<=) 0.

1 * 0.7 + 0 * 0.3 = 0.7 은 0.2 보다 크므로 (>) 1.

0 * 0.7 + 1 * 0.3 = 0.3 은 0.2  보다 크므로 (>) 1.

1 * 0.7 + 1 * 0.3 = 1.0 0.2  보다 크므로 (>) 1.

가중치와 임계값을 조정할 수 있다는 것을 알았다.

 

논리 회로, 퍼셉트론 활용을 파이썬으로 구현하는 방법

이론 이야기를 했으니 파이썬을 사용해서 직접 코딩해 보자.

아나콘다(파이썬)가 설치된 VSCode(Visual Studio Code)를 사용했다.

 

AND 게이트 함수 만들기

아래 코드를 살펴보자.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import numpy as np
 
def AndGate(x1, x2):
    xn = np.array([x1, x2])
    wn = np.array([0.70.3])
    theta = 0.9
 
    sumData = np.sum(wn*xn)
    if sumData <= theta:
        return 0
    else:
        return 1
    
 
 
print(AndGate(0,0))
print(AndGate(1,0))
print(AndGate(0,1))
print(AndGate(1,1))
cs

1번 라인은 numpy를 import 했다.

numpy 내부 함수 array와 sum을 사용할 것이다.

3번 라인에서 AndGate 함수를 선언했다. x1과 x2를 입력받는다.

4번 라인은 x1, x2를 numpy 내부 array함수에 세팅한다.

5번 라인은 w1, w2 값인 0.7, 0.3을 마찬가지로 내부 array 함수에 세팅한다.

6번은 theta( 𝞱)값을 0.9로 할당했다.

8번 라인은 4, 5번 라인 array 값들의 합을 sum 함수로 계산하고 sumData에 할당한다.

9번~ 12번은 sumData 값이 theta값보다 작거나 같으면(<=) 0 아니면 1을 출력한다.

16번부터 AND 게이트 입력값을 넣으면 같은 결과가 나온다.

결과 ( 0, 0, 0, 1)

NAND 게이트 함수 만들기.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import numpy as np
 
def NAND_GATE(x1, x2):
    w1, w2, theta = -0.7-0.3-0.9
    sumData = w1*x1 + w2*x2
    
    if sumData <= theta:
        return 0
    elif sumData > theta:
        return 1
    
 
 
print(NAND_GATE(0,0))
print(NAND_GATE(1,0))
print(NAND_GATE(0,1))
print(NAND_GATE(1,1))
cs

4번 라인에 NAND 게이트 가중치와 임계값을 세팅했다.

결과는 (1, 1, 1, 0)로 NAND 게이트와 일치한다.

 

OR 게이트 함수 만들기.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import numpy as np
 
def OrGate(x1, x2):
    xn = np.array([x1, x2])
    wn = np.array([0.70.3])
    theta = 0.2
 
    sumData = np.sum(wn*xn)
    if sumData <= theta:
        return 0
    else:
        return 1
    
 
 
print(OrGate(0,0))
print(OrGate(1,0))
print(OrGate(0,1))
print(OrGate(1,1))
cs

이번 포스팅의 마지막 소스 OR 게이트 구현이다.

OR 게이트 구현을 위해 theta( 𝞱)값에 0.2를 할당했다.

결과는 (0, 1, 1, 1)이다.

 

지금까지 NAND와 OR 게이트를 퍼셉트론에 활용하는 내용을 알아봤다.

해당 부분을 파이썬 코드로 구현도 했다.

딥러닝 다음 편은 XOR 게이트에 대해 알아본다.

XOR 게이트는 약간 다르다.

AI 개발자로 한걸음 더 다가섰다.

끝.

반응형
반응형

요즘 딥러닝과 파이썬만 공부하다 오랜만에 자바 스프링 한 번 해보려고 VSCode를 실행했다.

너무 오래되었는지 오류가 났다.

VSCode는 기존에 세팅 방식에서 변한 건 없고 jdk 버전만 올려주니 잘 되었다.

Spring.io에서 STS를 다운 받아서 실행하는데 오류가 난다.

 

오류메시지

오늘 일자로 STS(이클립스 버전) 받았고 jdk17 버전으로 세팅했다.

Spring Web 프로젝트를 Gradle로 생성했다.

그러자 위 오류가 났다.

오류정보 : 'Import Gettiing Started Content' has encountered a problem. ToolchainDownloadFailedException: No locall installed toolchains match and toolchain download repositories have not been configured.

사실 첨 보는 오류였다.

오류 정보도 친절하지 않네. 어이구야.

같은 조건으로 Maven 프로젝트는 문제 없이 잘 된다.

Gradle에서 jdk 버전 체크를 하는 듯 다.

 

해결방법 

jdk17, jdk19로 했더니 계속 오류가 났다.

오늘자로 받은 Spring STS는 최저 jdk 버전이 21부터 시작한다.

1. jdk21 버전을 다운 받는다. (https://jdk.java.net/archive/)

2. 원하는 위치에 압축을 푼다. (예: C:\jdk-21.0.2)

3. 환경설정에서 JAVA_HOME의 jdk 위치를 수정해서 넣어준다.

4. 명령 프롬프트에서 잘 세팅 되었는지 확인한다.

5. Spring STS를 실행하고 상단 Window>Preferences를 클릭한다.

6. Java>Compiler를 선택하고 JDK를 21로 변경 후 Apply(적용)한다.

7. Java>Installed JREs를 선택한 후 21 버전으로 선택 후 apply(적용)을 클릭한다.

8. Spring STS를 종료한다.

9. 원도우 탐색기를 실행해서 Spring STS가 설치된 위치로 이동한다.

10. SpringToolSuite4.ini 파일에 마우스 우클릭을 해서 메모장에서 편집을 클릭한다.

11. -vm을 찾고 그 아래 있던 정보는 지우고 새로 설치한 jdk위치를 포함한 아래 경로를 넣어주고 저장한다.

12. Spring STS를 다시 실행한다.

13. Spring Web Gradle 프로젝트를 생성한다.

 

이제 잘 실행될 것이다.

 

PS. SpringWeb 프로젝트를 생성했지만 Boot Dashboard의 local에 추가가 안되면 프로젝트 생성에 오류가 발생한 것이다. 

프로젝트가 오류 없이 생성되면 아래와 같이 자동으로 프로젝트가 추가된다.

 

이번 포스팅에서 ToolchainDownloadFailedException: No locall installed toolchains match and toolchain download repositories have not been configured.

오류 해결방법에 대해 알아봤다.

삽질은 이제 그만...

 

 

 

 

 

 

 

반응형