File: ack.at

package info (click to toggle)
mailfromd 9.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 11,512 kB
  • sloc: ansic: 56,882; sh: 22,979; yacc: 4,130; lex: 1,428; makefile: 928; lisp: 488; awk: 393; perl: 319; sed: 25
file content (58 lines) | stat: -rw-r--r-- 1,399 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
# This file is part of Mailfromd testsuite. -*- Autotest -*-
# Copyright (C) 2007-2025 Sergey Poznyakoff
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3, or (at your option)
# any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.

AT_SETUP([Ackerman function])
AT_KEYWORDS([ack])

MFT_RUN(
[/*
  * This test computes the value of Ackerman function ack(3,8), which
  * requires 2785999 calls of ack().  Maximum recursion depth is 2047,
  * which requires 8188 words on stack.  Heap allocation for echo arguments
  * requires extra 7 words. Extra 3 words are required for envfrom arguments.
  */

#pragma stacksize 8198

func ack(number a, number b)
  returns number
do
  if a = 0
    return b+1
  fi
  if b = 0
    return ack(a-1,1)
  fi
  return ack(a-1, ack(a,b-1))
done

func main(...)
  returns number
do
  echo "ack(3,8)=" . ack(3,8)
  return 0
done
],
[],
[0],
[],
[ack(3,8)=2045
])

AT_CLEANUP