Home My Page Projects Code Snippets Project Openings diderot
Summary Activity Tracker Tasks SCM

SCM Repository

[diderot] Annotation of /branches/charisee/src/compiler/gen/il/low-il.spec
ViewVC logotype

Annotation of /branches/charisee/src/compiler/gen/il/low-il.spec

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2400 - (view) (download)

1 : jhr 347 # specification of operators for LowIL version of the IR. Each line (other than comments)
2 : jhr 1640 # specifies an operator using five fields, which are separated by ":". The fields are
3 : cchiw 2400 #name
4 :     #argument type(optional)
5 : jhr 1640 # result arity
6 : cchiw 2400 #arity
7 :     #comment(optional)
8 : lamonts 344 #
9 : jhr 2356 # Operations with effects are denoted by a "!" as the first character of the line.
10 :     #
11 : lamonts 344 # type-indexed arithmetic operations
12 : cchiw 2400 IAdd : ty : 1 : 2 :
13 :     ISub : ty : 1 : 2 :
14 :     IMul : ty : 1 : 2 :
15 :     IDiv : ty : 1 : 2 :
16 :     INeg : ty : 1 : 1 :
17 : jhr 1640 Abs : ty : 1 : 1 :
18 :     LT : ty : 1 : 2 :
19 :     LTE : ty : 1 : 2 :
20 :     EQ : ty : 1 : 2 :
21 :     NEQ : ty : 1 : 2 :
22 :     GT : ty : 1 : 2 :
23 :     GTE : ty : 1 : 2 :
24 :     Not : : 1 : 1 : boolean negation
25 :     Max : : 1 : 2 :
26 :     Min : : 1 : 2 :
27 : jhr 1295 # Clamp<ty>(lo, hi, x) -- clamps x to the range lo..hi
28 : jhr 1640 Clamp : ty : 1 : 3 : clamp argument to range
29 : jhr 1116 # Lerp<ty>(a, b, t) -- computes a + t*(b-a)
30 : jhr 1640 Lerp : ty : 1 : 3 : linear interpolation between 0 and 1
31 : jhr 1116 # Norm<ty>(x) -- returns the norm of the tensor x, which has type ty
32 : jhr 1640 Norm : ty : 1 : 1 :
33 : jhr 1116 # Normalize<n>(v) -- returns the unit vector in direction u; n is the length ov u
34 : jhr 1640 Normalize : int : 1 : 1 :
35 :     PrincipleEvec : ty : 1 : 2 : principle eigenvector; ty is result vector type
36 :     EigenVecs2x2 : : 1 : 1 : Eigen vectors and values for 2x2 matrix
37 :     EigenVecs3x3 : : 1 : 1 : Eigen vectors and values for 3x3 matrix
38 :     EigenVals2x2 : : 1 : 1 : Eigen values for 2x2 matrix
39 :     EigenVals3x3 : : 1 : 1 : Eigen values for 3x3 matrix
40 : jhr 1116 # Zero<ty>() -- zero tensor
41 : jhr 1640 Zero : ty : 1 : 0 : identity matrix
42 :     # operations on sequences
43 :     # Select<ty,i>(u) -- select ith element of tuple; ty is tuple type
44 :     Select : ty * int : 1 : 1 :
45 :     # Index<ty,i>(u) -- select ith element of sequence; ty is sequence type
46 :     Index : ty * int : 1 : 1 :
47 :     # Subscript<ty>(u,i) -- select ith element of sequence; ty is type of sequence
48 :     Subscript : ty : 1 : 2 :
49 : cchiw 2400 # MkDynamic<ty,n> -- make a sequence with type ty{n} into a dynamic sequence
50 :     !MkDynamic : ty * int : 1 : 1 : make a fixed-length sequence dynamic
51 :     !Append : ty : 2 : 1 : append an element onto a dynamic sequence
52 :     !Prepend : ty : 2 : 1 : prepend an element onto a dynamic sequence
53 :     !Concat : ty : 2 : 1 : concatenate two dynamic sequences
54 :     # Length<ty> -- return the length of a sequence with type ty{}
55 :     Length : ty : 1 : 1 : return the length of a dynamic sequence
56 : jhr 1640 #
57 : jhr 1116 # compute integral parts of reals
58 : jhr 1640 Ceiling : int : 1 : 1 : compute real ceiling of a vector
59 :     Floor : int : 1 : 1 : compute real floor of a vector
60 :     Round : int : 1 : 1 : compute real rounding to nearest integral real of a vector
61 :     Trunc : int : 1 : 1 : compute real truncation to integral real of a vector
62 : lamonts 344 #
63 : jhr 457 ### conversions; the real to int forms are vector ops
64 : jhr 1640 IntToReal : : 1 : 1 :
65 :     RealToInt : int : 1 : 1 : cast real vector to int vector
66 : lamonts 344 #
67 : jhr 457 ### image/kernel operations
68 : jhr 1116 # ImageAddress<I>(V) -- the base address of an image with info I
69 : jhr 1640 ImageAddress : ImageInfo.info : 1 : 1 : image base address
70 : jhr 1116 # LoadVoxels<I,n>(a) -- load a vector of n voxels from the address a
71 : jhr 1640 LoadVoxels : ImageInfo.info * int : 1 : 1 : load a vector of voxel values from an address
72 : jhr 1116 # PosToImgSpace<I>(V,u) -- transforms the world-space position u into the image-space specified by V.
73 : jhr 1640 PosToImgSpace : ImageInfo.info : 1 : 2 : transform a world-space position to image-space
74 : jhr 1116 # TensorToWorldSpace<I,ty>(V,u) -- transforms the image-space tensor u to from V's image space to world space
75 : jhr 1640 TensorToWorldSpace : ImageInfo.info * ty : 1 : 2 : transform an image-space gradient to world-space
76 : jhr 1116 # Inside<I,s>(u,V) -- tests to see if image-space position u is inside the volume
77 :     # occupied by the image V. I is the image info and s is the border width
78 : jhr 1640 Inside : ImageInfo.info * int : 1 : 2 :
79 : lamonts 344 #
80 : cchiw 2400 # nrrd file loading
81 :     LoadSeq : ty * string : 1 : 0 : load sequence from nrrd file
82 :     LoadImage : ty * string * ImageInfo.info : 1 : 0 : load image from nrrd file
83 :     #
84 : lamonts 344 # inputs
85 : cchiw 2400 Input: input: 0 : 0 : program input
86 : jhr 1640 #
87 :     # printing support for debugging
88 : jhr 2356 !Print : tys : 0 : * : print strings

root@smlnj-gforge.cs.uchicago.edu
ViewVC Help
Powered by ViewVC 1.0.0