본문으로 이동

1차 논리: 두 판 사이의 차이

위키백과, 우리 모두의 백과사전.
내용 삭제됨 내용 추가됨
잔글 봇: 같이 보기 문단 추가
 
(사용자 14명의 중간 판 32개는 보이지 않습니다)
1번째 줄: 1번째 줄:
{{위키데이터 속성 추적}}
'''1차 논리'''(一次論理, {{llang|en|first-order logic}})는 원소에만 한정 기호를 가할 수 있고, 술어에는 한정 기호를 가할 수 없는 [[술어 논리]]이다.<ref>{{서적 인용|이름=Wilfrid |성=Hodges|날짜=2001-08|장=Classical logic I: first order logic|editor-first=Lou|editor-last=Goble|제목=The Blackwell Guide to Philosophical Logic|출판사=Blackwell|isbn=978-0-631-20693-4|zbl=1003.03010|언어=en}}</ref> [[명제 논리]]와 달리 변수에 대하여 한정 기호를 사용할 수 있으나, [[2차 논리]]와 달리 변수들의 집합에 대하여 한정 기호를 사용할 수 없다. 1차 논리의 경우, ([[2차 논리]]와 달리) [[괴델의 완전성 정리]] · [[콤팩트성 정리]] · [[뢰벤하임-스콜렘 정리]]와 같은 중요한 성질들이 성립한다.
'''1차 논리'''(一次論理, {{llang|en|first-order logic}})는 원소에만 한정 기호를 가할 수 있고, 술어에는 한정 기호를 가할 수 없는 [[술어 논리]]이다.<ref>{{서적 인용|이름=Wilfrid |성=Hodges|날짜=2001-08|장=Classical logic I: first order logic|editor-first=Lou|editor-last=Goble|제목=The Blackwell Guide to Philosophical Logic|출판사=Blackwell|isbn=978-0-631-20693-4|zbl=1003.03010|언어=en}}</ref> [[명제 논리]]와 달리 변수에 대하여 한정 기호를 사용할 수 있으나, [[2차 논리]]와 달리 변수들의 집합에 대하여 한정 기호를 사용할 수 없다. 1차 논리의 경우, ([[2차 논리]]와 달리) [[괴델의 완전성 정리]] · [[콤팩트성 정리]] · [[뢰벤하임-스콜렘 정리]]와 같은 중요한 성질들이 성립한다.

이외에 '''1차 술어 논리''', '''1계 논리''' 등으로도 불린다. 간단히 '''술어 논리'''(predicate logic)라 하면 1차 논리를 가리키는 경우가 많다.


== 정의 ==
== 정의 ==
1차 논리는 다음의 요소들로 이루어진다.
1차 논리는 다음의 요소들로 이루어진다.
* 특정 문자열들의 집합을 '''[[논리식]]'''의 집합라고 한다. 논리식이 만족시켜아 하는 문법은 재귀적으로 정의된다.
* 특정 문자열들의 집합을 '''[[논리식]]'''의 집합이라고 한다. 논리식이 만족시켜야 하는 문법은 재귀적으로 정의된다.
* 특정 논리식 집합으로부터 다른 논리식을 '''추론'''할 수 있다. 이에 대한 규칙은 힐베르트 체계 및 다른 여러 방식으로 명시될 수 있다.
* 특정 논리식 집합으로부터 다른 논리식을 '''추론'''할 수 있다. 이에 대한 규칙은 힐베르트 체계 및 다른 여러 방식으로 명시될 수 있다.
* 1차 논리 언어의 '''의미론'''이란, 그 언어의 문장들에 대하여 참인지 여부를 일관적으로 부여하는 구조이다. 이는 보통 [[모형 (논리학)|모형]]으로 주어진다.
* 1차 논리 언어의 '''의미론'''이란 그 언어의 문장들에 대하여 참인지 여부를 일관적으로 부여하는 구조이다. 이는 보통 [[모형 (논리학)|모형]]으로 주어진다.


=== 문법 ===
=== 문법 ===
18번째 줄: 21번째 줄:
** 가산 무한 개의 변수들만으로 충분한 이유는 모든 [[논리식]]의 길이가 유한하기 때문이다. [[무한 논리]]의 경우 더 많은 변수들을 추가할 수 있다.
** 가산 무한 개의 변수들만으로 충분한 이유는 모든 [[논리식]]의 길이가 유한하기 때문이다. [[무한 논리]]의 경우 더 많은 변수들을 추가할 수 있다.
* [[명제 논리]]의 연산 <math>\implies</math> ([[함의]]) 및 <math>\lnot</math> ([[부정]]).
* [[명제 논리]]의 연산 <math>\implies</math> ([[함의]]) 및 <math>\lnot</math> ([[부정]]).
** 그 대신 다른 기호들을 사용할 수도 있다. 예를 들어, [[논리합]] <math>\land</math> 또는 [[논리곱]] <math>\lor</math> 등이 있다.
** 그 대신 다른 기호들을 사용할 수도 있다. 예를 들어, [[논리합]] <math>\lor</math> 또는 [[논리곱]] <math>\land</math> 등이 있다.
* [[등호]] <math>=</math>
* [[등호]] <math>=</math>
* '''전칭 기호'''(全稱記號, {{llang|en|universal quantifier}}) <math>\forall</math>.
* '''전칭 기호'''(全稱記號, {{llang|en|universal quantifier}}) <math>\forall</math>.
** 그 대신 '''존재 기호'''(存在記號, {{llang|en|existential quantifier}}) <math>\exists</math>를 사용할 수도 있다. 사실, 임의의 변수 <math>x</math>에 대하여 <math>\forall x\phi\iff \lnot\exists x\lnot\phi</math>이며 <math>\exists x\phi\iff \lnot\forall x\lnot\phi</math>이므로, 이들은 서로 동치이다.
** 그 대신 '''존재 기호'''(存在記號, {{llang|en|existential quantifier}}) <math>\exists</math>를 사용할 수도 있다. 사실, 임의의 변수 <math>x</math>에 대하여 <math>\forall x\phi\iff \lnot\exists x\lnot\phi</math>이며 <math>\exists x\phi\iff \lnot\forall x\lnot\phi</math>이므로, 이들은 서로 동치이다.
* 각 <math>i\in I</math>에 대하여, 기호 <math>\mathsf f_i</math>. 이를 <math>m_i</math>항 '''연산'''이라고 하며, <math>m_i</math>를 <math>\mathsf f_i</math>의 '''항수'''(項數, {{llang|en|arity}})라고 한다. 0항 연산을 '''상수'''({{llang|en|constant}})라고 한다.
* 각 <math>i\in I</math>에 대하여, 기호 <math>\mathsf f_i</math>. 이를 <math>m_i</math>항 '''연산'''이라고 하며, <math>m_i</math>를 <math>\mathsf f_i</math>의 '''[[항수 (수학)|항수]]'''(項數, {{llang|en|arity}})라고 한다. 0항 연산을 '''상수'''({{llang|en|constant}})라고 한다.
* 각 <math>j\in J</math>에 대하여, 기호 <math>\mathsf R_j</math>. 이를 <math>n_j</math>항 '''관계'''라고 하며, <math>n_j</math>를 <math>\mathsf R_j</math>의 '''항수'''(項數, {{llang|en|arity}})라고 한다. 1항 관계를 '''술어'''({{llang|en|predicate}})라고 한다. (항수가 0인 관계는 고전 [[명제 논리]]에서는 참 또는 거짓이 되므로 자명하다.)
* 각 <math>j\in J</math>에 대하여, 기호 <math>\mathsf R_j</math>. 이를 <math>n_j</math>항 '''관계'''라고 하며, <math>n_j</math>를 <math>\mathsf R_j</math>의 '''항수'''(項數, {{llang|en|arity}})라고 한다. 1항 관계를 '''술어'''({{llang|en|predicate}})라고 한다. (항수가 0인 관계는 고전 [[명제 논리]]에서는 참 또는 거짓이 되므로 자명하다.)
* 이 밖에도, 괄호 <math>()</math> 및 반점 <math>,</math> 등은 엄밀히 말해 불필요하지만, 가독성을 돕기 위해 첨가한다. 예를 들어, <math>\mathsf f_i\mathsf x_0\mathsf x_2</math> 대신 <math>\mathsf f_i(\mathsf x_0,\mathsf x_2)</math>로 쓴다.
* 이 밖에도, 괄호 <math>()</math> 및 반점 <math>,</math> 등은 엄밀히 말해 불필요하지만, 가독성을 돕기 위해 첨가한다. 예를 들어, <math>\mathsf f_i\mathsf x_0\mathsf x_2</math> 대신 <math>\mathsf f_i(\mathsf x_0,\mathsf x_2)</math>로 쓴다.
41번째 줄: 44번째 줄:


=== 공리와 추론 규칙 ===
=== 공리와 추론 규칙 ===
1차 논리의 증명 이론은 다양한 방식으로 공리화할 수 있다. 예를 들어 [[다비트 힐베르트]]의 힐베르트 체계({{llang|en|Hilbert system}})나, [[게르하르트 겐첸]]의 시퀀트 계산법({{llang|en|sequent calculus}})이나 자연 언역({{llang|en|natural deduction}}) 등을 사용할 수 있다.
1차 논리의 [[증명 이론]]은 다양한 방식으로 공리화할 수 있다. 예를 들어 [[다비트 힐베르트]]의 [[힐베르트 체계]]({{llang|en|Hilbert system}})나, [[게르하르트 겐첸]]의 [[시퀀트 계산]]({{llang|en|sequent calculus}})이나 [[자연 연역]]({{llang|en|natural deduction}}) 등을 사용할 수 있다.


1차 논리를 힐베르트 체계를 사용하여 공리화하면, 다음과 같다. 우선, 편의상 다음과 같은 기호만을 사용한다고 하자.
1차 논리를 힐베르트 체계를 사용하여 공리화하면, 다음과 같다. 우선, 편의상 다음과 같은 기호만을 사용한다고 하자.
60번째 줄: 63번째 줄:
\chi
\chi
\end{matrix}</math>
\end{matrix}</math>
과 [[일반화 (논리학)|일반화]]
:㈁ <math>\begin{matrix}
\phi\\
\hline
\forall x\phi
\end{matrix}</math>
::추론 규칙 에서, <math>x</math>는 <math>\phi</math>의 자유 변수이어야 한다.
가 있다. 이 밖에, 다음과 같은 [[명제 논리]]의 공리 기본꼴들이 사용된다.
가 있다. 이 밖에, 다음과 같은 [[명제 논리]]의 공리 기본꼴들이 사용된다.
: <math>\phi \implies \left( \chi \implies \phi \right) </math>
: <math>\phi \implies \left( \chi \implies \phi \right) </math>
: <math>\left( \phi \implies \left( \chi \implies \psi \right) \right) \implies \left( \left( \phi \implies \chi \right) \implies \left( \phi \implies \psi \right) \right)</math>
: <math>\left( \phi \implies \left( \chi \implies \psi \right) \right) \implies \left( \left( \phi \implies \chi \right) \implies \left( \phi \implies \psi \right) \right)</math>
: <math>\left ( \lnot \phi \implies \lnot \chi \right) \implies \left( \chi\implies \phi \right) </math>
: <math>\left ( \lnot \phi \implies \lnot \chi \right) \implies \left( \chi\implies \phi \right) </math>
1차 술어 논리의 경우, 다음과 같은 추가 공리 기본꼴들이 사용된다.
1차 술어 논리의 경우, 다음과 같은 추가 공리 기본꼴들이 사용된다.
: <math> \forall x\phi\implies\phi[t/x]</math>
: <math> \forall x\phi\implies\phi[t/x]</math>
: <math>\forall x\left(\phi\implies\chi\right) \implies \left( \forall x\phi \implies \forall x\chi\right)</math>
: <math>\forall x\left(\phi\implies\chi\right) \implies \left( \forall x\phi \implies \forall x\chi\right)</math>
:㈆ <math> \phi \implies \forall x\phi</math>
::공리 기본꼴 에서, <math>x</math>는 <math>\phi</math>의 자유 변수일 수 없다.
:㈇ <math>x = x</math>
:㈇ <math>x = x</math>
:㈈ <math>\left(t=u\right) \implies \left( \phi[t/x] \implies \phi[u/x] \right)</math>
:㈈ <math>\left(t=u\right) \implies \left( \phi[t/x] \implies \phi[u/x] \right)</math>
95번째 줄: 103번째 줄:
비논리 기호를 포함하지 않는 1차 논리 문장들의 집합을 <math>\mathcal L_=^0</math>라고 하자. 그 가운데, 모든 [[모형 (논리학)|모형]]에서 참인 문장들의 부분 집합
비논리 기호를 포함하지 않는 1차 논리 문장들의 집합을 <math>\mathcal L_=^0</math>라고 하자. 그 가운데, 모든 [[모형 (논리학)|모형]]에서 참인 문장들의 부분 집합
:<math>\mathcal T=\{\phi\in\mathcal L_=^0\colon\forall M\in\operatorname{Model}(\mathcal L_=)\colon M\models\phi\}</math>
:<math>\mathcal T=\{\phi\in\mathcal L_=^0\colon\forall M\in\operatorname{Model}(\mathcal L_=)\colon M\models\phi\}</math>
을 생각하자. 또한, <math>\mathcal L_=^0</math> 속에서, 위의 힐베르트 체계를 통해 증명할 수 있는 문장들의 집합을
을 생각하자. 또한, <math>\mathcal L_=^0</math> 속에서, 위의 힐베르트 체계를 통해 증명할 수 있는 문장들의 집합을
:<math>\mathcal T'=\{\phi\in\mathcal L_=^0\colon\vdash\phi\}</math>
:<math>\mathcal T'=\{\phi\in\mathcal L_=^0\colon\vdash\phi\}</math>
그렇다면, 다음이 성립한다.
그렇다면, 다음이 성립한다.
* 1차 논리의 [[건전성 정리]]에 따르면, <math>\mathcal T=\mathcal T'</math>이다. 즉, 명제가 증명 가능한지 여부는 명제가 참인지 여부와 동치이다.
* 1차 논리의 [[건전성 정리]]에 따르면, <math>\mathcal T=\mathcal T'</math>이다. 즉, 명제가 증명 가능한지 여부는 명제가 참인지 여부와 동치이다.
* <math>\mathcal T</math>는 [[재귀 집합]]이다. (이는 레오폴트 뢰벤하임이 1915년에 증명하였다.)
* <math>\mathcal T</math>는 [[재귀 집합]]이다. (이는 레오폴트 뢰벤하임이 1915년에 증명하였다.)


134번째 줄: 142번째 줄:
는 두 개의 [[이항 연산]]과 하나의 1항 연산 및 두 개의 상수(0항 연산)을 포함하며, 하나의 2항 관계를 갖는다. 보통
는 두 개의 [[이항 연산]]과 하나의 1항 연산 및 두 개의 상수(0항 연산)을 포함하며, 하나의 2항 관계를 갖는다. 보통
<math>\mathsf R_\le(a,b)</math>는 <math>a\le b</math>와 같이 표기한다.
<math>\mathsf R_\le(a,b)</math>는 <math>a\le b</math>와 같이 표기한다.

=== 범주 ===
[[범주 (수학)|범주]]의 1차 논리 언어는 다음과 같이, 하나의 3항 관계
* <math>\mathsf C(-,-,-)</math> (<math>\mathsf C(x,y,z)</math>는 <math>x\circ y=z</math>임을 뜻함)
와 두 개의 1항 연산
* <math>\operatorname{dom}(-)</math> ([[사상 (수학)|사상]]의 [[정의역]])
* <math>\operatorname{codom}(-)</math> ([[사상 (수학)|사상]]의 [[공역]])
으로 나타낼 수 있다. 변수들은 [[사상 (수학)|사상]]을 나타내며, 대상들은 항등 사상으로 나타내어진다. 편의상 다음과 같은 술어를 정의하자.
:<math>\mathsf{Obj}(x)\iff \operatorname{dom}(x)=\operatorname{codom}(x)=x</math>
이는 <math>x</math>가 항등 사상(즉, 대상)임을 뜻한다. 그렇다면, 범주의 1차 논리 이론은 다음과 같은 공리들로 구성된다.
* <math>\operatorname{dom}(x)=x\iff\operatorname{codom}(x)=x</math> (항등 사상의 두 정의의 동치성)
* <math>\mathsf{Obj}(\operatorname{dom}x)</math> (사상의 정의역은 대상)
* <math>\mathsf{Obj}(\operatorname{codom}x)</math> (사상의 공역은 대상)
* <math>\mathsf C(x,y,z)\implies\operatorname{dom} x=\operatorname{codom}y</math> (사상 합성의 존재의 [[필요 조건]])
* <math>\mathsf C(x,y,z)\implies\operatorname{dom} y=\operatorname{dom} z</math> (합성 사상의 정의역)
* <math>\mathsf C(x,y,z)\implies\operatorname{codom}x=\operatorname{codom}z</math> (합성 사상의 공역)
* <math>\mathsf C(x,y,a)\land\mathsf C(a,z,c)\land\mathsf C(y,z,b)\land\mathsf C(x,b,d)\implies c=d</math> (사상 합성의 [[결합 법칙]])
* <math>\mathsf{Obj}(x)\land\mathsf C(x,y,z)\implies y=z</math> (항등 사상과의 합성)
* <math>\mathsf{Obj}(y)\land\mathsf C(x,y,z)\implies x=z</math> (항등 사상과의 합성)
이 이론의 [[모형 (논리학)|모형]]의 개념은 '''[[작은 범주]]'''의 개념과 동치이다.


== 역사 ==
== 역사 ==
[[고틀로프 프레게]]가 1879년에 출판된 《개념 표기법》<ref>{{서적 인용|제목=Begriffsschrift, eine der arithmetischen nachgebildete Formelsprache des reinen Denkens|이름=Gottlob|성=Frege|저자고리=고틀로프 프레게|날짜=1879|위치=[[할레]]|출판사=Verlag von Louis Nebert|url=http://gallica.bnf.fr/ark:/12148/bpt6k65658c|언어=de}}</ref>에서 사용한 논리는 (현대적 용어로는) [[2차 논리]]였다.<ref name="Putnam"/>{{rp|295}}<ref name="Moore"/>{{rp|101–102}} 이후 1885년에 [[찰스 샌더스 퍼스]]는 1차 논리와 2차 논리를 구분하였다.<ref>{{저널 인용|날짜=1885-01|이름=Charles Sanders|성=Peirce|저자고리=찰스 샌더스 퍼스|제목=On the algebra of logic: a contribution to the philosophy of notation|저널=American Journal of Mathematics|권=7|호=2|쪽=180–202|doi=10.2307/2369451|jstor=2369451|issn=0002-9327|jfm= 17.0044.02|언어=en}}</ref><ref name="Putnam">{{저널 인용
[[고틀로프 프레게]]가 1879년에 출판된 《개념 표기법》<ref>{{서적 인용|제목=Begriffsschrift, eine der arithmetischen nachgebildete Formelsprache des reinen Denkens|이름=Gottlob|성=Frege|저자링크=고틀로프 프레게|날짜=1879|위치=[[할레]]|출판사=Verlag von Louis Nebert|url=http://gallica.bnf.fr/ark:/12148/bpt6k65658c|언어=de}}</ref>에서 사용한 논리는 (현대적 용어로는) [[2차 논리]]였다.<ref name="Putnam"/>{{rp|295}}<ref name="Moore"/>{{rp|101–102}} 이후 1885년에 [[찰스 샌더스 퍼스]]는 1차 논리와 2차 논리를 구분하였다.<ref>{{저널 인용|날짜=1885-01|이름=Charles Sanders|성=Peirce|저자링크=찰스 샌더스 퍼스|제목=On the algebra of logic: a contribution to the philosophy of notation|저널=American Journal of Mathematics|권=7|호=2|쪽=180–202|doi=10.2307/2369451|jstor=2369451|issn=0002-9327|jfm= 17.0044.02|언어=en}}</ref><ref name="Putnam">{{저널 인용
| doi= 10.1016/0315-0860(82)90123-9
| doi= 10.1016/0315-0860(82)90123-9
| 성= Putnam |이름= Hilary |저자고리=힐러리 퍼트넘
| 성= Putnam |이름= Hilary |저자링크=힐러리 퍼트넘
| year=1982
| year=1982
| title=Peirce the logician
| title=Peirce the logician
144번째 줄: 172번째 줄:
| volume=9
| volume=9
| pages= 290–301
| pages= 290–301
| issue= 3 | 언어=en}}</ref>{{rp|296}}<ref name="Moore">{{서적 인용|장url=http://mcps.umn.edu/philosophy/11_4Moore.pdf|장=The emergence of first-order logic|제목=History and philosophy of modern mathematics|이름=Gregory H.|성=Moore|날짜=1988|쪽=95–135|editor1-first=William|editor1-last=Aspray|editor2-first=Philip|editor2-last=Kitcher|총서=Minnesota Studies in the Philosophy of Science|권=11|jstor=10.5749/j.cttttp0k.7|출판사=University of Minnesota Press|언어=en}}</ref>{{rp|99}} 퍼스는 1차 논리를 "1차 의도적 논리"({{llang|en|first-intensional logic}})로, [[2차 논리]]를 "2차 의도적 논리"({{llang|en|second-intensional logic}})로 일컬었다.<ref name="Moore"/>{{rp|99–100}}
| issue= 3 | 언어=en}}</ref>{{rp|296}}<ref name="Moore">{{서적 인용|장url=http://mcps.umn.edu/philosophy/11_4Moore.pdf|장=The emergence of first-order logic|제목=History and philosophy of modern mathematics|이름=Gregory H.|성=Moore|날짜=1988|쪽=95–135|editor1-first=William|editor1-last=Aspray|editor2-first=Philip|editor2-last=Kitcher|총서=Minnesota Studies in the Philosophy of Science|권=11|jstor=10.5749/j.cttttp0k.7|출판사=University of Minnesota Press|언어=en}}</ref>{{rp|99}} 퍼스는 1차 논리를 "1차 내포 논리"({{llang|en|first-intensional logic}})로, [[2차 논리]]를 "2차 내포 논리"({{llang|en|second-intensional logic}})로 일컬었다.<ref name="Moore"/>{{rp|99–100}}


이후 [[에른스트 체르멜로]]는 [[2차 논리]]를 사용하여 [[집합론]]을 개발하였다. [[토랄프 스콜렘]]은 1922년에 체르멜로의 집합론을 1차 논리로 재정의하였다.<ref>{{서적 인용|이름=Thoralf|성=Skolem|저자고리=토랄프 스콜렘|장=Einige Bemerkungen zur axiomatischen Begründung der Mengenlehre|제목=Matematikerkongressen i Helsingfors den 4–7 Juli 1922, Den femte skandinaviska matematikerkongressen, Redogörelse|출판사=Akademiska Bokhandeln|위치=[[헬싱키]]|쪽=217–232|날짜=1923|jfm=49.0138.02|언어=de}}</ref><ref name="Moore"/>{{rp|123–124}}<ref>{{저널 인용|제목=On how logic became first-order|이름=Matti|성=Eklund|저널=Nordic Journal of Philosophical Logic|권=1|호=2|쪽=147–167|날짜=1996-12|url=http://www.hf.uio.no/ifikk/forskning/publikasjoner/tidsskrifter/njpl/vol1no2/howlogic.pdf|zbl= 0885.03006|언어=en}}</ref>{{rp|153–156}}<ref name="Ferreiros">{{저널 인용|제목=The road to modern logic — an interpretation|이름=Jose|성=Ferreiros|저널=The Bulletin of Symbolic Logic|권=7|호=4|날짜=2001-12|쪽= 441–484 |jstor=2687794|doi=10.2307/2687794|issn=1079-8986|url=http://personal.us.es/josef/BSL0704-001.pdf|zbl= 1005.03003|언어=en}}</ref>{{rp|447}} 이는 오늘날 사용되는 [[체르멜로-프렝켈 집합론]]의 기반이 되었다.
이후 [[에른스트 체르멜로]]는 [[2차 논리]]를 사용하여 [[집합론]]을 개발하였다. [[토랄프 스콜렘]]은 1922년에 체르멜로의 집합론을 1차 논리로 재정의하였다.<ref>{{서적 인용|이름=Thoralf|성=Skolem|저자링크=토랄프 스콜렘|장=Einige Bemerkungen zur axiomatischen Begründung der Mengenlehre|제목=Matematikerkongressen i Helsingfors den 4–7 Juli 1922, Den femte skandinaviska matematikerkongressen, Redogörelse|출판사=Akademiska Bokhandeln|위치=[[헬싱키]]|쪽=217–232|날짜=1923|jfm=49.0138.02|언어=de}}</ref><ref name="Moore"/>{{rp|123–124}}<ref>{{저널 인용|제목=On how logic became first-order|이름=Matti|성=Eklund|저널=Nordic Journal of Philosophical Logic|권=1|호=2|쪽=147–167|날짜=1996-12|url=http://www.hf.uio.no/ifikk/forskning/publikasjoner/tidsskrifter/njpl/vol1no2/howlogic.pdf|zbl= 0885.03006|언어=en}}</ref>{{rp|153–156}}<ref name="Ferreiros">{{저널 인용|제목=The road to modern logic — an interpretation|이름=Jose|성=Ferreiros|저널=The Bulletin of Symbolic Logic|권=7|호=4|날짜=2001-12|쪽=441–484|jstor=2687794|doi=10.2307/2687794|issn=1079-8986|url=http://personal.us.es/josef/BSL0704-001.pdf|zbl=1005.03003|언어=en|access-date=2016-07-29|archive-date=2015-03-26|archive-url=https://web.archive.org/web/20150326210656/http://personal.us.es/josef/BSL0704-001.pdf|url-status=}}</ref>{{rp|447}} 이는 오늘날 사용되는 [[체르멜로-프렝켈 집합론]]의 기반이 되었다.


[[제2차 세계 대전]] 이후 1차 논리는 ([[2차 논리]]나 [[ 이론]] 등을 대신하여) 통상적으로 사용되는 수학의 기반이 되었다.<ref name="Ferreiros"/>{{rp|448}}
[[제2차 세계 대전]] 이후 1차 논리는 ([[2차 논리]]나 [[유형 이론]] 등을 대신하여) 통상적으로 사용되는 수학의 기반이 되었다.<ref name="Ferreiros"/>{{rp|448}}


== 참고 문헌 ==
== 같이 보기 ==
* [[논리 기호]]
* [[로지반]]
* [[프리넥스 표준형]]
* [[프롤로그 (프로그래밍 언어)]]
* [[관계대수]]
* [[관계형 모델]]
* [[스콜렘 표준형]]
* [[진리표]]
== 각주 ==
{{각주}}
{{각주}}


== 바깥 고리 ==
== 외부 링크 ==
* {{eom|title=Logical calculus}}
* {{eom|title=Logical calculus}}
* {{eom|title=Characterization theorems for logics}}
* {{eom|title=Characterization theorems for logics}}
165번째 줄: 202번째 줄:
* {{nlab|id=first-order logic|title=First-order logic}}
* {{nlab|id=first-order logic|title=First-order logic}}


[[분류:수리논리학]]
[[분류:술어 논리]]

2024년 6월 2일 (일) 18:51 기준 최신판

1차 논리(一次論理, 영어: first-order logic)는 원소에만 한정 기호를 가할 수 있고, 술어에는 한정 기호를 가할 수 없는 술어 논리이다.[1] 명제 논리와 달리 변수에 대하여 한정 기호를 사용할 수 있으나, 2차 논리와 달리 변수들의 집합에 대하여 한정 기호를 사용할 수 없다. 1차 논리의 경우, (2차 논리와 달리) 괴델의 완전성 정리 · 콤팩트성 정리 · 뢰벤하임-스콜렘 정리와 같은 중요한 성질들이 성립한다.

이외에 1차 술어 논리, 1계 논리 등으로도 불린다. 간단히 술어 논리(predicate logic)라 하면 1차 논리를 가리키는 경우가 많다.

정의

[편집]

1차 논리는 다음의 요소들로 이루어진다.

  • 특정 문자열들의 집합을 논리식의 집합이라고 한다. 논리식이 만족시켜야 하는 문법은 재귀적으로 정의된다.
  • 특정 논리식 집합으로부터 다른 논리식을 추론할 수 있다. 이에 대한 규칙은 힐베르트 체계 및 다른 여러 방식으로 명시될 수 있다.
  • 1차 논리 언어의 의미론이란 그 언어의 문장들에 대하여 참인지 여부를 일관적으로 부여하는 구조이다. 이는 보통 모형으로 주어진다.

문법

[편집]

다음과 같은 데이터가 주어졌다고 하자. (여기서 자연수, 즉 음이 아닌 정수의 집합이다.)

  • 집합 및 함수 , . 는 유한 집합이거나 무한 집합일 수 있다. 이를 연산(演算, 영어: operation)의 집합이라고 한다.
  • 집합 및 함수 , . 는 유한 집합이거나 무한 집합일 수 있다. 이를 관계(關係, 영어: relation)의 집합이라고 한다.

그렇다면, 으로 정의되는 1차 논리 언어 는 특정한 문자열들의 집합이다. 이 문자열을 구성하는 문자 집합

은 구체적으로 다음과 같다.

  • 가산 무한 개의 변수들
    • 가산 무한 개의 변수들만으로 충분한 이유는 모든 논리식의 길이가 유한하기 때문이다. 무한 논리의 경우 더 많은 변수들을 추가할 수 있다.
  • 명제 논리의 연산 (함의) 및 (부정).
    • 그 대신 다른 기호들을 사용할 수도 있다. 예를 들어, 논리합 또는 논리곱 등이 있다.
  • 등호
  • 전칭 기호(全稱記號, 영어: universal quantifier) .
    • 그 대신 존재 기호(存在記號, 영어: existential quantifier) 를 사용할 수도 있다. 사실, 임의의 변수 에 대하여 이며 이므로, 이들은 서로 동치이다.
  • 에 대하여, 기호 . 이를 연산이라고 하며, 항수(項數, 영어: arity)라고 한다. 0항 연산을 상수(영어: constant)라고 한다.
  • 에 대하여, 기호 . 이를 관계라고 하며, 항수(項數, 영어: arity)라고 한다. 1항 관계를 술어(영어: predicate)라고 한다. (항수가 0인 관계는 고전 명제 논리에서는 참 또는 거짓이 되므로 자명하다.)
  • 이 밖에도, 괄호 및 반점 등은 엄밀히 말해 불필요하지만, 가독성을 돕기 위해 첨가한다. 예를 들어, 대신 로 쓴다.

이 기호들 가운데, 를 제외한 기호들을 논리 기호(영어: logical symbol)라고 한다.

1차 논리의 (項, 영어: term)은 다음 문법을 따른다.

  • 모든 변수는 항이다.
  • 임의의 개의 항 에 대하여, 은 항이다. (상수의 경우, 즉 일 때, 보통 괄호 를 생략하여 로 쓴다.)

1차 논리의 논리식(영어: (well-formed) formula)은 다음 문법을 따르는, 위 기호들의 문자열이다.

  • 임의의 개의 항 에 대하여, 은 논리식이다.
  • 두 항 , 에 대하여, 는 논리식이다.
  • 논리식 에 대하여, 는 논리식이다.
  • 논리식 에 등장하는 변수 가 자유 변수라면, 는 논리식이다.

여기서 논리식 및 그 속에 등장하는 변수 에 대하여, 만약 를 포함하지 않는다면, 자유 변수(영어: free variable)라고 하며, 그렇지 않다면 종속 변수(영어: bound variable)라고 한다.

자유 변수를 갖지 않는 (즉, 그 속에 등장하는 모든 변수가 종속 변수인) 논리식을 문장(文章, 영어: sentence)이라고 한다.

공리와 추론 규칙

[편집]

1차 논리의 증명 이론은 다양한 방식으로 공리화할 수 있다. 예를 들어 다비트 힐베르트힐베르트 체계(영어: Hilbert system)나, 게르하르트 겐첸시퀀트 계산(영어: sequent calculus)이나 자연 연역(영어: natural deduction) 등을 사용할 수 있다.

1차 논리를 힐베르트 체계를 사용하여 공리화하면, 다음과 같다. 우선, 편의상 다음과 같은 기호만을 사용한다고 하자.

  • 명제 논리에서, 오직 함의 부정 만을 사용한다고 하자. (논리합이나 논리곱과 같은 다른 명제 논리 기호는 이 둘로 나타낼 수 있다.)
  • 술어 논리에서, 오직 전칭 기호 만을 사용한다고 하자. (존재 기호 만으로 나타낼 수 있다.)

이 경우, 다음과 같은 공리 기본꼴(영어: axiom schema)들을 정의한다. 이 공리 기본꼴들에서 사용된 기호들은 다음과 같다.

  • , , 는 임의의 논리식을 뜻한다.
  • , 는 임의의 항을 뜻한다.
  • 는 임의의 변수를 뜻한다.

즉, 공리 기본꼴에서 위의 기호들을 실제의 논리식·항·변수로 치환하면 공리들을 얻는다.

우선, 추론 규칙으로 전건 긍정의 형식

일반화

추론 규칙 ㈁에서, 의 자유 변수이어야 한다.

가 있다. 이 밖에, 다음과 같은 명제 논리의 공리 기본꼴들이 사용된다.

1차 술어 논리의 경우, 다음과 같은 추가 공리 기본꼴들이 사용된다.

공리 기본꼴 ㈈에서, 논리식 의 자유 변수이어야 한다.

위 공리 기본꼴들에서, 논리식 에 등장하는 자유 변수 를 항 로 대체하여 얻는 논리식을 뜻한다. 예를 들어, 의 언어에서

이다. 이때, 논리식 내부의 ‘’에서 가 치환되지 않는 이유는 이 부분에서는 가 종속 변수이기 때문이다.

성질

[편집]

의미론

[편집]

1차 논리의 의미론은 보통 모형으로 주어진다. 주어진 연산 집합 와 관계 집합 을 갖는 1차 논리 언어 가 주어졌다고 하자. 그렇다면, 이 언어의 모형은 집합 및 각 항 연산 에 대하여 해석 및 각 항 관계 에 대하여 그 해석 으로 구성된다. 이를 통해, 의 문장 의 모형 에 대하여, 에서 참인지 또는 거짓인지 여부를 정의할 수 있다. 에서 참이라는 것은

로 표기한다.

보다 일반적으로, 의 논리식 가 자유 변수 를 갖는다고 하자. 그렇다면, 의 모형 및 그 속의 개의 원소

가 주어졌을 때,에서 에 대하여 참인지 또는 거짓인지 여부를 정의할 수 있다. 이는

로 표기한다.

1차 논리의 경우 콤팩트성 정리뢰벤하임-스콜렘 정리가 성립한다.

증명 이론

[편집]

비논리 기호를 포함하지 않는 1차 논리 문장들의 집합을 라고 하자. 그 가운데, 모든 모형에서 참인 문장들의 부분 집합

을 생각하자. 또한, 속에서, 위의 힐베르트 체계를 통해 증명할 수 있는 문장들의 집합을

그렇다면, 다음이 성립한다.

  • 1차 논리의 건전성 정리에 따르면, 이다. 즉, 명제가 증명 가능한지 여부는 명제가 참인지 여부와 동치이다.
  • 재귀 집합이다. (이는 레오폴트 뢰벤하임이 1915년에 증명하였다.)

보다 일반적으로, 임의의 가산 연산 집합 와 관계 집합 를 갖는 1차 논리 언어 속에서, 문장들의 집합을 라고 하자. 그 가운데, 모든 모형에서 참인 문장들의 부분 집합

을 생각하자.

  • 괴델의 완전성 정리에 따르면, 재귀 열거 집합이다.
  • 만약 에 (등호를 제외한) 2항 이상의 항수를 갖는 관계가 존재한다면, 재귀 집합이 아니다.
  • 만약 이며, 의 모든 관계가 술어(1항 관계) 또는 등호라면, 재귀 집합이다. 이러한 언어를 1항 1차 언어(영어: monadic first-order language)라고 한다.

린드스트룀 정리

[편집]

린드스트룀 정리(영어: Lindström’s theorem)에 따르면, 1차 술어 논리는 (가산) 콤팩트성 정리와 하향 뢰벤하임-스콜렘 정리를 만족시키는 가장 강력한 논리 체계이다.[2]

[편집]

집합론

[편집]

체르멜로-프렝켈 집합론의 언어는 하나의 2항 관계 만을 포함하며, 아무런 연산을 갖지 않는다. 집합론에서 사용되는 대부분의 명제들은 이 언어로 나타낼 수 있다.

체와 순서체

[편집]

의 1차 논리 언어

는 두 개의 이항 연산과 하나의 1항 연산 및 두 개의 상수(0항 연산)을 포함하며, 등호 밖의 관계를 갖지 않는다. 보통 와 같이 표기한다.

순서체의 1차 논리 언어

는 두 개의 이항 연산과 하나의 1항 연산 및 두 개의 상수(0항 연산)을 포함하며, 하나의 2항 관계를 갖는다. 보통 와 같이 표기한다.

범주

[편집]

범주의 1차 논리 언어는 다음과 같이, 하나의 3항 관계

  • (임을 뜻함)

와 두 개의 1항 연산

  • (사상정의역)
  • (사상공역)

으로 나타낼 수 있다. 변수들은 사상을 나타내며, 대상들은 항등 사상으로 나타내어진다. 편의상 다음과 같은 술어를 정의하자.

이는 가 항등 사상(즉, 대상)임을 뜻한다. 그렇다면, 범주의 1차 논리 이론은 다음과 같은 공리들로 구성된다.

  • (항등 사상의 두 정의의 동치성)
  • (사상의 정의역은 대상)
  • (사상의 공역은 대상)
  • (사상 합성의 존재의 필요 조건)
  • (합성 사상의 정의역)
  • (합성 사상의 공역)
  • (사상 합성의 결합 법칙)
  • (항등 사상과의 합성)
  • (항등 사상과의 합성)

이 이론의 모형의 개념은 작은 범주의 개념과 동치이다.

역사

[편집]

고틀로프 프레게가 1879년에 출판된 《개념 표기법》[3]에서 사용한 논리는 (현대적 용어로는) 2차 논리였다.[4]:295[5]:101–102 이후 1885년에 찰스 샌더스 퍼스는 1차 논리와 2차 논리를 구분하였다.[6][4]:296[5]:99 퍼스는 1차 논리를 "1차 내포 논리"(영어: first-intensional logic)로, 2차 논리를 "2차 내포 논리"(영어: second-intensional logic)로 일컬었다.[5]:99–100

이후 에른스트 체르멜로2차 논리를 사용하여 집합론을 개발하였다. 토랄프 스콜렘은 1922년에 체르멜로의 집합론을 1차 논리로 재정의하였다.[7][5]:123–124[8]:153–156[9]:447 이는 오늘날 사용되는 체르멜로-프렝켈 집합론의 기반이 되었다.

제2차 세계 대전 이후 1차 논리는 (2차 논리유형 이론 등을 대신하여) 통상적으로 사용되는 수학의 기반이 되었다.[9]:448

같이 보기

[편집]

각주

[편집]
  1. Hodges, Wilfrid (2001년 8월). 〈Classical logic I: first order logic〉. Goble, Lou. 《The Blackwell Guide to Philosophical Logic》 (영어). Blackwell. ISBN 978-0-631-20693-4. Zbl 1003.03010. 
  2. Lindström, Per (1969년 4월). “On extensions of elementary logic”. 《Theoria》 (영어) 35 (1): 1–11. doi:10.1111/j.1755-2567.1969.tb00356.x. ISSN 0040-5825. 
  3. Frege, Gottlob (1879). 《Begriffsschrift, eine der arithmetischen nachgebildete Formelsprache des reinen Denkens》 (독일어). 할레: Verlag von Louis Nebert. 
  4. Putnam, Hilary (1982). “Peirce the logician”. 《Historia Mathematica》 (영어) 9 (3): 290–301. doi:10.1016/0315-0860(82)90123-9. ISSN 0315-0860. 
  5. Moore, Gregory H. (1988). 〈The emergence of first-order logic〉 (PDF). Aspray, William; Kitcher, Philip. 《History and philosophy of modern mathematics》. Minnesota Studies in the Philosophy of Science (영어) 11. University of Minnesota Press. 95–135쪽. JSTOR 10.5749/j.cttttp0k.7. 
  6. Peirce, Charles Sanders (1885년 1월). “On the algebra of logic: a contribution to the philosophy of notation”. 《American Journal of Mathematics》 (영어) 7 (2): 180–202. doi:10.2307/2369451. ISSN 0002-9327. JFM 17.0044.02. JSTOR 2369451. 
  7. Skolem, Thoralf (1923). 〈Einige Bemerkungen zur axiomatischen Begründung der Mengenlehre〉. 《Matematikerkongressen i Helsingfors den 4–7 Juli 1922, Den femte skandinaviska matematikerkongressen, Redogörelse》 (독일어). 헬싱키: Akademiska Bokhandeln. 217–232쪽. JFM 49.0138.02. 
  8. Eklund, Matti (1996년 12월). “On how logic became first-order” (PDF). 《Nordic Journal of Philosophical Logic》 (영어) 1 (2): 147–167. Zbl 0885.03006. 
  9. Ferreiros, Jose (2001년 12월). “The road to modern logic — an interpretation” (PDF). 《The Bulletin of Symbolic Logic》 (영어) 7 (4): 441–484. doi:10.2307/2687794. ISSN 1079-8986. JSTOR 2687794. Zbl 1005.03003. 2015년 3월 26일에 원본 문서 (PDF)에서 보존된 문서. 2016년 7월 29일에 확인함. 

외부 링크

[편집]