annotate test/suite_floats/mkcase.py @ 0:3e629dc19168

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:24:28 +0100
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
1 #!/usr/bin/python
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
2 #
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
3 # Copyright (c) 2007,2010 Daniel Adler <dadler@uni-goettingen.de>,
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
4 # Tassilo Philipp <tphilipp@potion-studios.com>
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
5 #
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
6 # Permission to use, copy, modify, and distribute this software for any
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
7 # purpose with or without fee is hereby granted, provided that the above
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
8 # copyright notice and this permission notice appear in all copies.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
9 #
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
10 # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
11 # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
12 # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
13 # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
14 # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
15 # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
16 # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
17 #
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
18
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
19 import sys
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
20
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
21 # parameters
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
22
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
23 nargs = 10
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
24
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
25 types = ["DCdouble","DCfloat"]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
26 typeSigs = ["d" ,"f" ]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
27
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
28 # generator
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
29
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
30 ntypes = len(types)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
31
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
32 sys.stderr.write("/* auto generated by mkcase (on stderr) */\n");
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
33 sys.stderr.write("".join(["#define NARGS ",str(nargs),"\n"]))
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
34 sys.stderr.write("".join(["#define NTYPES ",str(ntypes),"\n"]))
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
35
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
36 def powerfact(x, n):
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
37 if n==0:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
38 return 0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
39 else:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
40 return x**n+powerfact(x,n-1)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
41
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
42 x = 0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
43 end = powerfact(ntypes,nargs)+1
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
44
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
45 sys.stdout.write("/* auto generated by mkcase.py (on stdout) */\n");
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
46
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
47 while x < end:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
48 args = [str(x)]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
49 sig = ["f_"]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
50 pos = 0
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
51 y = x
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
52 while y > 0:
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
53 s = (y-1) % ntypes
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
54 y = (y-1) / ntypes
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
55 args += [ types [s] ]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
56 sig += [ typeSigs[s] ]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
57 pos += 1
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
58 sig = "".join(sig)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
59 args += [ sig ]
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
60 args = ",".join(args)
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
61 sys.stdout.write( "".join(["VF",str(pos),"(",args,")\n"]) )
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
62 x += 1
3e629dc19168 initial from svn dyncall-1745
Daniel Adler
parents:
diff changeset
63