웹개발

불대수 / 부울대수

업무 중 2021. 1. 21. 12:41

부울 대수(Boolean algebra) 또는 불 대수는 조지 불(George Boole)이 창안한 논리 대수입니다. 대수(代數)의 사전적 의미는 "숫자 대신에 그 숫자를 대표하는 문자를 써서 수학 법칙을 간명하게 나타내는 수학의 한 분야"로 부울 대수는 논리 문제로 기호로 설명하는 것이라 할 수 있습니다. 부울 대수는 값의 범위가 참(True)과 거짓(False)으로 한정되는 대수의 한 분야로 컴퓨터에서 부울 대수가 기본적으로 언급되는 이유는 바로 컴퓨터의 논리 회로가 1, 0만의 디지털 신호를 다루기 때문입니다. 부울 대수는 회로 뿐만아니라 소프트웨어와도 깊은 연관성을 가지는데 프로그래밍 언어에서 조건을 기술하는 if , for, while 등의 문장에서는 부울 대수와 연관성을 가지는 논리 연산이 수행됩니다. 기본적인 부울 대수 법칙을 숙지해두면 회로 관련 문제 뿐만아니라 추후 프로그래밍 과정에서 복잡한 조건을 보다 명확한 방식으로 기술하는데 도움을 받을 수 있습니다.

NOT, AND, OR를 기본적인 연산자로 사용하며 관련 내용은 "정보처리기능사 필기 해설 1 - 논리게이트"를 참조하실 수 있습니다. 부울 대수의 법칙들은 아래와 같습니다.

 

■ 결합(Associativity) 법칙

논리합, 논리곱 등 동일한 연산자가 연속되어 있을때 괄호의 위치를 변경해도 동일한 결과를 가져옴

 

■ 교환(Commutativity) 법칙

논리합, 논리곱 연산자 앞뒤의 연산 대상의 순서를 바꾸어도 동일한 결과를 가져옴

 

■ 배분(Distributivity) 법칙

괄호로 묶인 대상과 논리합, 논리곱을 수행하는 경우 괄호 내의 대상과 개별적인 연산을 수행한 다음 괄호내 연산을 수행해도 동일한 결과를 가져옵니다. 배분법칙에서 주의할 점은 일반 대수의 경우에도 a(b+c)=ab + ac는 성립합니다. 그렇지만 a+(bc) = (a+b)(a+c)는 일반 대수에서는 성립하지 않는 다는 점입니다. a+(bc) = (a+b)(a+c)는 부울 대수에서만 성립합니다.

일반 대수로 a=1, b=2, c=3으로 a+(bc) = 7이지만 (a+b)(a+c) = 12입니다. a+(bc) = (a+b)(a+c) 배분 법칙이 일반대수에서는 성립되지 않습니다. 반면에 부울 대수로 a=1, b=0, c=1을 대입하면 a+(bc) = 1(0) = 1이고 (a+b)(a+c) = (1)(1) = 1로 이며  a=0, b=0, c=1을 대입해도 a+(bc) = 0(0) = 0이고 (a+b)(a+c) = (0)(1) = 0으로 부울대수의 a+(bc) = (a+b)(a+c) 배분 법칙은 성립합니다.

 

■ 항등(Identity) 법칙

0과 논리합, 1과 논리곱하면 원래 값과 동일한 결과를 가져옴

 

■ 소멸(Annihilator) 법칙

1과 논리합, 0과 논리곱하면 원래값이 원어지는 결과를 가져옴. 논리식 간소화에 매우 유용한 법칙.

 

■ 멱등(Idempotence) 법칙

동일한 연산 대상에 대해서 논리합, 논리곱을 여러번 수행해도 동일한 결과를 가져옴

 

■ 흡수(Absorption) 법칙

항등 법칙과 소멸 법칙이 응용된 법칙으로 괄호 바깥과 내부에 동일한 대상이 서로 다른 논리합, 논리곱 연산자로 묶인 경우 괄호 내외부에 동일하게 등장하는 연산 대상으로 흡수되는 결과를 가져옴

 

■ 부정(Complementation) 법칙

집합의 여집합 또는 보집합과 동일한 결과를 가져옴. 부울 대수의 부정을 일반 대수의 음수(-)로 대치시키면 법칙이 성립되지 않음에 주의해야 합니다.  3 * -3 = 0이 아니라 -9입니다. 3+ -3 = 1이 아니라 0입니다. 

 

■ 드모르간(De Morgan)의 법칙

두 연산 대상에 대한 논리합, 논리곱 연산 결과의 부정은 연산 대상 각각의 부정을 논리곱, 논리합으로 전환한 것과 동일한 결과를 가져옴. 필자의 경우 프로그램을 작성하다가 복자한 조건문을 명확하게 하기 위해서 이 법칙을 자주 사용합니다. 예를 들어 "if (a > b && c < d)..."라는 C 코드를 거꾸로 기술하면 드 모르간의 법칙을 따라서 부등호를 전환하고 &&(AND)는 ||(OR)로 바꾸어 주면 "if (a <=b || c>=d) ..."로 작성할 수 있습니다. 두 문장중에 더 명쾌한 방식으로 조건문을 기술하는 것입니다.

 

■ 논리식 간소화

복잡한 논리식은 위에서 언급한 여러가지 법칙을 응용해서 최소화할 수 있습니다. 항의 개수가 줄어들거나 없어지는 항등, 소멸, 멱등, 흡수, 부정 법칙을 곧바로 적용할 수 있다면 곧바로 논리식이 간소화 되겠지만 그렇지 않다면 결합, 배분, 드 모르간의 법칙 및 기타 간소화 예제를 활용하여 논리식을 변형해가며 간소화 시킵니다. 기본 법칙들을 활용한 간소화 예제들은 아래와 같습니다.

    • 배분법칙으로 식을 전개한 다음 부정법칙으로 1(a+b)를 유도하고 항등법칙에 따라 1과의 논리곱 a+b가 남습니다.
      같은 방식을 적용하면  

      입니다.

       


    • 배분법칙으로 식을 전개한 다음 멱등법칙으로 aa=a, 흡수법칙으로 a+ac=a, a+ab=a가 됩니다.
      같은 방식을 적용하면  

      입니다.

       

    • 배분법칙으로 식을 전개한 다음 멱등법칙으로 a+a=a, 부정법칙으로 1이 되고 흡수법칙으로 a가 남은 상태에서 항등법칙에 따라 최종적으로 a가 남습니다.

    • 부정법칙과 항등법칙을 활용하여 논리식에 영향을 주지 않는  

      를 더하거나(a+0=a) 

      를 곱한(a*1=a) 다음 논리식 간소화를 진행하는 여분의 항 추가 방법도 좋은 방법입니다.

 

정보처리기능사 필기 문제에서는 부울 대수의 기본 법칙이나 기본 게이트에 대한 논리식 위주의 문제가 출제되고 있습니다. 간소화 문제가 나오기도 합니다. 정답보기를 클릭하면 답을 확인할 수 있습니다.

 

1. 불 대수의 관계가 옳은 것은? (정답보기☜)

   가. 

   나. 

   다. 

         라. 

 

※ (나)번 보기는 헷갈릴 수 있는데 드 모르간의 법칙을 확인해 보세요.

 

 

2. 다음 논리 회로를 나타내는 불 대수식은? (정답보기☜)

    가. X = ABC 나. X = A'+B'+C'

    다. X = AB+C 라. X = A+B+C

 

 

3. 다음 보기의 논리회로도에 맞는 불 대수식은? (정답보기☜)

    가. Y=AB          나. Y=A+B

    다. Y=A(A+B)   라. Y=(A+B)B

 

※ 회로도를 그대로 옮기면 (A+B)+B 이고 결합법칙을 적용하면 A+(B+B), 멱등법칙을 적용하면 A+B가 됩니다.

 

 

4. 불 대수(Boolean Algebra)의 정리 중 틀린 것은? (정답보기☜)

    가. A+A=A   나. AA'=0

    다. A+A'=1  라. A+0=0

 

※ 멱등법칙과 부정법칙을 확인하세요.

 

 

5.  

와 같은 논리식은? (정답보기☜)

   가.

  나. 

   다. 

  라. 

 

※ 드모르간의 법칙과 배분법칙, 부정법칙, 항등법칙을 차례로 적용하면

 

6. 다음 논리회로의 논리식은? (정답보기☜)

    가. f = A + B'         나. f = A' + B

    다. f = A·B 라. f = A + B

 

※ 처음 식은 A'+B'에 대한 NOR이므로 (A'+B')'입니다. 드 모르간의 법칙을 적용하면 f=AB가 됩니다.

 

 

7. 다음 회로에 해당하는 출력 Y의 논리식은? (정답보기☜)

    가. A' + B 나. A + B'

    다. A' + B' 라. A + B

 

※ 입력 A가 연결되는 게이트가 NOT이 아니라 NAND 게이트 이지만 입력이 하나이므로 NOT으로 간주하면 됩니다. NOT, AND, OR를 응용한 NOR, NAND, XOR, XNOR에 대한 기본 논리식과 간소화된 논리식은 숙지할 필요가 있습니다. XOR : A'B+AB',  NAND : (AB)'=A'+B', NOR : (A+B)'=A'B', XNOR : AB+A'B'

 

8. 논리식

를 간소화 하면 결과는? (정답보기☜)

   가.  Z=A+B    나. Z=A'B

   다.  Z=A       라. Z=1

 

※ 흡수법칙을 참고하세요. 



출처: https://yaraba.tistory.com/602 [야라바]

'웹개발' 카테고리의 다른 글

알고리즘 설계 기법(Algorithm Design Paradigm)  (0) 2021.01.26
DMA  (0) 2021.01.20
논리회로  (0) 2021.01.19
WebService  (0) 2021.01.15
트랜잭션(Transaction)이란?  (0) 2021.01.11