FRACTRAN
FRACTRAN은 수학자 존 호턴 콘웨이가 고안한 난해한 프로그래밍 언어이다. FRACTRAN 프로그램은 양의 분수들로 이루어진 하나의 목록의 형태이다. 이 프로그램은 다음의 규칙으로 자연수 입력값 n을 갱신하며 작동한다.
- 목록의 분수들 중에서 nf가 자연수인 가장 첫번째 분수가 f일 때, 입력값 n을 nf로 바꿔쓴다.
- 더 이상 nf가 자연수인 분수 f가 없을때까지 위 과정을 반복한 후, 프로그램을 정지한다.
간단한 FRACTRAN 프로그래밍 예제[편집]
FRACTRAN 프로그램은 괴델 넘버링을 사용해 입력값과 출력값을 하나의 소인수분해로 표현한다. 예를 들어 a=2, b=1, c=1 을 입력하면
와 같은 형태로 표현한다
덧셈 프로그램
a와 b를 입력하면 a+b를 출력하는 프로그램은 다음과 같다
이 프로그램은 다음 알고리즘을 따른다.
상태 행동 2의 지수>0 2의 지수에서 1을빼고
3의 지수에 1을 더한다
2의 지수 = 0 정지
a와 b를 입력하면 다음과 같은 소인수분해 가 입력된다, 이 프로그램은 다음과 같은 수열 , ...을 생성하다가, 결국에 곧, 를 출력한다.
뺄셈 프로그램
a와 b를 입력하면 a-b를 출력하는 프로그램은 다음과 같다.
최댓값 구하기 프로그램
a와 b를 입력하면 a와 b중 더 큰 값을 출력하는 프로그램은 다음과 같다
소수 생성 프로그램
다음은 존 콘웨이가 제시한 소수 생성 프로그램이다.
n=2를 입력하면,이 프로그램은 다음과 같은 수열
을 생성하다가, 2의 소수 거듭제곱을 포함한다.
곱셈 프로그램
두 자연수 a,b를 입력했을 때, ab를 출력하는 프로그램은 다음과 같다.
피보나치 프로그램
피보나치 수열을 생성하는 프로그램은 다음과 같다.
참고 문헌[편집]
- Havil, Julian (2007). 《Nonplussed!》. Princeton University Press. ISBN 0-691-12056-0.
- Conway, John (2010). 〈FRACTRAN: A simple universal programming language for arithmetic〉. Jeffrey C. Lagarias. 《The Ultimate Challenge: the 3x+1 problem》. American Mathematical Society. 249–264쪽. ISBN 978-0-8218-4940-8. Zbl 1216.68068.
- Roberts, Siobhan (2015). 〈Criteria of virtue〉. 《Genius At Play - The Curious Mind of John Horton Conway》. Bloomsbury. 115–119쪽. ISBN 978-1-62040-593-2.
- Conway, John H. (1987). 《Open Problems in Communication and Computation》. Springer-Verlag New York, Inc. ISBN 978-1-4612-9162-6.
외부 링크[편집]
- "Prime Number Pathology: Fractran"
- Weisstein, Eric Wolfgang. “FRACTRAN”. 《Wolfram MathWorld》 (영어). Wolfram Research.
- Prime Number Pathology
- FRACTRAN - (Esolang wiki)
- Ruby implementation and example programs
- Project Euler Problem 308
- "Building Fizzbuzz in Fractran from the Bottom Up"
- Chris Lomont, "A Universal FRACTRAN Interpreter in FRACTRAN"