source: src/tests/gmp.c@ 6e09f211

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors deferred_resn demangler enum forall-pointer-decay jacob/cs343-translation jenkins-sandbox new-ast new-ast-unique-expr new-env no_list persistent-indexer pthread-emulation qualifiedEnum resolv-new with_gc
Last change on this file since 6e09f211 was a933bcb3, checked in by Peter A. Buhr <pabuhr@…>, 8 years ago

documentation and formatting

  • Property mode set to 100644
File size: 2.2 KB
RevLine 
[4c8f86b3]1//
2// Cforall Version 1.0.0 Copyright (C) 2016 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
7// gmp.c --
8//
9// Author : Peter A. Buhr
10// Created On : Tue Apr 19 08:55:51 2016
11// Last Modified By : Peter A. Buhr
[a933bcb3]12// Last Modified On : Wed May 24 22:05:38 2017
13// Update Count : 540
[4c8f86b3]14//
15
16#include <gmp>
17
[935315d]18int main( void ) {
[4c8f86b3]19 sout | "constructors" | endl;
20 short int si = 3;
21 Int x = { "50000000000000000000" }, y = { si }, z = x + y;
22 sout | x | y | z | endl;
23 sout | "x:" | x | "y:" | y | "z:" | z | endl;
24
25 sout | "conversions" | endl;
26 y = 'a';
27 sout | "y:" | y | endl;
[4adbe45]28 y = "12345678901234567890123456789";
29 sout | "y:" | y | endl;
[4c8f86b3]30 y = si;
31 sout | "y:" | y | endl;
32 y = -3;
33 sout | "y:" | y | endl;
34 y += 7;
35 sout | "y:" | y | endl;
36 y -= 1;
37 sout | "y:" | y | endl;
38 int b;
39 b = y;
40 si = y;
41 sout | "y:" | y | "b:" | b | "si:" | si | endl;
42
43 sout | "comparison" | endl;
44 sout | x == x | endl;
45 sout | x != x | endl;
46 sout | x < x | endl;
47 sout | x <= x | endl;
48 sout | x > x | endl;
49 sout | x >= x | endl;
50
51 sout | "arithmetic" | endl;
52 z = x + y + z;
53 sout | "z:" | z | endl;
54 z = z = x;
55 sout | "z:" | z | endl;
56 z = x - y - z;
57 sout | "z:" | z | endl;
58 z = x * y * z;
59 sout | "z:" | z | endl;
60 z = x * 3;
61 sout | "z:" | z | endl;
62 z = 3 * x;
63 sout | "z:" | z | endl;
64 z = x / 3;
65 sout | "z:" | z | endl;
[4adbe45]66 sout | div( x, 3 ) | x / 3 | "," | x % 3 | endl;
[4c8f86b3]67 [ x, y ] = div( x, 3 );
68 sout | "x:" | x | "y:" | y | endl;
69
70 sout | endl;
71
72 sout | "Fibonacci Numbers" | endl;
73 Int fn, fn1, fn2;
74 fn = (Int){0}; fn1 = fn; // 1st case
75 sout | (int)0 | fn | endl;
[18c55e1]76 fn = 1; fn2 = fn1; fn1 = fn; // 2nd case
[4c8f86b3]77 sout | 1 | fn | endl;
[935315d]78 for ( unsigned int i = 2; i <= 200; i += 1 ) {
[4c8f86b3]79 fn = fn1 + fn2; fn2 = fn1; fn1 = fn; // general case
80 sout | i | fn | endl;
81 } // for
82
83 sout | endl;
84
85 sout | "Factorial Numbers" | endl;
86 Int fact;
[18c55e1]87 fact = 1; // 1st case
[4c8f86b3]88 sout | (int)0 | fact | endl;
[935315d]89 for ( unsigned int i = 1; i <= 40; i += 1 ) {
[a933bcb3]90 fact *= i; // general case
[4c8f86b3]91 sout | i | fact | endl;
92 } // for
93} // main
94
95// Local Variables: //
96// tab-width: 4 //
[a933bcb3]97// compile-command: "cfa gmp.c -l gmp" //
[4c8f86b3]98// End: //
Note: See TracBrowser for help on using the repository browser.