h$f'      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                                                                                                                                                                                                ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! " # # # # # # # # # # # # # # # # # # # # # # # # # # # # # $ $ $ $ $ $ $ $ $ % % % % % % % % % % % % % % % % % % % & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) * * * * * * * * * * * * * * * * * * + + + + + + + + + + + + + + + + + + + , , , - - - - - - - - - - - - - - - - - - . . . . . . . . . . . . . . . . . . . . . . . . / / / / / / / / / / / / / / / / / / / / / / / / / 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 444444444444444444444444444444455555555555555555555555555555556667777777778888888888888888888888888888888888888888888889999999999999999999999999999999999999999999:::::::::::::::::::::::::::::::::::::::::::::;;;<<====================================================================>>?????@@@AAAAAAAAAABBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBCCCCDDDDDDDDDDDDDDDDDEEEEEEEFGGGHHHHHHIIIIIIIIIIIIIIIIIIIJJJJJJJKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOPPPPPPQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQRRRRSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSTTTTTTTTTUUVVVVVVVVVVVWXXXXXXXXXYZZZZZZ[[[[[[\\\\]]]]]]]]]^^^_``````````````aaaaaaaaaaaabbbbbbcddddddddddddeeeeeeffgggghhhhhhhiiiiiiiiijjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjkkkllllllllllllllllllmmmmmmmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnnnnnnnooooopppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppqrrrrrrsssssssssssssssssssssssssssssssssssssssssttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttuuuuuuuuuuvvvvvvvvvvvwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwxxxyyyyyyyyyyyyzz{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{|||||||||||}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}~~                                                                                                                                !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""################################################################################################################################$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''Nonekfuthark&Whether an option accepts an argument.futharkThe ' becomes part of the help text.futharkSpecification if a single command line option. The option must have a long name, and may also have a short name.In the action, the option argument (if any) is stored as in the char*-typed variable optarg.futharkGenerate an option parser as a function of the given name, that accepts the given command line options. The result is a function that should be called with argc and argv'. The function returns the number of argv# elements that have been processed.If option parsing fails for any reason, the entire process will terminate with error code 1.  NonelNone wfutharkA mapping from package paths to their chosen revisions. This is the result of the version solver.futharkA structure corresponding to a  futhark.pkg file, including comments. It is an invariant that duplicate required packages do not occcur (the parser will verify this).futharkThe name of the package.futharkAn entry in the required section of a  futhark.pkg file.futharkName of the required package.futharkThe minimum revision.futharkAn optional hash indicating what this revision looked like the last time we saw it. Used for integrity checking.futharkWraps a value with an annotation of preceding line comments. This is important to our goal of being able to programmatically modify the  futhark.pkg$ file while keeping comments intact.futharkA line comment.futharkThe dependencies of a (revision of a) package is a mapping from package paths to minimum versions (and an optional hash pinning).futharkA package path is a unique identifier for a package, for example  github.comuserfoo.futharkTurn a package path (which always uses forward slashes) into a file path in the local file system (which might use different slashes).futharkVersions of the form (0,0,0)-timestamp+hash are treated specially, as a reference to the commit identified uniquely with hash (typically the Git commit ID). This function detects such versions.futharkcommitVersion timestamp commit constructs a commit version.futharkUnfortunately, Data.Versions has a buggy semver parser that collapses consecutive zeroes in the metadata field. So, we define our own parser here. It's a little simpler too, since we don't need full semver.futhark9The name of the file containing the futhark-pkg manifest.futharkPossibly given a package path, construct an otherwise-empty manifest file.futharkPrettyprint a package manifest such that it can be written to a  futhark.pkg file.futhark3The required packages listed in a package manifest.futharkWhere in the corresponding repository archive we can expect to find the package files.futharkAdd new required package to the package manifest. If the package was already present, return the old version.'futharkCheck if the manifest specifies a required package with the given package path.futhark6Remove a required package from the manifest. Returns ' if the package was not found in the manifest, and otherwise the new manifest and the  that was present.futharkParse a text as a . The ' is used for any error messages.futhark%Read contents of file and pass it to .futharkPrettyprint a build list; one package per line and newline-terminated.0uv}|wxy{z~0uv}|wxy{z~ Trustworthy#futhark Encoded form.futharkAs the user typed it.futharkLike , but monadic.futhark chunk n a splits a into n!-size-chunks. If the length of a is not divisible by n', the last chunk will have fewer than n' elements (but it will never be empty).futhark chunks ns a splits a, into chunks determined by the elements of ns. It must hold that sum ns == length a, or the resulting list may contain too few chunks, or not all elements of a.futharkLike '%, but returns zero for an empty list.futhark dropAt i n drops n elements starting at element i.futhark takeLast n l takes the last n elements of l.futhark dropLast n l drops the last n elements of l.futharkA combination of ' and '.futharkReturn the list element at the given index, if the index is valid.futhark3Return the first element of the list, if it exists.futharkLike ', but from the end.futharkLike ', but produces three lists.futharkReturn the list element at the given index, if the index is valid, along with the elements before and after.futhark7The Unix environment when the Futhark compiler started.futharkIs an environment variable set to 0 or 1? If 0, return False; if 1, True; otherwise the default value.futharkAre we running in a terminal capable of fancy commands and visualisation?futharkLike ', but also wraps exceptions when the indicated binary cannot be launched, or some other exception is thrown. Also does shenanigans to handle improperly encoded outputs.futhark7Every non-directory file contained in a directory tree.futhark9Round a single-precision floating point number correctly.futharkRound a single-precision floating point number upwards correctly.futharkRound a single-precision floating point number downwards correctly.futhark9Round a double-precision floating point number correctly.futharkRound a double-precision floating point number upwards correctly.futharkRound a double-precision floating point number downwards correctly.futharkThe system-level lgamma() function.futharkThe system-level  lgammaf() function.futharkThe system-level tgamma() function.futharkThe system-level  tgammaf() function.futhark?futhark*Typeclass for monads that support logging.futharkAdd one log entry.futharkAppend an entire log.futharkTypeclass for things that can be turned into a single-entry log.futhark1An efficiently catenable sequence of log entries.futharkTransform a log into text. Every log entry becomes its own line (or possibly more, in case of multi-line entries). None futharkMonads that support a stateful package registry. These are also required to be instances of ' because most package registry operations involve network operations.futharkA package registry is a mapping from package paths to information about the package. It is unlikely that any given registry is global; rather small registries are constructed on-demand based on the package paths referenced by the user, and may also be combined monoidically. In essence, the PkgRegistry is just a cache.futharkInformation about a package. The name of the package is stored separately.futharkLook up information about a specific commit, or HEAD in case of Nothing.futharkInformation about a version of a single package. The version number is stored separately.futhark1The directory inside the zipball containing the lib directory, in which the package files themselves are stored (Based on the package path).futharkThe commit ID can be used for verification ("freezing"), by storing what it was at the time this version was last selected.futhark8Timestamp for when the revision was made (rarely used).futharkThe manifest is stored as a monadic action, because we want to fetch them on-demand. It would be a waste to fetch it information for every version of every package if we only actually need a small subset of them.'futhark!Download URL via shelling out to curl.'futharkCreate memoisation around a  action to ensure that multiple inspections of the same revisions will not result in potentially expensive network round trips.futharkDownload the zip archive corresponding to a specific package version.futhark6Lookup information about a given version of a package.futharkRetrieve information about a package based on its package path. This uses Semantic Import Versioning when interacting with repositories. For example, a package  github.comuserrepo6 will match version 0.* or 1.* tags only, a package  github.comuserrepo/v2$ will match 2.* tags, and so forth..futhark=Given a package path, look up information about that package.futhark:Look up information about a specific version of a package.futhark%Find the newest version of a package.None ?'futharkA mapping of package revisions to the dependencies of that package. Can be considered a  without the option of obtaining more information from the Internet. Probably useful only for testing the solver.(futharkA rough build list is like a build list, but may contain packages that are not reachable from the root. Also contains the dependencies of each package.(futharkGiven a list of immediate dependency minimum version constraints, find dependency versions that fit, including transitive dependencies.futharkRun the solver, producing both a package registry containing a cache of the lookups performed, as well as a build list.futharkPerform package resolution with only pre-known information. This is useful for testing. Trustworthyc futhark.Prettyprint a value, wrapped to 80 characters.futharkPrettyprint a value to a (, wrapped to 80 characters.futhark2Prettyprint a value without any width restriction.futhark Re-export of (.futhark,Prettyprint a list enclosed in curly braces.futhark The document  ds separates ds1 with commas and encloses them with parentheses.futharkMake sure that the given document is printed on just a single line.futharkLike c, but splits the string into words and permits line breaks between all of them.futharkStack and prepend a list of d s to another d?, separated by a linebreak. If the list is empty, the second d1 will be returned without a preceding linebreak.futharkSurround the given document with enclosers and add linebreaks and indents.futharkPrettyprint on a single line up to at most some appropriate number of characters, with trailing ... if necessary. Used for error messages.(((((  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdlefghikj  !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdlefghikjSafe̳futhark+Conversion operators try to generalise the from t0 x to t1 instructions from LLVM.futharkZero-extend the former integer type to the latter. If the new type is smaller, the result is a truncation.futharkSign-extend the former integer type to the latter. If the new type is smaller, the result is a truncation.futharkConvert value of the former floating-point type to the latter. If the new type is smaller, the result is a truncation.futharkConvert a floating-point value to the nearest unsigned integer (rounding towards zero).futharkConvert a floating-point value to the nearest signed integer (rounding towards zero).futhark6Convert an unsigned integer to a floating-point value.futhark3Convert a signed integer to a floating-point value.futharkConvert an integer to a boolean value. Zero becomes false; anything else is true.futharkConvert a boolean to an integer. True is converted to 1 and False to 0.futharkComparison operators are like s, but they always return a boolean value. The somewhat ugly constructor names are straight out of LLVM.futharkAll types equality.futharkUnsigned less than.futharkUnsigned less than or equal.futharkSigned less than.futharkSigned less than or equal.futharkFloating-point less than.futhark"Floating-point less than or equal.futharkBoolean less than.futharkBoolean less than or equal.futharkBinary operators. These correspond closely to the binary operators in LLVM. Most are parametrised by their expected input and output types.futharkInteger addition.futharkFloating-point addition.futharkInteger subtraction.futharkFloating-point subtraction.futharkInteger multiplication.futharkFloating-point multiplication.futharkUnsigned integer division. Rounds towards negativity infinity. Note: this is different from LLVM.futhark>Unsigned integer division. Rounds towards positive infinity.futharkSigned integer division. Rounds towards negativity infinity. Note: this is different from LLVM.futhark?/futharkA part of an error message.futharkA literal string.futharkA run-time integer value.futharkAn error message is a list of error parts, which are concatenated to form the final message.futharkAn element of a pattern - consisting of a name and an addditional parametric decoration. This decoration is what is expected to contain the type of the resulting variable.futharkThe name being bound.futharkPattern element decoration.futhark A list of s, indicating how an array should be sliced. Whenever a function accepts a , that slice should be total, i.e, cover all dimensions of the array. Deviators should be indicated by taking a list of  es instead.futhark,How to index a single dimension of an array.futharkFix index in this dimension.futhark&DimSlice start_offset num_elems stride.futharkA function or lambda parameter.futharkName of the parameter.futharkFunction parameter decoration.futharkA subexpression is either a scalar constant or a variable. One important property is that evaluation of a subexpression is guaranteed to complete in constant time.futhark:A list of names used for certificates in some expressions.futharkAn identifier consists of its name and the type of the value bound to the identifier.futharkInformation about which parts of a value/type are consumed. For example, we might say that a function taking three arguments of types ([int], *[int], [int]) has diet [Observe, Consume, Observe].futharkConsumes this value.futharkOnly observes value in this position, does not consume. A result may alias this.futharkAs , but the result will not alias, because the parameter does not carry aliases.futharkAn > with uniqueness information, used for function return types.futharkA type with shape and uniqueness information, used declaring return- and parameters types.futharkA type with existentially quantified shapes - used as part of function (and function-like) return types. Generally only makes sense when used in a list.futharkA type with shape information, used for describing the type of variables.futharkA Futhark type is either an array or an element type. When comparing types for equality with (, shapes must match.futharkA fancier name for ()% - encodes no uniqueness information.futhark:A string representing a specific non-default memory space.futhark!The memory space of a block. If , this is the "default" space, whatever that is. The exact meaning of the  depends on the backend used. In GPU kernels, for example, this is used to distinguish between constant, global and shared memory spaces. In GPU-enabled host code, it is used to distinguish between host memory () and GPU space.futharkA special kind of memory that is a statically sized array of some primitive type. Used for private memory on GPUs.futhark>A class encompassing types containing array shape information.futhark0Return the rank of an array with the given size.futharkstripDims n shape strips the outer n dimensions from shape.futhark5Check whether one shape if a subset of another shape.futharkThe size of an array type as merely the number of dimensions, with no further information.futharkLike  but some of its elements may be bound in a local environment instead. These are denoted with integral indices.futharkThe size of this dimension.futhark"Something that may be existential.futharkThe size of an array as a list of subexpressions. If a variable, that variable must be in scope where this array is used.futharkThe size of an array type as a list of its dimension sizes, with the type of sizes being parametric.futharkIf the argument is a , return its component.futharkIf the slice is all s, return the components.futhark3The dimensions of the array produced by this slice.futharkA slice with a stride of one.futharkFix the ?s of a slice. The number of indexes must equal the length of  for the slice.futharkFurther slice the >s of a slice. The number of slices must equal the length of  for the slice.futharkHow many non-constant parts does the error message have, and what is their type?nqrt s Safe-Inferred[futhark$If a Haskell type is an instance of , it means that a value of that type can be converted to a Futhark . This is intended to cut down on boilerplate when writing compiler code - for example, you'll quickly grow tired of writing Constant (LogVal True) loc.futhark Create a   containing the given value.futhark1Utility definition for reasons of type ambiguity.futhark1Utility definition for reasons of type ambiguity. Safe-Inferred>?9futharkSomething with an existential context that can be (partially) fixed.futharkFix the given existentional variable to the indicated free value.futhark/Typeclass for things whose type can be changed.futhark"Typeclass for things that contain s.futhark"Typeclass for things that contain s.futhark"Typeclass for things that contain s.futhark"Typeclass for things that contain s.futhark%Remove shape information from a type.futharkReturn the dimensionality of a type. For non-arrays, this is zero. For a one-dimensional array it is one, for a two-dimensional it is two, and so forth.futhark:Return the shape of a type - for non-arrays, this is the (.(futharkModify the shape of an array - for non-arrays, this does nothing.futharkSet the shape of an array. If the given type is not an array, return the type unchanged.futharkTrue if the given type has a dimension that is existentially sized.futhark Return the uniqueness of a type.futharkunique t is (' if the type of the argument is unique.futharkConvert types with non-existential shapes to types with non-existential shapes. Only the representation is changed, so all the shapes will be .futharkAs , but on a single type.futhark arrayOf t s u constructs an array type. The convenience compared to using the  constructor directly is that t can itself be an array. If t is an n-dimensional array, and s is a list of length n, the resulting type is of an n+m6 dimensions. The uniqueness of the new array will be u, no matter the uniqueness of t. If the shape s has rank 0, then the t will be returned, although if it is an array, with the uniqueness changed to u.futharkConstruct an array whose rows are the given type, and the outer size is the given dimension. This is just a convenient wrapper around .futharkConstruct an array whose rows are the given type, and the outer size is the given -. This is just a convenient wrapper around .futharkSet the dimensions of an array. If the given type is not an array, return the type unchanged.futharkReplace the size of the outermost dimension of an array. If the given type is not an array, it is returned unchanged.futharkReplace the size of the given dimension of an array. If the given type is not an array, it is returned unchanged.futhark2Replace the outermost dimension of an array shape.futhark2Replace the specified dimension of an array shape.futhark peelArray n t4 returns the type resulting from peeling the first n array dimensions from t . Returns Nothing if t has less than n dimensions.futharkstripArray n t removes the n outermost layers of the array. Essentially, it is the type of indexing an array of type t with n indexes.futharkReturn the size of the given dimension. If the dimension does not exist, the zero constant is returned.futharkReturn the dimensions of a type - for non-arrays, this is the empty list.futharkReturn the existential dimensions of a type - for non-arrays, this is the empty list.futharkReturn the size of the given dimension. If the dimension does not exist, the zero constant is returned.futharkReturn the size of the given dimension in the first element of the given type list. If the dimension does not exist, or no types are given, the zero constant is returned.futhark0Return the immediate row-type of an array. For [[int]], this would be [int].futharkA type is a primitive type if it is not an array or memory block.futhark.Returns the bottommost type of an array. For [[int]], this would be int5. If the given type is not an array, it is returned.futhark*Swap the two outer dimensions of the type.futharkRearrange the dimensions of the type. If the length of the permutation does not match the rank of the type, the permutation will be extended with identity.futharkdiet t< returns a description of how a function parameter of type t might consume its argument.futharkx `subtypeOf` y is true if x is a subtype of y (or equal to y ), meaning x is valid whenever y is.futharkxs `subtypesOf` ys is true if xs is the same size as ys, and each element in xs/ is a subtype of the corresponding element in ys..futhark2Add the given uniqueness information to the types.futhark,Remove uniqueness information from the type.futhark5If an existential, then return its existential index.futharkGiven the existential return type of a function, and the shapes of the values returned by the function, return the existential shape context. That is, those sizes that are existential in the return type.futharkThe set of identifiers used for the shape context in the given s.futharkIf all dimensions of the given 9 are statically known, return the corresponding list of .futharkGiven two lists of (s of the same length, return a list of (s that is a subtype of the two operands.futharkGiven a list of s and a list of "forbidden" names, modify the dimensions of the s such that they are  where they were previously 0 with a variable in the set of forbidden names.futhark In the call shapeMapping ts1 ts2 , the lists ts1 and ts must be of equal length and their corresponding elements have the same types modulo exact dimensions (but matching array rank is important). The result is a mapping from named dimensions of ts1. to a set of the corresponding dimensions in ts2% (because they may not fit exactly).This function is useful when ts10 are the value parameters of some function and ts2 are the value arguments, and we need to figure out which shape context to pass.(futharkLike  shapeMapping%, but works with explicit dimensions.futharkLike 4, but produces a mapping for the dimensions context.futhark  IntType Int8futhark  IntType Int16futhark  IntType Int32futhark  IntType Int64futhark FloatType Float32futhark FloatType Float64<< Safe-Inferred>futharkA type representing the return type of a function. In practice, a list of these will be used. It should contain at least the information contained in an 5, but may have more, notably an existential context.futhark-Contruct a return type from a primitive type.futharkGiven a function return type, the parameters of the function, and the arguments for a concrete call, return the instantiated return type for the concrete call, if valid.futharkA type representing the return type of a body. It should contain at least the information contained in a list of 6s, but may have more, notably an existential context.futhark,Construct a body type from a primitive type.futharkGiven shape parameter names and value parameter types, produce the types of arguments accepted. Safe-Inferred? futharkA collection of type families, along with constraints specifying that the types they map to should satisfy some minimal requirements.futhark)Decoration for every let-pattern element.futhark Decoration for every expression.futharkDecoration for every body.futhark5Decoration for every (non-lambda) function parameter.futhark/Decoration for every lambda function parameter.futhark-The return type decoration of function calls.futhark'The return type decoration of branches.futharkExtensible operation.  Trustworthy 2>?0VfutharkAn entire Futhark program.futharkTop-level constants that are computed at program startup, and which are in scope inside all functions.futharkThe functions comprising the program. All funtions are also available in scope in the definitions of the constants, so be careful not to introduce circular dependencies (not currently checked).futharkEvery entry point argument and return value has an annotation indicating how it maps to the original source program type.futhark6Is an unsigned integer or array of unsigned integers.futharkA black box type comprising this many core values. The string is a human-readable description with no other semantics.futharkMaps directly.futharkInformation about the parameters and return value of an entry point. The first element is for parameters, the second for return value.futharkFunction Declarationsfuthark5Contains a value if this function is an entry point.futharkA lambda parameter.futharkA function and loop parameter.futhark#Type alias for namespacing reasons.futhark%Anonymous function for use in a SOAC.futhark#A type alias for namespace control.futharkWhat kind of branch is this? This has no semantic meaning, but provides hints to simplifications.futharkAn ordinary branch.futharkA branch where the "true" case is what we are actually interested in, and the "false" case is only present as a fallback for when the true case cannot be safely evaluated. The compiler is permitted to optimise away the branch if the true case contains only safe statements.futharkBoth of these branches are semantically equivalent, and it is fine to eliminate one if it turns out to have problems (e.g. contain things we cannot generate code for).futharkData associated with a branch.futharkFor-loop or while-loop?futhark'The root Futhark expression type. The  constructor contains a lore-specific operation. Do-loops, branches and function calls are special. Everything else is a simple .futhark#A simple (non-recursive) operation.futhark'loop {a} = {v} (for i < n|while b) do b. The merge parameters are divided into context and value part.futharkA primitive operation that returns something of known size and does not itself contain any bindings.futharkA variable or constant.futharkSemantically and operationally just identity, but is invisible/impenetrable to optimisations (hopefully). This is just a hack to avoid optimisation (so, to work around compiler limitations).futharkArray literals, e.g., [ [1+x, 3], [2, 1+4] ]. Second arg is the element type of the rows of the array. Scalar operationsfutharkUnary operation.futharkBinary operation.futhark+Comparison - result type is always boolean.futharkConversion "casting".futharkTurn a boolean into a certificate, halting the program with the given error message if the boolean is false.futhark5The certificates for bounds-checking are part of the .futharkAn in-place update of the given array at the given position. Consumes the array.futharkconcat!0([1],[2, 3, 4]) = [1, 2, 3, 4]@.futhark:Copy the given array. The result will not alias anything.futharkManifest an array with dimensions represented in the given order. The result will not alias anything.futhark$iota(n, x, s) = [x,x+s,..,x+(n-1)*s].The  indicates the type of the array returned and the offset/stride arguments, but not the length argument.futhark +replicate([3][2],1) = [[1,1], [1,1], [1,1]]futhark>Create array of given type and shape, with undefined elements.futhark71st arg is the new shape, 2nd arg is the input array *)futharkPermute the dimensions of the input array. The list of integers is a list of dimensions (0-indexed), which must be a permutation of [0,n-1], where n1 is the number of dimensions in the input array.futharkRotate the dimensions of the input array. The list of subexpressions specify how much each dimension is rotated. The length of this list must be equal to the rank of the array.futhark A list of -s, indicating the new dimensions of an array.futharkThe new dimension in a -like operation. This allows us to disambiguate "real" reshapes, that change the actual shape of the array, from type coercions that are just present to make the types work out. The two constructors are considered equal for purposes of (.futharkThe new dimension is guaranteed to be numerically equal to the old one.futharkThe new dimension is not necessarily numerically equal to the old one.futhark!Type alias for namespace reasons.futharkA body consists of a number of bindings, terminating in a result (essentially a tuple literal).futhark5The result of a body is a sequence of subexpressions.futharkA sequence of statements.futharkA local variable binding.futharkPattern.futhark Auxiliary information statement.futhark Expression.futhark3Auxilliary Information associated with a statement.futhark#A type alias for namespace control.futhark?A pattern is conceptually just a list of names and their types.futhark-existential context (sizes and memory blocks)futhark "real" valuesfuthark#A type alias for namespace control.futharkEvery statement is associated with a set of attributes, which can have various effects throughout the compiler.futharkA single attribute.futhark Construct  from a single .futhark8Is the given attribute to be found in the attribute set?futharkx  y gives x# except for any attributes also in y.futharkA single statement.futhark1Convert a statement list to a statement sequence.futhark1Convert a statement sequence to a statement list.futhark,The first statement in the sequence, if any.nqrt s Safe-Inferred== futharkThe new dimension.futhark6The new dimensions resulting from a reshape operation.futhark1The new shape resulting from a reshape operation.futhark Construct a " where all dimension changes are s.futhark reshapeOuter newshape n oldshape returns a % expression that replaces the outer n dimensions of oldshape with newshape.futhark reshapeInner newshape n oldshape returns a % expression that replaces the inner m-n dimensions (where m is the rank of oldshape) of src with newshape.futharkIf the shape change is nothing but shape coercions, return the new dimensions. Otherwise, return '.futharkfuseReshape s1 s2 creates a new 2 that is semantically the same as first applying s1 and then s2-. This may take advantage of properties of  versus  to preserve information.futharkGiven concrete information about the shape of the source array, convert some s into s.futhark!reshapeIndex to_dims from_dims is transforms the index list is" (which is into an array of shape  from_dims) into an index list is'", which is into an array of shape to_dims. is must have the same length as  from_dims, and is' will have the same length as to_dims.futharkunflattenIndex dims i: computes a list of indices into an array with dimension dims given the flat index i2. The resulting list will have the same size as dims.futharkflattenIndex dims is computes the flat index of is into an array with dimensions dims. The length of dims and is must be the same.futharkGiven a length n list of dimensions dims, sizeSizes dims will compute a length n+1 list of the size of each possible array slice. The first element of this list will be the product of dims!, and the last element will be 1.   Safe-Inferred?AfutharkThe  of a parameter.futharkThe  of a parameter.futharkAn  corresponding to a parameter.futharkAn $ corresponding to a pattern element.futharkThe type of a name bound by a .futharkSet the lore of a .futharkAll pattern elements in the pattern - context first, then values.futharkReturn a list of the s bound by the .futharkReturn a list of the context s bound by the .futharkReturn a list of the value s bound by the .futharkReturn a list of the s bound by the .futharkReturn a list of the #s bound by the context part of the .futharkReturn a list of the !s bound by the value part of the .futhark1Return a list of the typess bound by the pattern.futharkReturn a list of the typess bound by the value part of the pattern.futhark0Return the number of names bound by the pattern.futharkCreate a pattern using  as the attribute. Safe-Inferred>?C2futhark:The class of lores whose annotations can be prettyprinted.futhark=Class for values that may have some prettyprinted annotation.futharkLike , but produces a d. Trustworthy-2>?Kfuthark4A monad transformer that carries around an extended . Its ( method will first look in the extended , and then use the  method of the underlying monad.futhark4A constraint that indicates two lores have the same  representation.futharkThe class of things that can provide a scope. There is no overarching rule for what this means. For a +, it is the corresponding pattern. For a , is is the parameters.futhark,The class of monads that not only provide a 1, but also the ability to locally extend it. A ( containing a - is the prototypical example of such a monad.futharkRun a computation with an extended type environment. Note that this is intended to *add* to the current type environment, it does not replace it.futharkThe class of applicative functors (or more common in practice: monads) that permit the lookup of variable types. A default method for  exists, which is sufficient (if not always maximally efficient, and using ( to fail) when  is defined.futharkReturn the type of the given variable, or fail if it is not in the type environment.futharkReturn the info of the given variable, or fail if it is not in the type environment.futharkReturn the type environment contained in the applicative functor.futharkReturn the result of applying some function to the type environment.futharkA scope is a mapping from variable names to information about that name.futhark!How some name in scope was bound.futhark"Extend the monadic scope with the  the given value.futharkThe scope of a pattern.futharkThe scope of a pattern element.futhark$The scope of some lambda parameters.futhark.The scope of some function or loop parameters.futharkIf two scopes are really the same, then you can convert one to the other.futhark3Run a computation in the extended type environment.SafeOq futharkExpress a monad expression on a syntax node. Each element of this structure expresses the action to be performed on a given child.futharkExpress a monad mapping operation on a syntax node. Each element of this structure expresses the operation to be performed on a given child.futharkMost bodies are enclosed in a scope, which is passed along for convenience.futhark/A mapper that simply returns the tree verbatim.futharkMap a monadic action across the immediate children of an expression. Importantly, the mapping does not descend recursively into subexpressions. The mapping is done left-to-right.futharkLike  , but in the ( monad.futharkTransform any s in the type.futharkA no-op traversal.futharkAs $, but do not construct a result AST. Safe-Inferred >?Rx futharkAny operation must define an instance of this class, which describes the type of the operation (at the value level). futharkThe type of a subexpression. futharkmapType f arrts* wraps each element in the return type of f in an array with size equal to the outermost dimension of the first element of arrts. futhark"The type of a primitive operation. futharkThe type of an expression. futhark/The number of values returned by an expression.(futhark:Given the context and value merge parameters of a Futhark loop, produce the return type.%   Safe-Inferred>?YJ futharkEither return precomputed free names stored in the attribute, or the freshly computed names. Relies on lazy evaluation to avoid the work. futharkA class indicating that we can obtain free variable information from values of this type. futhark+A computation to build a free variable set. futharkA set of names. Note that the (0 instance is a dummy that treats everything as ( if (, and otherwise (. futharkRetrieve the data structure underlying the names representation. futhark(Does the set of names contain this name? futhark(Construct a name set from a list. Slow. futhark,Turn a name set into a list of names. Slow. futhark(Construct a name set from a single name. futhark"The intersection of two name sets. futharkDo the two name sets intersect? futhark-Subtract the latter name set from the former. futharkMap over the names in a set. futhark-Consider a variable to be bound in the given   computation. futhark"Take note of a variable reference. futhark*Take note of a set of variable references. futharkReturn the set of variable names that are free in the given statements and result. Filters away the names that are bound by the statements. futhark/The free variables of some syntactic construct. futhark1The names bound by the bindings immediately in a . futharkThe names bound by a binding. futhark The names bound by the bindings. futhark?eV futhark:Lores in which all annotations support name substitution. futharkA type that is an instance of this class supports substitution of any names contained within. futharksubstituteNames m e replaces the variable names in e* with new names, based on the mapping in m$. It is assumed that all names in e( are unique, i.e. there is no shadowing. futharkThe substitutions to be made are given by a mapping from names to names.  ! Safe-InferredgW futhark8A heuristic for setting the default value for something. futhark&A size that can be assigned a default. futharkThe value supplies by a heuristic can depend on some device information. This will be translated into a call to clGetDeviceInfo(). Make sure to only request info that can be casted to a scalar type. futhark9The type of OpenCL device that this heuristic applies to. futharkAll of our heuristics.  " Safe-Inferredh futharkGeneralize two  s of the the same type.  # Trustworthyj futhark#Phantom type for number of threads. futhark/Phantom type for the group size of some kernel. futhark5Phantom type for the number of groups of some kernel. futharkA wrapper supporting a phantom type for indicating what we are counting. futharkThe class of some kind of configurable size. Each class may impose constraints on the valid values. futharkLikely not useful on its own, but querying the maximum can be handy. futharkA bespoke size with a default. futharkAn indication of which comparisons have been performed to get to this point, as well as the result of each comparison.  $ Safe-Inferred;m1 futharkA name source is conceptually an infinite sequence of names with no repeating entries. In practice, when asked for a name, the name source will return the name along with a new name source, which should then be used in place of the original.The ( instance is based on how many names have been extracted from the name source. futhark9Produce a fresh name, using the given name as a template. futharkA blank name source. futhark=A new name source that starts counting from the given number.  % Safe-Inferred>q4 futharkA monad that stores a name source. The following is a good instance for a monad in which the only state is a  NameSource vn:  instance MonadFreshNames vn MyMonad where getNameSource = get putNameSource = put futharkRun a computation needing a fresh name source and returning a new one, using   and  # before and after the computation. futhark9Produce a fresh name, using the given name as a template. futharkAs newName, but takes a ' for the name template.(futharkProduce a fresh *, using the given base name as a template. futharkProduce a fresh *, using the given base name as a template. futharkProduce a fresh %, using the given name as a template. futharkProduce a fresh , using the given 1 as a template, but possibly modifying the name. futharkProduce a fresh %, using the given name as a template. & Trustworthy->?y futhark.Lores in which all annotations are renameable. futharkMembers of class   can be uniquely renamed. futharkRename the given value such that it does not contain shadowing, and has incorporated any substitutions present in the   environment. futhark)The monad in which renaming is performed. futharkRename variables such that each is unique. The semantics of the program are unaffected, under the assumption that the program was correct to begin with. In particular, the renaming may make an invalid program valid. futharkRename bound variables such that each is unique. The semantics of the expression is unaffected, under the assumption that the expression was correct to begin with. Any free variables are left untouched. futharkRename bound variables such that each is unique. The semantics of the binding is unaffected, under the assumption that the binding was correct to begin with. Any free variables are left untouched, as are the names in the pattern of the binding. futharkRename bound variables such that each is unique. The semantics of the body is unaffected, under the assumption that the body was correct to begin with. Any free variables are left untouched. futharkRename bound variables such that each is unique. The semantics of the lambda is unaffected, under the assumption that the body was correct to begin with. Any free variables are left untouched. Note in particular that the parameters of the lambda are renamed. futharkProduce an equivalent pattern but with each pattern element given a new name.(futharkProduce a map of the substitutions that should be performed by the renamer. futharkPerform a renaming using the   instance. This only works if the argument does not itself perform any name binding, but it can save on boilerplate for simple types. futharkRename some statements, then execute an action with the name substitutions induced by the statements active. 'Safe  ->? futharkLore-specific attributes; also means the lore supports some basic facilities. futharkGiven a pattern, construct the type of a body that would match it. An implementation for many lores would be  . futharkA type class for operations. futharkLike  , but for arbitrary ops. futhark,Should we try to hoist this out of branches? futharkA handy shorthand for properties that we usually want to things we stuff into ASTs. futharkisBuiltInFunction k is ( if k is an element of  . futhark0A map of all built-in functions and their types. futharkIf the expression is a , return it, otherwise '. futharkAn expression is safe if it is always well-defined (assuming that any required certificates have been checked) in any context. For example, array indexing is not safe, as the index may be out of bounds. On the other hand, adding two numbers cannot fail. futhark"Return the variable names used in * subexpressions. May contain duplicates. futharkIf the  is a  return the variable name. futhark>Return the variable dimension sizes. May contain duplicates. futharkDoes the given lambda represent a known commutative function? Based on pattern matching and checking whether the lambda represents a known arithmetic operator; don't expect anything clever here. futharkHow many value parameters are accepted by this entry point? This is used to determine which of the function parameters correspond to the parameters of the original function (they must all come at the end). futharkA  with empty . futhark-The certificates associated with a statement. futhark Add certificates to a statement. futharkConstruct the type of an expression that would match the pattern. futhark1Keep only those attributes that are relevant for  expressions.  ( Safe-Inferred>? futharkThe class of operations that can be given aliasing information. This is a somewhat subtle concept that is only used in the simplifier and when using "lore adapters". futhark3The op that results when we add aliases to this op. futharkRemove aliases from this op. futharkAdd aliases to this op. futharkThe class of operations that can produce aliasing and consumption information. futhark*Something that contains alias information. futhark"The alias of the argument element. futhark5The class of lores that contain aliasing information. futhark The aliases of the body results. futhark#The variables consumed in the body. futharkThe alises of a subexpression. futharkThe aliases of an expression, one per non-context value returned. futhark)The variables consumed in this statement. futhark*The variables consumed in this expression. futhark&The variables consumed by this lambda. futhark?( futhark$The most commonly used binder monad. futhark;A monad transformer that tracks statements and provides a   instance, assuming that the underlying monad provides a name source. In almost all cases, this is what you will use for constructing statements (possibly as part of a larger monad stack). If you find yourself needing to implement   from scratch, then it is likely that you are making a mistake. futharkA   (and by extension, a  ) is only an instance of   for lores that implement this type class, which contains methods for constructing statements. futharkRun a binder action given an initial scope, returning a value and the statements added ( ) during the action. futharkLike  !, but return only the statements. futharkLike  4, but get the initial scope from the current monad. futharkLike  4, but get the initial scope from the current monad. futharkRun a binder action, returning a value and the statements added ( ) during the action. Assumes that the current monad provides initial scope and name source. futharkLike  , but throw away the result and just return the added statements. futharkRun a binder that produces a , and prefix that < by the statements produced during execution of the action.3 0 Safe-Inferred>? futhark'The aliases of what is returned by the %, and what is consumed inside of it. futhark&Everything consumed in the expression. futhark&The aliases of the let-bound variable. futharkA wrapper around 'AliasDec to get around the fact that we need an () instance, which 'AliasDec does not have. futhark&The lore for the basic representation. futharkEverything consumed in the given statements and result (even transitively).nqrt s  1 Safe-Inferred>?(futharkWisdom about a body. futharkWisdom about an expression. futhark%The wisdom of the let-bound variable.  2 Safe-Inferred? futharkPre-existing aliases for variables. Used to add transitive aliases. futhark,Perform alias analysis on a Futhark program.  3Safe>? futharkInstances of this class can be converted to Futhark expressions within a  . futharkAs   , but an  can be given. futhark Construct an 3 expressions that slices an array with unit stride. futhark.Are these indexes out-of-bounds for the array? futharkWrite to an index of the array, if within bounds. Otherwise, nothing. Produces the updated array. futhark1Construct an unspecified value of the given type. futhark&Sign-extend to the given integer type. futhark&Zero-extend to the given integer type. futharkApply a binary operator to several subexpressions. A left-fold. futharkTrue if all operands are true. futharkCreate a two-parameter lambda whose body applies the given binary operation to its arguments. It is assumed that both argument and result types are the same. (This assumption should be fixed at some point.) futharkAs   , but for s. futhark)Slice a full dimension of the given size. futharkfullSlice t slice returns slice , but with ?s of entire dimensions appended to the full dimensionality of t. This function is used to turn incomplete indexing complete, as required by . futhark sliceAt t n slice returns slice but with s of the outer n dimensions prepended, and as many appended as to make it a full slice. This is a generalisation of  . futharkLike  (, but the dimensions are simply numeric. futharkDoes the slice describe the full size of the array? The most obvious such slice is one that s the full span of every dimension, but also one that fixes all unit dimensions. futhark8Conveniently construct a body that contains no bindings. futharkConveniently construct a body that contains no bindings - but this time, monadically! futharkEvaluate the action, producing a body, then wrap it in all the bindings it created using  . futharkChange that result where evaluation of the body would stop. Also change type annotations at branches. futharkInstantiate all existential parts dimensions of the given type, using a monadic action to create the necessary s. You should call this function within some monad that allows you to collect the actions performed (say, (). futhark!Can be used as the definition of   for a  & instance for simple representations. futharkA convenient composition of   and  . . 4 Trustworthy9>?K futhark,The class of lores that can be type-checked. futhark/Used at top level; can be locally changed with  . futhark$The type checker runs in this monad.(futharkThe environment contains a variable table and a function table. Type checking happens with access to this environment. The function table is only initialised at the very beginning, but the variable table will be extended during type-checking when let-expressions are encountered.(futharkThe ( data structure is used to keep track of which variables have been consumed, as well as whether a violation has been detected.(futharkA tuple of a return type and a list of parameters, possibly named. futhark A type error. futhark6Information about an error during type checking. The (? instance for this type produces a human-readable description. futharkAdd information about what is being type-checked to the current context. Liberal use of this combinator makes it easier to track type errors, as the strings are added to type errors signalled via  .(futharkMark a name as bound. If the name has been bound previously in the program, report a type error.(futharkProclaim that we have made read-only use of the given variable. No-op unless the variable is array-typed. futhark5Proclaim that we have written to the given variables. futharkPermit consumption of only the specified names. If one of these names is consumed, the consumption will be rewritten to be a consumption of the corresponding alias set. Consumption of anything else will result in a type error.(futharkGiven the immediate aliases, compute the full transitive alias set (including the immediate aliases).(futharkcheckAnnotation loc s t1 t2 checks if t2 is equal to t1 . If not, a   is raised. futhark require ts se* causes a '(TypeError vn)' if the type of se* is not a subtype of one of the types in ts. futhark Variant of   working on variable names. futharkType check a program containing arbitrary type information, yielding either a type error or a program with complete type information.futharkRemove all aliases from the (.> >    5 Trustworthy ? futharkA compiler pipeline is conceptually a function from programs to programs, where the actual representation may change. Pipelines can be composed using their ( instance.futhark5Configuration object for running a compiler pipeline.futhark3A compilation always ends with some kind of action.futharkThe main Futhark compiler driver monad - basically some state tracking on top if '.futharkHow much information to print to stderr while the compiler is running.futharkSilence is golden.futhark+Print messages about which pass is running.futhark'Also print logs from individual passes.futharkRun a  action.futhark&Run the pipeline on the given program.futhark1Construct a pipeline from a single compiler pass.futhark(Create a pipeline from a list of passes."6 Safe-Inferred?ԔfutharkPerform the substitution.7 Safe-Inferred@futharkConvert an expression to a  . The provided function is used to convert expressions that are not trivially  s. This includes constants and variable names, which are passed as s.futharkLike  , but for a .futharkConvert s of a given type.futhark5Applying a monadic transformation to the leaves in a  .futharkAs , but in the identity monad.futhark3Substituting names in a PrimExp with other PrimExpsfuthark Convert a  slice to a   slice.futhark Convert a   slice to a  slice. 8 Safe-InferredOfutharkAn index function is a mapping from a multidimensional array index space (the domain) to a one-dimensional memory index space. Essentially, it explains where the element at position [i,j,p] of some array is stored inside the flat one-dimensional array that constitutes its memory. For example, we can use this to distinguish row-major and column-major representations.2An index function is represented as a sequence of (s.futhark8ignoring permutations, is the index function contiguous?(futharkLMAD's representation consists of a general offset and for each dimension a stride, rotate factor, number of elements (or shape), permutation, and monotonicity. Note that the permutation is not strictly necessary in that the permutation can be performed directly on LMAD dimensions, but then it is difficult to extract the permutation back from an LMAD.LMAD algebra is closed under composition w.r.t. operators such as permute, index and slice. However, other operations, such as reshape, cannot always be represented inside the LMAD algebra.It follows that the general representation of an index function is a list of LMADS, in which each following LMAD in the list implicitly corresponds to an irregular reshaping operation.However, we expect that the common case is when the index function is one LMAD -- we call this the "nice" representation.)Finally, the list of LMADs is kept in an IxFun together with the shape of the original array, and a bit to indicate whether the index function is contiguous, i.e., if we instantiate all the points of the current index function, do we get a contiguous memory interval??By definition, the LMAD denotes the set of points (simplified):!{ o + Sigma_{j=0}^{k} ((i_j+r_j) : n_j)*s_j, forall i_j such that 0<=i_jfinally, the underlying memory is contiguous (and monotonous).If any of these conditions do not hold, then the reshape operation will conservatively add a new LMAD to the list, leading to a representation that provides less opportunities for further analysis.futharkReshape an index function.futhark=The number of dimensions in the domain of the input function.(futharkHandle the case where a rebase operation can stay within m + n - 1 LMADs, where m is the number of LMADs in the index function, and n is the number of LMADs in the new base. If both index function have only on LMAD, this means that we stay within the single-LMAD domain.We can often stay in that domain if the original ixfun is essentially a slice, e.g. `x[i, (k1,m,s1), (k2,n,s2)] = orig`.,XXX: TODO: handle repetitions in both lmads.2How to handle repeated dimensions in the original?(a) Shave them off of the last lmad of original (b) Compose the result from (a) with the first lmad of the new base (c) apply a repeat operation on the result of (b).However, I strongly suspect that for in-place update what we need is actually the INVERSE of the rebase function, i.e., given an index function new-base and another one orig, compute the index function ixfun0 such that:new-base == rebase ixfun0 ixfun, or equivalently: new-base == ixfun o ixfun0because then I can go bottom up and compose with ixfun0 all the index functions corresponding to the memory block associated with ixfun.futhark.Rebase an index function on top of a new base.futharkIf the memory support of the index function is contiguous and row-major (i.e., no transpositions, repetitions, rotates, etc.), then this should return the offset from which the memory-support of this index function starts.futharkSimilar restrictions to linearWithOffset except for transpositions, which are returned together with the offset.futhark2Is this a row-major array starting at offset zero?(futhark8Generalised iota with user-specified offset and strides.(futhark(Check monotonicity of an index function.futhark!Generalization (anti-unification)Anti-unification of two index functions is supported under the following conditions: 0. Both index functions are represented by ONE lmad (assumed common case!) 1. The support array of the two indexfuns have the same dimensionality (we can relax this condition if we use a 1D support, as we probably should!) 2. The contiguous property and the per-dimension monotonicity are the same (otherwise we might loose important information; this can be relaxed!) 3. Most importantly, both index functions correspond to the same permutation (since the permutation is represented by INTs, this restriction cannot be relaxed, unless we move to a gated-LMAD representation!)futharkWhen comparing index functions as part of the type check in KernelsMem, we may run into problems caused by the simplifier. As index functions can be generalized over if-then-else expressions, the simplifier might hoist some of the code from inside the if-then-else (computing the offset of an array, for instance), but now the type checker cannot verify that the generalized index function is valid, because some of the existentials are computed somewhere else. To Work around this, we've had to relax the KernelsMem type-checker a bit, specifically, we've introduced this function to verify whether two index functions are "close enough" that we can assume that they match. We use this instead of `ixfun1 == ixfun2` and hope that it's good enough.9 Safe-Inferred-?(futhark#Index a delayed array, if possible.(futhark#Index a delayed array, if possible.(futharkTrue if consumed.futharkTrue if this name has been used as an array size, implying that it is non-negative.(futhark%Indexing a delayed array if possible.futhark'The result of indexing a delayed array.futharkA PrimExp based on the indexes (that is, without accessing any actual array).futharkThe indexing corresponds to another (perhaps more advantageous) array.futhark?Which names are available just before the most enclosing loop?futhark/We are in a situation where we should simplifyhoistun-existentialise memory as much as possible - typically, inside a kernel.futhark,If the given variable name is the name of a 0 parameter, then return the bound of that loop.futhark!In symbol table and not consumed.(futhark>Hide definitions of those entries that satisfy some predicate.futharkHide these definitions, if they are protected by certificates in the set of names.&&: Trustworthy?=futhark2A collection of both top-down and bottom-up rules.(futhark A collection of bottom-up rules.(futharkA collection of top-down rules.futharkContext for a rule applied during bottom-up traversal of the program. Takes a symbol table and usage table as arguments.futharkContext for a rule applied during top-down traversal of the program. Takes a symbol table as argument.(futharkA collection of rules grouped by which forms of statements they may apply to.futharkA simplification rule takes some argument and a statement, and tries to simplify the statement.futharkAn efficient way of encoding whether a simplification rule should even be attempted.futharkGive it a shot.futhark Don't bother.futhark6The monad in which simplification rules are evaluated.(futhark Execute a  action. If succesful, returns the result and a list of new bindings.futhark1Construct a rule book from a collection of rules.futharksimplifyStm lookup bnd) performs simplification of the binding bnd. If simplification is possible, a replacement list of bindings is returned, that bind at least the same names as the original binding (and possibly more, for intermediate results).futharksimplifyStm uses bnd) performs simplification of the binding bnd. If simplification is possible, a replacement list of bindings is returned, that bind at least the same names as the original binding (and possibly more, for intermediate results). The first argument is the set of names used after this binding."";Safe?kfuthark?A function that, given a variable name, returns its definition.futhark+foldClosedForm look foldfun accargs arrargs, determines whether each of the results of foldfun# can be expressed in a closed form.futhark+loopClosedForm pat respat merge bound bodys determines whether the do-loop can be expressed in a closed form.(futhark Lambda-bound<Safe?(futharkA simple rule is a top-down rule that can be expressed as a pure function.(futhark9A function that, given a subexpression, returns its type.futharkA set of standard simplification rules. These assume pure functional semantics, and so probably should not be applied after memory block merging.futharkTurn copy(x) into x iff x? is not used after this copy statement and it can be consumed.>This simplistic rule is only valid before we introduce memory.(futharkMove out results of a conditional expression whose computation is either invariant to the branches (only done for results in the context), or the same in both branches.(futharkIf we are copying a scratch array (possibly indirectly), just turn it into a scratch by itself.(futharkRemove the return values of a branch, that are not actually used after a branch. Standard dead code removal can remove the branch if *none* of the return values are used, but this rule is more precise.=None->?  futharkMake a hoisted Op safe. The SubExp is a boolean that is true when the value of the statement will actually be used.futhark+Blocker for hoisting out of parallel loops.futhark-Blocker for hoisting out of sequential loops.futhark%Blocker for hoisting out of branches.(futharkMark that we have changed something and it would be a good idea to re-run the simplifier.(futharkWe are willing to hoist potentially unsafe statements out of branches, but they most be protected by adding a branch on top of them. (This means such hoisting is not worth it unless they are in turn hoisted out of a loop somewhere.)(futharkWe are willing to hoist potentially unsafe statements out of loops, but they most be protected by adding a branch on top of them.(futharkStatements that are not worth hoisting out of loops, because they are unsafe, and added safety (by (%) may inhibit further optimisation..futharkSimplify a single body. The [Diet] only covers the value elements, because the context cannot be consumed.(futharkSimplify a single . The [Diet] only covers the value elements, because the context cannot be consumed.(futharkBranch condition.futhark1Which side of the branch are we protecting here? />None? futhark Simplify a  $, including copy propagation. If a   refers to a name that is a , the node turns into a  .futharkLike , but where leaves may be s.?None-?qfutharkSimplify the given program. Even if the output differs from the output, meaningful simplification may not have taken place - the order of bindings may simply have been rearranged.futhark.Run a simplification operation to convergence.futharkSimplify the given function. Even if the output differs from the output, meaningful simplification may not have taken place - the order of bindings may simply have been rearranged. Runs in a loop until convergence.futharkSimplify just a single .futharkSimplify a sequence of s.@None-?futhark*Run copy propagation on an entire program.futhark(Run copy propagation on some statements.futhark#Run copy propagation on a function.ANone>futhark,The phantom type for the Seq representation.futharkSimplify a sequential program.nqrt s B Safe-Inferred  ->?$%futharkLike , but just for s.futhark)How to compute a single reduction result.futhark$How to compute a single scan result.futharkThe essential parts of a 4 factored out (everything except the input arrays).futharkWhat kind of stream is this?futharkIs the stream chunk required to correspond to a contiguous subsequence of the original input ( ) or not?  streams can be more efficient, but not all algorithms work with this.futhark/Information about computing a single histogram.futhark Race factor RF means that only 1/RF bins are used.futhark'A second-order array combinator (SOAC).futhark Scatter  cs  length  lambda originalindex and value arrays length is the length of each index array and value array, since they all must be the same length for any fusion to make sense. If you have a list of index-value array pairs of different sizes, you need to use multiple writes instead.2The lambda body returns the output in this manner: >index_0, index_1, ..., index_n, value_0, value_1, ..., value_nThis must be consistent along all Scatter-related optimisations.futhark Hist  length  dest-arrays-and-ops  bucketfun inputarraysThe first SubExp is the length of the input arrays. The first list describes the operations to perform. The : is the bucket function. Finally comes the input images.futhark7A combination of scan, reduction, and map. The first ! is the size of the input arrays.futhark1How many reduction results are produced by these s?futhark5Combine multiple scan operators to a single operator.futhark1How many reduction results are produced by these s?futhark:Combine multiple reduction operators to a single operator.futharkThe types produced by a single %, given the size of the input array.futharkConstruct a lambda that takes parameters of the given types and simply returns them unchanged.futhark'Is the given lambda an identity lambda?futhark3A lambda with no parameters that returns no values.futharkConstruct a Screma with possibly multiple scans, and the given map function.futharkConstruct a Screma with possibly multiple reductions, and the given map function.futharkConstruct a Screma with possibly multiple scans, and identity map function.futharkConstruct a Screma with possibly multiple reductions, and identity map function.futhark*Construct a Screma corresponding to a map.futhark6Does this Screma correspond to a scan-map composition?futhark)Does this Screma correspond to pure scan?futhark8Does this Screma correspond to a reduce-map composition?futhark-Does this Screma correspond to a pure reduce?futharkDoes this Screma correspond to a simple map, without any reduction or scan results?futhark/A mapper that simply returns the SOAC verbatim.futharkMap a monadic action across the immediate children of a SOAC. The mapping does not descend recursively into subexpressions and is done left-to-right.futharkThe type of a SOAC.futharkType-check a SOAC.futhark2Get Stream's accumulators as a sub-expression listfutharkPrettyprint the given Screma.futhark*Prettyprint the given histogram operation.;;C Safe-Inferred?)futharkTurns a binding of a redomap into two seperate bindings, a map binding and a reduce" binding (returned in that order).$Reuses the original pattern for the reduce&, and creates a new pattern with new s for the result of the map.%Only handles a pattern with an empty .futharkTurn a Screma into a Scanomap (possibly with mapout parts) and a Redomap. This is used to handle Scremas that are so complicated that we cannot directly generate efficient parallel code for them. In essense, what happens is the opposite of horisontal fusion.futharkTurn a stream SOAC into statements that apply the stream lambda to the entire input.futharkSplit the parameters of a stream reduction lambda into the chunk size parameter, the accumulator parameters, and the input chunk parameters. The integer argument is how many accumulators are used. DSafe>,[futhark&The lore for the basic representation.nqrt s nqrt sE Safe-Inferred-?7tfutharkThe constraints that a monad must uphold in order to be used for first-order transformation.futharkThe constraints that must hold for a lore in order to be the target of first-order transformation.futharkFirst-order-transform a single function, with the given scope provided by top-level constants.futhark0First-order-transform these top-level constants.futharkFirst transform any nested  or  elements, then apply  if the expression is a SOAC.futharkTransform a single  into a do-loop. The body of the lambda is untouched, and may or may not contain further s depending on the given lore.futhark+Recursively first-order-transform a lambda.FNone?7futhark$The first-order transformation pass.G Safe-Inferred?9Mfuthark1Interchange Scan With Inner Map. Tries to turn a  scan(map) into a @map(scan)futhark3Interchange Reduce With Inner Map. Tries to turn a  reduce(map) into a @map(reduce)futharkDoes this reduce operator contain an inner map, and if so, what does that map look like? Trustworthy  ><5futharkA mapping from external variable names to the corresponding internalised subexpressions.futharkExtra parameters to pass when calling this function. This corresponds to the closure of a locally defined function.futhark;Add a function definition to the program being constructed.futhark Construct an  statement, but taking attributes into account. Always use this function, and never construct  directly in the internaliser!(futharkExecute the given action if / is true, otherwise just return an empty list.(futharkExecute the given action if / is true, otherwise just return an empty list.m mH Safe-Inferred??futharkReshape the arguments to a function so that they fit the expected shape declarations. Not used to change rank of arguments. Assumes everything is otherwise type-correct.INone >?C(futharkNever constructed.futharkDoes this lore contain  s in its s? A lore must be an instance of this class for the simplification rules to work.futharkRemove all arguments to the map that are simply replicates. These can be turned into free variables instead.(futharkLike  , but for .(futhark0Remove inputs that are not used inside the SOAC.(futharkSome of the results of a reduction (or really: Redomap) may be dead. We remove them here. The trick is that we need to look at the data dependencies to see that the "dead" result is not actually used for computing one of the live ones.(futharkIf we are writing to an array that is never used, get rid of it.J Safe-Inferred FwfutharkThe call graph is a mapping from a function name, i.e., the caller, to a set of the names of functions called *directly* (not transitively!) by the function.>We keep track separately of the functions called by constants.futhark.Is the given function known to the call graph?futhark(Does the first function call the second?futhark/Is the function called in any of the constants?futhark&All functions called by this function.futharkbuildCallGraph prog build the program's call graph.(futharkbuildCallGraph ftable fg fname updates fg% with the contributions of function fname.futharkThe set of all functions that are called noinline somewhere, or have a noinline attribute on their definition.KNone  ->?Q8futharkThe memory return of a function, which must always indicate where returned arrays are located.futharkThe return of a body, which must always indicate where returned arrays are located.futharkThe memory return of an expression. An array is annotated with Maybe MemReturn, which can be interpreted as the expression either dictating exactly where the array is located when it is returned (if (8), or able to put it whereever the binding prefers (if ').This is necessary to capture the difference between an expression that is just an array-typed variable, in which the array being "returned" is located where it already is, and a copy expression, whose entire purpose is to store an existing array in some arbitrary location. This is a consequence of the design decision never to have implicit memory copies.futharkA description of the memory properties of an array being returned by an operation.futharkThe array is located in a memory block that is already in scope.futhark8The operation returns a new (existential) memory block.futhark?Memory information for an array bound somewhere in the program.futhark7Located in this memory block with this index function.futharkA summary of the memory information for every let-bound identifier, function parameter, and return value. Parameterisered over uniqueness, dimension, and auxiliary array information.futharkA primitive value.futharkA memory block.futharkThe array is stored in the named memory block, and with the given index function. The index function maps indices in the array to element offset, not byte offsets! To translate to byte offsets, multiply the offset with the size of the array element type.futhark9An index function that may contain existential variables.futhark>The index function representation used for memory annotations.futharkAllocate a memory block. This really should not be an expression, but what are you gonna do...futhark-The class of ops that have memory allocation.(futhark/Helper function for index function unification.0The first return value maps a VName (wrapped in ) to its Int (wrapped in ). In case of duplicates, it is mapped to the *first* Int that occurs.5The second return value maps each Int (wrapped in an ) to a   : with the Int at which its associated VName first occurs.futharkThe return information of an expression. This can be seen as the "return type with memory annotations" of the expression.nqrt s ,LNone-9>?Z (futhark1Monad for adding allocations to a single pattern.futhark2Monad for adding allocations to an entire program.futharkAggressively try to reuse memory in do-loops - should be True inside kernels, False outside.futharkWhen allocating memory, put it in this memory space. This is primarily used to ensure that group-wide statements store their results in local memory.futharkThe set of names that are known to be constants at kernel compile time.(futharkA mapping from chunk names to their maximum size. XXX FIXME HACK: This is part of a hack to add loop-invariant allocations to reduce kernels, because memory expansion does not use range analysis yet (it should).futharkThe subexpression giving the number of elements we should allocate space for. See ( comment.futhark;Get those names that are known to be constants at run-time.futhark.Allocate memory for a value of the given type.(((((((((((((()'))))))))))))))))))))))))))))))))))))))))))))()))) MNone  -2>?ns%futharkDoes this lore contain  s in its s? A lore must be an instance of this class for the simplification rules to work.futharkLike , but just for s.futharkA  is semantically a perfectly nested stack of maps, on top of some bottommost computation (scalar computation, reduction, scan, or histogram). The % encodes the original map structure.All s are parameterised by the representation of their body, as well as a *level*. The *level* is a representation-specific bit of information. For example, in GPU backends, it is used to indicate whether the < is expected to run at the thread-level or the group-level.futharkThe KernelSpace must always have at least two dimensions, implying that the result of a SegRed is always an array.futharkIndex space of a .futharkFlat physical index corresponding to the dimensions (at code generation used for a thread ID or similar).futharkDo we need group-virtualisation when generating code for the segmented operation? In most cases, we do, but for some simple kernels, we compute the full number of groups in advance, and then virtualisation is an unnecessary (but generally very small) overhead. This only really matters for fairly trivial but very wide map kernels where each thread performs constant-time work on scalars.futharkNot only do we not need virtualisation, but we _guarantee_ that all physical threads participate in the work. This can save some checks in code generation.futharkA  does not return an ordinary (. Instead, it returns a list of these.futharkEach "worker" in the kernel returns this. Whether this is a result-per-thread or a result-per-group depends on where the  occurs.futhark8Metadata about whether there is a subtle point to this . This is used to protect things like tiling, which might otherwise be removed by the simplifier because they're semantically redundant. This has no semantic effect and can be ignored at code generation.futharkDon't simplify this one!futharkGo nuts.futharkThe results produced are only used within the same physical thread later on, and can thus be kept in registers.futharkThe body of a .futharkAn operator for  and .futharkIn case this operator is semantically a vectorised operator (corresponding to a perfect map nest in the SOACS representation), these are the logical "dimensions". This is used to generate more efficient code.futharkAn operator for .futharkIn case this operator is semantically a vectorised operator (corresponding to a perfect map nest in the SOACS representation), these are the logical "dimensions". This is used to generate more efficient code.futhark"How an array is split into chunks.futhark&The type of a histogram produced by a /. This can be different from the type of the 5s in case we are dealing with a segmented histogram.futhark1How many reduction results are produced by these s?futharkSplit some list into chunks equal to the number of values returned by each futhark Get the root  corresponding values for a .futharkPerform alias analysis on a .futhark*The variables consumed in the kernel body.futhark(The sizes spanned by the indexes of the .futharkA < containing all the identifiers brought into scope by this .futharkThe level of a .futharkThe space of a .)futharkThe return type of a .futhark Type check a  , given a checker for its level.futhark!A mapper that simply returns the  verbatim.futharkApply a  to the given .futharkSimplify the given .futhark%Simplification rules for simplifying s.futharkLike )!, but for memory representations.NNone-?p,futhark?ua )futhark"Description of distribution to do.)futhark*Also related to avoiding identity mapping.futharkNote: first element is *outermost* nesting. This is different from the similar types elsewhere!futharkFirst pair element is the very innermost ("current") target. In the list, the outermost target comes first. Invariant: Every element of a pattern must be present as the result of the immediately enclosing target. This is ensured by & by removing unused pattern elements.)futharkFirst pair element is the very innermost ("current") nest. In the list, the outermost nest comes first.)futharkBoth parameters and let-bound.futhark&Retrieve the innermost kernel nesting.futharkAdd new outermost nesting, pushing the current outermost to the list, also taking care to swap patterns if necessary.futharkAdd new innermost nesting, pushing the current outermost to the list. It is important that the  has the right order (non-permuted compared to what is expected by the outer nests).futharkFlatten a kernel nesting to: The index space.:The kernel inputs - note that some of these may be unused.((PNone?wfutharkAn encoding of a sequential do-loop with no existential context, alongside its result pattern.futharkGiven a (parallel) map nesting and an inner sequential loop, move the maps inside the sequential loop. The result is several statements - one of these will be the loop, which will then contain statements with map expressions.QNone >?w  RNone ->?zfutharkSome constraints that must hold for the simplification rules to work.)futharkIf a branch is returning some existential memory, but the size of the array is not existential, and the index function of the array does not refer to any names in the pattern, then we can create a block of the proper size and always return there.)futharkIf we are copying something that is itself a copy, just copy the original one instead.)futharkIf the destination of a copy is the same as the source, just remove it.SNone ->?) futhark=A host-level operation; parameterised by what else it can do.futharkA segmented operation.futhark)A simple size-level query or computation.futhark!SplitSpace o w i elems_per_thread.Computes how to divide array elements to threads in a kernel. Returns the number of elements in the chunk that the current thread should take.w5 is the length of the outer dimension in the array. i: is the current thread index. Each thread takes at most elems_per_thread elements. If the order o is , thread with index i should receive elements i*elems_per_tread, i*elems_per_thread + 1, ..., i*elems_per_thread + (elems_per_thread-1). If the order o is  stride$, the thread will receive elements =i, i+stride, i+2*stride, ..., i+(elems_per_thread-1)*stride.futhark'Produce some runtime-configurable size.futharkThe maximum size of some class.futhark:Compare size (likely a threshold) with some integer value.futhark)CalcNumGroups w max_num_groups group_size calculates the number of GPU workgroups to use for an input of the given size. The Name is a size name. Note that w% is an i64 to avoid overflow issues.futharkAt which level the *body* of a  executes. TNone>??futharkThe operations that permit CSE.)futhark*Perform CSE within any nested expressions.futhark+Perform CSE on every function in a program.futhark!Perform CSE on a single function.futharkPerform CSE on some statements.UNone ?k)futhark"inlineInFunDef constf fdmap caller inlines in calleer the functions in fdmap that are called as constf/. At this point the preconditions are that if fdmap8 is not empty, and, more importantly, the functions in fdmap" do not call any other functions.futhark=Inline all functions and remove the resulting dead functions.futharkremoveDeadFunctions prog removes the functions that are unreachable from the main function from the program.VNone ->?nqrt s WNone>?XNone>?futhark5The phantom data type for the kernels representation.nqrt s 5YNone? )futharkMap from variable names to defining expression. We use this to hackily determine whether something is transposed or otherwise funky in memory (and we'd prefer it not to be). If we cannot find it in the map, we just assume it's all good. HACK and FIXME, I suppose. We really should do this at the memory level.futharkThe pass definition.ZNone-?5[None-?)futharkInt64)futharkInt32)futharkGiven a chunked fold lambda that takes its initial accumulator value as parameters, bind those parameters to the neutral element instead.futharkLike , but cap the thread count to the input size. This is more efficient for small kernels, e.g. summing a small array.\None >?futharkConvert the statements inside a map nest to kernel statements, attempting to parallelise any remaining (top-level) parallel statements. Anything that is not a map, scan or reduction will simply be sequentialised. This includes sequential loops that contain maps, scans or reduction. In the future, we could probably do something more clever. Make sure that the amount of parallelism to be exploited does not exceed the group size. Further, as a hack we also consider the size of all intermediate arrays as "parallelism to be exploited" to avoid exploding local memory.We distinguish between "minimum group size" and "maximum exploitable parallelism".]None >?futharkTransform a program using SOACs to a program using explicit kernels, using the kernel extraction transformation.)futharkIntra-group parallelism is worthwhile if the lambda contains more than one instance of non-map nested parallelism, or any nested parallelism inside a loop.)futharkA lambda is worth sequentialising if it contains enough nested parallelism of an interesting kind.^None?)futharkThe variance table keeps a mapping from a variable name (something produced by a ) to the kernel thread indices that name depends on. If a variable is not present in this table, that means it is bound outside the kernel (and so can be considered invariant to all dimensions).)futharkInformation about a loop that has been tiled inside a kernel, as well as the kinds of changes that we would then like to perform on the kernel.)futharkStatements that we insert directly into every thread-private SegMaps. This is for things that cannot efficiently be computed once in advance in the prelude SegMap, primarily (exclusively?) array slicing operations.futharkThe pass definition.)futharkMove statements from prelude to postlude if they are not used in the tiled statement anyway.)futharkPartition prelude statements preceding a tiled loop (or something containing a tiled loop) into three categories:1) Group-level statements that are invariant to the threads in the group.2) Thread-variant statements that should be computed once with a segmap_thread_scalar.3) Thread-variant statements that should be recomputed whenever they are needed.The third category duplicates computation, so we only want to do it when absolutely necessary. Currently, this is necessary for results that are views of an array (slicing, rotate, etc), because these cannot be efficiently represented by a scalar segmap (they'll be manifested in memory)._None?)futharkGiven a statement, compute how often each of its free variables are used. Not accurate: what we care about are only 1, and greater than 1.futharkThe pass definition.`None?futharkName of result.futharkType of result.  aNone ->?/futhark>Apply the in-place lowering optimisation to the given program.futhark>Apply the in-place lowering optimisation to the given program.)futhark>Apply the in-place lowering optimisation to the given program.bNone ->?ccNone?futharkThe pass definition.dNone ->?nqrt s eNone?fNone>?XgNone>?futharkThe pass from  to .futhark Convert some  stms to .hNone?)futhark:A map from memory block names to new index function bases.)futharkA description of allocations that have been extracted, and how much memory (and which space) is needed.futhark%The memory expansion pass definition.iNone ->?=)futharkThe booleans indicate whether we should also play with the initial merge values.)futharkFirst name is the memory block to copy to, second is the name of the array copy.futhark%The double buffering pass definition.j Safe-Inferred>+futhark8The reason why some expression cannot be converted to a  value.futhark,The expression is not a (tuple-)SOAC at all.futhark/A definite representation of a SOAC expression.futharkOne array input to a SOAC - a SOAC may have multiple inputs, but all are of this form. Only the array inputs are expressed with this type; other arguments, such as initial accumulator values, are plain expressions. The transforms are done left-to-right, that is, the first element of the  list is applied first.futhark0A view of the last transformation to be applied.futhark1A view of the first transformation to be applied.futhark:A sequence of array transformations, heavily inspired by Data.Seq. You can decompose it using  and , and grow it by using  and . These correspond closely to the similar operations for sequences, except that appending will try to normalise and simplify the transformation sequence.The data type is opaque in order to enforce normalisation invariants. Basically, when you grow the sequence, the implementation will try to coalesce neighboring permutations, for example by composing permutations and removing identity transformations.futharkA single, simple transformation. If you want several, don't just create a list, use  instead.futhark*A permutation of an otherwise valid input.futhark(A reshaping of an otherwise valid input.futhark#A reshaping of the outer dimension.futhark2A reshaping of everything but the outer dimension.futhark2Replicate the rows of the array a number of times.futharkThe empty transformation list.futhark#Is it an empty transformation list?futhark7Decompose the input-end of the transformation sequence.futhark8Decompose the output-end of the transformation sequence.futhark6Add a transform to the end of the transformation list.futhark9futhark"Phantom type for a count of bytes.futhark%Phantom type for a count of elements.futharkA function call argument.futharkA side-effect free expression whose execution will produce a single primitive value.futharkThe leaves of an .futhark/A scalar variable. The type is stored in the   constructor itself.futharkThe size of a primitive type.futharkReading a value from memory. The arguments have the same meaning as with .futharkThe volatility of a memory access or variable. Feel free to ignore this for backends where it makes no sense (anything but C and similar low-level things)futhark1A block of imperative code. Parameterised by an , which allows extensibility. Concrete uses of this type will instantiate the type parameter with e.g. a construct for launching GPU kernels.futharkNo-op. Crucial for the ( instance.futhark(Statement composition. Crucial for the ) instance.futharkA for-loop iterating the given number of times. The loop parameter starts counting from zero and will have the given type. The bound is evaluated just once, before the loop is entered.futharkWhile loop. The conditional is (of course) re-evaluated before every iteration of the loop.futharkDeclare a memory block variable that will point to memory in the given memory space. Note that this is distinct from allocation. The memory block must be the target of either an  or a / before it can be used for reading or writing.futhark$futharkThe result of compilation to C is four parts, which can be put together in various ways. The obvious way is to concatenate all of them, which yields a CLI program. Another is to compile the library part by itself, and use the header file to call into it.futharkUtility definitions that must be visible to both CLI and library parts.)futharkMapping memory blocks to sizes. These memory blocks are CPU memory that we know are used in particularly simple ways (no reference counting necessary). To cut down on allocator pressure, we keep these allocations around for a long time, and record their sizes so we can reuse them if possible (and realloc() when needed).futharkConstruct the Python array being returned from an entry point.futhark;Create a static array of values - initialised at load time.futhark&Copy from one memory block to another.futharkAllocate a memory block of the given size in the given memory space, saving a reference in the given variable name.futharkRead a scalar from the given memory block with the given index and in the given memory space.futharkWrite a scalar to the given memory block with the given index and in the given memory space.futharkA substitute expression compiler, tried before the main compilation function.futharkA set of operations that fail for every operation involving non-default memory spaces. Uses plain pointers and malloc for memory management.futhark7A constructor that takes no arguments and does nothing.futharkA  where the function is a variable and every argument is a simple .futhark#The ctypes type corresponding to a .futhark#The ctypes type corresponding to a , taking sign into account.futhark"The Numpy type corresponding to a .futhark"The Numpy type corresponding to a , taking sign into account.futharkTell me how to compile a v, and I'll Compile any  PrimExp v for you.44~None 5futharkrtspython opencl.py embedded as a string.futhark*Python code (as a string) that calls the initiatialize_opencl_object5 procedure. Should be put in the class constructor. Trustworthy 5futharkPrelude embedded as ( values, one for every file.Safe2>?YfutharkThe program described by a single Futhark file. May depend on other files.futharkA top-level binding.futharkA module parameter.futharkA module binding.futharkModule expression.futhark)The contents of another file as a module.futharkFunctor application.futharkModule type binding.futharkA type refinement.futharkA module type expression.futhark'A spec is a component of a module type.futharkAbstract type.futharkA type parameter.futhark%A type parameter that must be a size.futhark%A type parameter that must be a type.futhark,The liftedness of a type parameter. By the Ord instance, Unlifted < SizeLifted < Lifted.futharkMay only be instantiated with a zero-order type of (possibly symbolically) known size.futharkMay only be instantiated with a zero-order type, but the size can be varying.futhark+May be instantiated with a functional type.futharkType DeclarationsfutharkFunction DeclarationsfutharkJust if this function is an entry point. If so, it also contains the externally visible interface. Note that this may not strictly be well-typed after some desugaring operations, as it may refer to abstract types that are no longer in scope.futharkInformation about the external interface exposed by an entry point. The important thing is that that we remember the original source-language types, without desugaring them at all. The annoying thing is that we do not require type annotations on entry points, so the types can be either ascribed or inferred.futharkPart of the type of an entry point. Has an actual type, and maybe also an ascribed type expression.futhark1Documentation strings, including source location.futharkA pattern as used most places where variables are bound (function parameters, let expressions, etc).futharkWhether the loop is a for -loop or a while-loop.futharkA case in a match expression.futharkAn entry in a record literal.futhark The Futhark expression language.In a value of type Exp f vn*, annotations are wrapped in the functor f, and all names are of type vn.This allows us to encode whether or not the expression has been type-checked in the Haskell type of the expression. Specifically, the parser will produce expressions of type Exp  ., and the type checker will convert these to Exp  , in which type information is always present and all names are unique.futharkA polymorphic integral literal.futharkA polymorphic decimal literal.futhark?A string literal is just a fancy syntax for an array of bytes.futharkA parenthesized expression.futharkTuple literals, e.g., {1+3, {x, y+z}}.futharkRecord literals, e.g.  {x=2,y=3,z}.futharkArray literals, e.g., [ [1+x, 3], [2, 1+4] ]7. Second arg is the row type of the rows of the array.futharkType ascription: e : t.futharkSize coercion: e :> t.futharkThe  Maybe VName is a possible existential size that is instantiated by this argument..The [VName] are the existential sizes that come into being at this call site.futhark;Numeric negation (ugly special case; Haskell did it first).futhark+0; first two types are operands, third is result.futhark2+*; first type is operand, second is result.futhark+2*; first type is operand, second is result.futharkField projection as a section: (.x.y.z).futharkArray indexing as a section: (.[i,j]).futharkFail if the first expression does not return true, and return the value of the second expression if it does.futharkAn n-ary value constructor.futharkA match expression.futhark1An attribute applied to the following expression.futhark6A name qualified with a breadcrumb of module accesses.futhark"An indexing of a single dimension.futhark&Whether a bound for an end-point of a / or a range literal is inclusive or exclusive.futhark%May be "down to" if step is negative.futharkDefault binary operators.futharkA pseudo-operator standing in for any normal identifier used as an operator (they all have the same fixity). Binary Ops for Numbersfuthark |>futhark<| MiscfutharkAn identifier consists of its name and the type of the value bound to the identifier.futharkSimple Futhark values. Values are fully evaluated and their type is always unambiguous.futharkIt is assumed that the array is 0-indexed. The type is the full type.futhark;Information about which parts of a value/type are consumed.futhark$Consumes these fields in the record.futhark?A function that consumes its argument(s) like this. The final  should always be , as there is no way for a function to consume its return value.futharkConsumes this value.futhark8Only observes value in this position, does not consume.futhark'A declaration of the type of something.futharkThe type declared by the user.futhark%The type deduced by the type checker.futhark8A type argument expression passed to a type constructor.futharkAn unstructured type with type variables and possibly shape declarations - this is what the user types in the source program. These are used to construct s in the type checker.futhark0A dimension declaration expression for use in a .futharkThe size of the dimension is this name, which must be in scope.futharkThe size is a constant.futharkNo dimension declaration.futhark6A value type contains full, manifest size information.futharkA "structural" type with shape annotations and no aliasing information, used for declarations.futharkA type with aliasing information and shape annotations, used for describing the type patterns and expressions.futharkAliasing for a type, which is a set of the variables that are aliased.futharkA variable that is aliased. Can be still in-scope, or have gone out of scope and be free. In the latter case, it behaves more like an equivalence class. See uniqueness-error18.fut for an example of why this is necessary.futhark)An argument passed to a type constructor.futharkAn expanded Futhark type is either an array, or something that can be an element of an array. When comparing types for equality, function parameter names are ignored. This representation permits some malformed types (arrays of functions), but importantly rules out arrays-of-arrays.futharkTypes that can be elements of arrays. This representation does allow arrays of records of functions, which is nonsensical, but it convolutes the code too much if we try to statically rule it out.futharkThe aliasing corresponds to the lexical closure of the function.futhark0The name (if any) of a function parameter. The ( and (5 instances always compare values of this type equal.futhark?A type name consists of qualifiers (for error messages) and a  (for equality checking).futharkThe size of an array type is a list of its dimension sizes. If '3, that dimension is of a (statically) unknown size.futhark Declaration of a dimension size.futharkThe size of the dimension is this name, which must be in scope. In a return type, this will give rise to an assertion.futharkThe size is a constant.futharkNo dimension declaration.futhark5A type class for things that can be array dimensions.futhark unifyDims x y combines x and y to contain their maximum common information, and fails if they conflict.futharkThe payload of an attribute.futharkA class for converting ordinary Haskell values to primitive Futhark values.futharkNon-array values.futharkLow-level primitive types.futharkSome information. The dual to futharkNo information functor. Usually used for placeholder type- or aliasing information.futharkConvenience class for deriving ( instances for the AST.futhark.The number of dimensions contained in a shape.futharkstripDims n shape strips the outer n dimensions from shape , returning '3 if this would result in zero or fewer dimensions.futharkunifyShapes x y combines x and y to contain their maximum common information, and fails if they conflict.futhark Convert a  to a .futhark Convert a  to a .futharkThe name of a type parameter.nqrt s Safe-Inferred>?~yfuthark8A case (of a match expression) with no type annotations.futhark+A Futhark program with no type annotations.futhark A spec with no type annotations.futhark'A declaration with no type annotations.futhark0A function declaration with no type annotations.futhark#A pattern with no type annotations.futhark*A type parameter with no type annotations.futhark2A module type expression with no type annotations.futhark-A module expression with no type annotations.futhark'An expression with no type annotations.futhark"An index with no type annotations.futhark'An identifier with no type annotations.futhark)A type declaration with no expanded type.futhark'An expression with no type annotations.futhark:A type with no aliasing information but shape annotations.futharkThe nature of something predefined. These can either be monomorphic or overloaded. An overloaded builtin is a list valid types it can be instantiated with, to the parameter and result type, with ', representing the overloaded parameter type.futhark Where does this dimension occur?futharkImmediately in the argument to .futharkIn a function parameter type.futharkIn a function return type.futharkReturn the dimensionality of a type. For non-arrays, this is zero. For a one-dimensional array it is one, for a two-dimensional it is two, and so forth.futhark5Return the shape of a type - for non-arrays, this is (.futharkReturn any shape declarations in the type, with duplicates removed.futhark/Change the shape of a type to be just the rank.futhark"Add size annotations that are all .futhark"Change all size annotations to be .futharkPerform a traversal (possibly including replacement) on sizes that are parameters in a function type, but also including the type immediately passed to the function. Also passes along a set of the parameter names inside the type that have come in scope at the occurrence of the dimension.futharkFigure out which of the sizes in a parameter type must be passed explicitly, because their first use is as something else than just an array dimension.  is like this function, but first decomposes into parameter types.futharkFigure out which of the sizes in a binding type must be passed explicitly, because their first use is as something else than just an array dimension.futhark Return the uniqueness of a type.futharkunique t is (' if the type of the argument is unique.futharkReturn the set of all variables mentioned in the aliasing of a type.futharkdiet t< returns a description of how a function parameter of type t might consume its argument.futharkConvert any type to one that has rank information, no alias information, and no embedded names.futhark(Remove aliasing information from a type.futhark,Replace no aliasing with an empty alias set.futhark peelArray n t4 returns the type resulting from peeling the first n array dimensions from t . Returns Nothing if t has less than n dimensions.futhark arrayOf t s u constructs an array type. The convenience compared to using the  constructor directly is that t can itself be an array. If t is an n-dimensional array, and s is a list of length n, the resulting type is of an n+m6 dimensions. The uniqueness of the new array will be u, no matter the uniqueness of t.futharkstripArray n t removes the n outermost layers of the array. Essentially, it is the type of indexing an array of type t with n indexes.futharkCreate a record type corresponding to a tuple with the given element types.futharkDoes this type corespond to a tuple? If so, return the elements of that tuple.futhark+Does this record map correspond to a tuple?futhark0Construct a record map corresponding to a tuple.futhark1Increasing field names for a tuple (starts at 0).futharkSort fields by their name; taking care to sort numeric fields by their numeric value. This ensures that tuples and tuple-like records match.futharkSort the constructors of a sum type in some well-defined (but not otherwise significant) manner.futhark Is this a ?futhark Is this a ?futharkCombine the shape information of types as much as possible. The first argument is the orignal type and the second is the type of the transformed expression. This is necessary since the original type may contain additional information (e.g., shape restrictions) from the user given annotation.futhark6Match the dimensions of otherwise assumed-equal types.futharkSet the uniqueness attribute of a type. If the type is a record or sum type, the uniqueness of its components will be modified.futharkt `setAliases` als returns t , but with als/ substituted for any already present aliasing.futharkt `addAliases` f returns t5, but with any already present aliasing replaced by f applied to that aliasing.futharkThe type of a basic value.futharkThe type of the value.futhark*The size of values of this type, in bytes.futhark Construct a  with the given number of  dimensions.futharkThe type is leaving a scope, so clean up any aliases that reference the bound variables, and turn any dimensions that name them into AnyDim instead.futhark:Perform some operation on a given record field. Returns ' if that field does not exist.futharkThe type of an Futhark term. The aliasing will refer to itself, if the term is a non-tuple-typed variable.futharkfoldFunType ts ret creates a function type () that takes ts as parameters and returns ret.futharkExtract the parameter types and return type from a type. If the type is not an arrow type, the list of parameter types is empty.futhark#The type names mentioned in a type.futhark orderZero t is ( if the argument type has order 0, i.e., it is not a function type, does not contain a function type as a subcomponent, and may not be instantiated with a function type.futhark:Extract all the shape names that occur in a given pattern.futhark7Extract all the shape names that occur in a given type.futharkpatternOrderZero pat is (8 if all of the types in the given pattern have order 0.futhark*The set of identifiers bound in a pattern.futhark$The set of names bound in a pattern.futhark8A mapping from names bound in a map to their identifier.futhark(The type of values bound by the pattern.futharkThe type matched by the pattern, including shape declarations if present.futharkWhen viewed as a function parameter, does this pattern correspond to a named parameter of some type?futharkNames of primitive types to types. This is only valid if no shadowing is going on, but useful for tools.futharkA map of all built-ins.futharkThe largest tag used by an intrinsic - this can be used to determine whether a / refers to an intrinsic or a user-defined name.futhark-Create a name with no qualifiers from a name.futhark8Add another qualifier (at the head) to a qualified name.futhark2Create a type name name with no qualifiers from a .futhark*The modules imported by a Futhark program.futhark-The modules imported by a single declaration.futharkThe set of module types used in any exported (non-local) declaration.futharkExtract a leading $((name, namespace, file), remainder) from a documentation comment string. These are formatted as `name`@namespace[@file]. Let us hope that this pattern does not occur anywhere else.futharkGiven an operator name, return the operator that determines its syntactical properties. Safe-Inferred>?futharkClass for type constructors that represent annotations. Used in the prettyprinter to either print the original AST, or the computed decoration.futharkExtract value, if any.futharkA class for types that are variable names in the Futhark source language. This is used instead of a mere ( instance because in the compiler frontend we want to print VNames differently depending on whether the FUTHARK_COMPILER_DEBUGGING environment variable is set, yet in the backend we want to always print VNames with the tag. To avoid erroneously using the ( instance for VNames, we in fact only define it inside the modules for the core language (as an orphan instance). futharkPrettyprint a name to a string. futharkDepending on the environment variable FUTHARK_COMPILER_DEBUGGING, VNames are printed as either the name with an internal tag, or just the base name.   Trustworthy  futharkA lexical token. It does not itself contain position information, so in practice the parser will consume tokens tagged with a source position. futhark&A value tagged with a source location.)futhark+Suffix a zero if the last character is dot. futharkGiven a starting position, produce tokens from the given text (or a lexer error). Returns the final position. ) Trustworthy > futharkA parse error. Use )% to get a human-readable description.)futharkParse an Futhark expression incrementally from monadic actions, using the '' as the source name for error messages. futharkParse either an expression or a declaration incrementally; favouring declarations in case of ambiguity. )))))))) )9 )9 Safe  futhark/Parse an entire Futhark program from the given ( , using the '' as the source name for error messages. futhark+Parse an Futhark expression from the given ' , using the '' as the source name for error messages.!futhark1Parse a Futhark module expression from the given ' , using the '' as the source name for error messages.!futhark%Parse an Futhark type from the given ' , using the '' as the source name for error messages.!futhark'Parse any Futhark value from the given ' , using the '( as the source name for error messages.!futharkParse several Futhark values (separated by anything) from the given ' , using the '( as the source name for error messages. !!!! !!!! Safen!futhark,A type-checked case (of a match expression).!futhark.A known scalar type with no shape annotations.!futharkA type-checked type parameter.!futhark(A known type arg with shape annotations.!futhark)An Futhark program with type information.!futharkA type-checked specification.!futharkA type-checked declaration.!futhark&A type-checked module type expression.!futhark A type-checked module parameter.!futhark!A type-checked module expression.!futhark#A type-checked module type binding.!futharkA type-checked module binding.!futhark%A type binding with type information.!futhark(A type declaration with type information!futhark.An constant declaration with type information.!futhark A pattern with type information.!futhark$An expression with type information.!futharkAn index with type information.!futhark2An identifier with type- and aliasing information.nqrt s !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!Safe!futhark6Modules produces environment with this representation.!futharkA mapping from names (which always exist in some namespace) to a unique (tagged) name.!futharkType parameters, list of parameter types (optinally named), and return type. The type parameters are in scope in both parameter types and the return type. Non-functional values have only a return type.!futhark2A binding from a name to its definition as a type.!futhark Representation of a module type.!futhark"Abstract types in the module type.!futharkA parametric functor consists of a set of abstract types, the environment of its parameter, and the resulting module type.!futharkRepresentation of a module, which is either a plain environment, or a parametric module ("functor" in SML).!futhark0A mapping of abstract types to their liftedness.!futharkThe space inhabited by a name.!futharkFunctions and values.!futharkA mapping from import names to imports. The ordering is significant.!futharkThe result of type checking some file. Can be passed to further invocations of the type checker.!futharkAbstract types.!futharkCanonical reference to a Futhark code file. Does not include the .fut extension. This is most often a path relative to the current working directory of the compiler.!futharkCreate an import name immediately from a file path specified by the user.!futhark We resolve '..' paths here and assume that no shenanigans are going on with symbolic links. If there is, too bad. Don't do that.!futhark Create a .fut file corresponding to an !.!futhark7Produce a human-readable canonicalized string from an !.(!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!(!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!None 567!futharkThe interpreter context. All evaluation takes place with respect to a context, and it can be extended with more definitions, which is how the REPL works.!futharkAn error occurred during interpretation due to an error in the user program. Actual interpreter errors will be signaled with an IO exception (().!futhark'The actual type- and value environment.*futharkA mapping from type parameters to the shapes of the value to which they were initially bound.*futharkA TermValue with a '! type annotation is an intrinsic.*futhark.A polymorphic value that must be instantiated.!futhark A fully evaluated Futhark value.*futharkA shape is a tree to accomodate the case of records. It is parameterised over the representation of dimensions.*futhark*The monad in which evaluation takes place.!futhark(What is the reason for this break point?!futhark&An explicit breakpoint in the program.!futharkA!futhark,Does the value correspond to an empty array?!futharkString representation of an empty array with the provided element type. This is pretty ad-hoc - don't expect good results unless the element type is a primitive.*futharkCreate an array value; failing if that would result in an irregular array.*futhark*, but with 0 as 1.*futharkExpand type based on information that was not available at type-checking time (the structure of abstract types).!futharkThe initial environment contains definitions of the various intrinsic functions.!futharkExecute the named function on the given arguments; may fail horribly if these are ill-typed.!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! Trustworthy?"futharkThe names that are bound for some types, either implicitly or explicitly."futhark)Determine the names bound for some types."futharkAs ">, but returns components of a top-level tuple type piecemeal."futharkHow many core language values are needed to represent one source language value of the given type?"futhark7Convert an external primitive to an internal primitive."futharkConvert an external primitive value to an internal primitive value. """""""""" """""""""" Safe-Inferred?"futhark%A function for internalising lambdas."""""""""""" Trustworthy? *futharkDefunctionalization monad. The Reader environment tracks both the current Env as well as the set of globally defined dynamic functions. This is used to avoid unnecessarily large closure environments.*futharkEnvironment mapping variable names to their associated static value.*futharkA static value stores additional information about the result of defunctionalization of an expression, aside from the residual expression.*futharkThe .s are shape parameters that are bound by the !.*futharkThe constructor that is actually present, plus the others that are not.*futharkAn expression or an extended ; (with size parameters, which AST lambdas do not support).*futharkReturns the defunctionalization environment restricted to the given set of variable names and types.*futharkRun a computation in the defunctionalization monad. Returns the result of the computation, a new name source, and a list of lifted function declations.*futharkLooks up the associated static value for a given name in the environment.*futharkDefunctionalization of an expression. Returns the residual expression and the associated static value in the defunctionalization monad.*futharkSame as *%, except it ignores the static value.*futharkDefunctionalize the function argument to a SOAC by eta-expanding if necessary and then defunctionalizing the body of the introduced lambda.*futhark8Defunctionalize an indexing of a single array dimension.*futharkDefunctionalize a let-bound function, while preserving parameters that have order 0 types (i.e., non-functional).*futharkDefunctionalize an application expression at a given depth of application. Calls to dynamic (first-order) functions are preserved at much as possible, but a new lifted function is created if a dynamic function is only partially applied.*futhark Check if a * and a given application depth corresponds to a fully applied dynamic function.*futharkConverts a dynamic function * into a list of dimensions, a list of parameters, a function body, and the appropriate static value for applying the function at the given depth of partial application.*futharkConverts a pattern to an environment that binds the individual names of the pattern to their corresponding types wrapped in a * static value.*futhark6Create an environment that binds the shape parameters.*futharkCreate a new top-level value declaration with the given function name, return type, list of parameters, and body expression.*futharkGiven a closure environment, construct a record pattern that binds the closed over variables.*futharkGiven a closure environment pattern and the type of a term, construct the type of that term, where uniqueness is set to  for those arrays that are bound in the environment or pattern (except if they are unique there). This ensures that a lifted function can create unique arrays as long as they do not alias any of its parameters. XXX: it is not clear that this is a sufficient property, unfortunately.*futhark8Compute the corresponding type for a given static value.*futharkConstruct the type for a fully-applied dynamic function from its static value and the original types of its arguments.*futharkMatch a pattern with its static value. Returns an environment with the identifier components of the pattern mapped to the corresponding subcomponents of the static value.*futharkGiven a pattern and the static value for the defunctionalized argument, update the pattern to reflect the changes in the types.*futharkConvert a record (or tuple) type to a record static value. This is used for "unwrapping" tuples and records that are nested in * static values.*futhark3Compute the set of free variables of an expression.*futhark2Extract all the variable names bound in a pattern.*futharkDefunctionalize a top-level value binding. Returns the transformed result as well as an environment that binds the name of the value binding to the static value of the transformed body. The boolean is true if the function is a *.*futhark1Defunctionalize a list of top-level declarations."futharkTransform a list of top-level value bindings. May produce new lifted function definitions, which are placed in front of the resulting list of declarations.""Safe?7*futharkFlatten a pattern. Returns a list of identifiers. The structural type of each identifier is returned separately."""""""" Trustworthy k "futhark$Two values differ in some way. The (1 instance produces a human-readable explanation.*futhark?The position the value number and a flat index into the array."futharkA representation of the simple values we represent in this module."futhark/An efficiently represented Futhark value. Use . to get a human-readable representation, and *$ to obtain binary a representation."futharkAn Unboxed vector."futharkA textual description of the type of a value. Follows Futhark type notation, and contains the exact dimension sizes if an array.*futharkA character that can be part of a value. This doesn't work for string and character literals."futhark/Parse Futhark values from the given bytestring.*futharkA human-readable description of how two values are not the same."futharkCompare two sets of Futhark values for equality. Shapes and types must also match."futharkAs " , but only reports one mismatch.""""""""""""""""""""""""""""""""""""""""None ?Α#"futhark/The result expected from a succesful execution."futharkThese values are expected."futharkCompute expected values from executing a known-good reference implementation."futhark)How a test case is expected to terminate."futhark;Execution suceeds, with or without expected result values."futhark Execution fails with this error.*futharkGenerate a value of the given rank and primitive type. Scalars are considered 0-ary arrays.*futhark'A fixed non-randomised primitive value."futharkSeveral Values - either literally, or by reference to a file, or to be generated on demand."futhark6A condition for execution, input, and expected result."futharkA warning test requires that a warning matching the regular expression is produced. The program must also compile succesfully."futharkA structure test specifies a compilation pipeline, as well as metrics for the program coming out the other end."futhark!How a program can be transformed."futhark'The error expected for a negative test."futhark/Input and output pairs for some entry point(s)."futharkHow to test a program."futharkDescription of a test to be carried out on a Futhark program. The Futhark program is stored separately.*futhark?A prettyprinted representation of type of value produced by a *."futhark;Read the test specification from the given Futhark program."futharkLike "!, but kills the process on error.*futharkRead test specifications from the given path, which can be a file or directory containing .fut files and further directories."futharkRead test specifications from the given paths, which can be a files or directories containing .fut files and further directories."futharkLike "", but kills the process on errors."futhark7Try to parse a several values from a byte string. The '' parameter is used for error messages."futhark6Get the actual core Futhark values corresponding to a " specification. The '9 is the directory which file paths are read relative to."futhark(Extract a pretty representation of some ". In the IO monad because this might involve reading from a file. There is no guarantee that the resulting byte string yields a readable value.*futharkThere is a risk of race conditions when multiple programs have identical ". In such cases, multiple threads in 'futhark test' might attempt to create the same file (or read from it, while something else is constructing it). This leads to a mess. To avoid this, we create a temporary file, and only when it is complete do we move it into place. It would be better if we could use file locking, but that does not work on some file systems. The approach here seems robust enough for now, but certainly it could be made even better. The race condition that remains should mostly result in duplicate work, not crashes or data corruption.*futharkCompute the expected size of the file. We use this to check whether an existing file is broken/truncated."futharkWhen/if generating a reference output file for this run, what should it be called? Includes the "data/" folder."futhark;Get the values corresponding to an expected result, if any."futhark&The name we use for compiled programs."futhark4compileProgram extra_options futhark backend program compiles program with the command  futhark backend extra-options..., and returns stdout and stderr of the compiler. Throws an IO exception containing stderr if compilation fails."futhark0runProgram runner extra_options prog entry input runs the Futhark program prog (which must have the .fut suffix), executing the entry entry point and providing input on stdin. The program must have been compiled in advance with ". If runner is non-null, then it is used as "interpreter" for the compiled program (e.g. python( when using the Python backends). The  extra_options are passed to the program."futharkEnsure that any reference output files exist, or create them (by compiling the program with the reference compiler and running it on the input) if necessary."futharkDetermine the --tuning options to pass to the program. The first argument is the extension of the tuning file, or ' if none should be used.;""""""""""""""""""""""""""""""""""""""""""""""""""""""""""";"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""None ?ҫ #futharkHow to compile a benchmark.#futharkHow to run a benchmark.#futharkInvoked for every runtime measured during the run. Can be used to provide a progress bar.#futhark8The results for all datasets for some benchmark program.#futharkThe results for a single named dataset is either an error message, or runtime measurements along the stderr that was produced.#futhark&The runtime of a single succesful run.#futhark1Transform benchmark results to a JSON bytestring.#futhark0Decode benchmark results from a JSON bytestring.*futharkLike tail -f., but running an arbitrary IO action per line.#futhark3Run the benchmark program on the indicated dataset.#futhark'Compile and produce reference datasets."#################################"############### Safe-Inferred>#futhark'The class of things that we can map an # across.#futharkMap a monadic action across the immediate children of an object. Importantly, the # action is not invoked for the object itself, and the mapping does not descend recursively into subexpressions. The mapping is done left-to-right.#futharkExpress a monad mapping operation on a syntax node. Each element of this structure expresses the operation to be performed on a given child.#futharkAn #& that just leaves its input unchanged.#futharkRemove all annotations from an expression, but retain the name/scope information. ########### ########### Safe-Inferred?#futhark7Information about what is at the given source location.#futharkWhat a name is bound to.#futharkWhere was a bound variable actually bound? That is, what is the location of its definition?*futhark*All bindings of everything in the program.#futharkInformation about what's at the given source position. Returns ' if there is nothing there, including if the source position is invalid. po######### #########po TrustworthyR*futhark5A pairing of a lexical closure and a module function.*futharkA non-parametric module.*futharkA substitution from names in the original program to names in the generated/residual program.*futhark(A general-purpose substitution of names.#futharkPerform defunctorisation.##Safeڍ#futhark,The warnings produced by the compiler. The (1 instance produces a human-readable description.#futhark'A single warning at the given location.#futharkA single warning at the given location, but also with a stack trace (sort of) to the location.###### Trustworthy ?#futharkMonads that support type checking. The reason we have this internal interface is because we use distinct monads for checking expressions and declarations.#futhark$The type checker runs in this monad.#futhark!A mapping from import strings to !s. This is used to resolve import declarations.#futhark0Information about an error during type checking.#futharkA collection of *s.*futhark5A note with extra information regarding a type error.#futharkA single note.#futharkAn unexpected functor appeared!#futhark#An unknown variable was referenced.#futharkAn unknown type was referenced.$futhark,A name prefixed with an underscore was used.$futharkRun a # computation.$futharkRetrieve the current !.$futhark$The name of the current file/import.$futharkLook up a module type.$futharkLook up an import.$futhark Evaluate a #! computation within an extended (not replaced) environment.$futharkElaborate the given name in the given namespace at the given location, producing the corresponding unique .$futharkMap source-level names do fresh unique internal names, and evaluate a type checker context with the mapping active.*futharkExtract from a type either a function type comprising a list of parameter types and a return type, or a first-order type.$futharkTry to prepend qualifiers to the type names such that they represent how to access the type in some scope.$futharkTurn a ( # into an actual error.$futharkAll signed integer types.$futharkAll unsigned integer types.$futharkAll integer types.$futharkAll floating-point types.$futharkAll number types.$futharkAll primitive types.$futharkThe !( corresponding to the intrinsics module.$futhark8The names that are available in the initial environment.!!!!!!!!!!!!!!!!!!!!!!!!!!!!!########################$$$$$$$$$$$$$$$$$$$#$$$$$$$$#####$##############$$!!!!!!!!!!!!!#!!!!!!!!!!!!$$$$$$!!!!$$Safe >?B$futharkClass of types which allow for substitution of types with no annotations for type variable names.$futharkA type substituion may be a substitution or a yet-unknown substitution (but which is certainly an overloaded primitive type!). The latter is used to remove aliases from types that are yet-unknown but that we know cannot carry aliases (see issue #682).$futhark#A collection of type substitutions.$futharkA substitution for when using $.$futharkunifyTypes uf t1 t2 attempts to unify t1 and t2". If unification cannot happen, '> is returned, otherwise a type that combines the aliasing of t1 and t2* is returned. Uniqueness is unified with uf.$futharkx `subtypeOf` y is true if x is a subtype of y (or equal to y ), meaning x is valid whenever y is.$futharkx $ y is true if x is not less unique than y.$futharkUse $ to check a type declaration.$futharkType-check a single , returning the checked , its fully expanded type (modulo yet-unelaborated type variables), and whether it is potentially higher-order.$futharkCheck for duplication of names inside a pattern group. Produces a description of all names used in the pattern group.*futharkCheck whether the type contains arrow types that define the same parameter. These might also exist further down, but that's not really a problem - we mostly do this checking to help the user, since it is likely an error, but it's easy to assign a semantics to it (normal name shadowing).$futharkcheckTypeParams ps m checks the type parameters ps!, then invokes the continuation m with the checked parameters, while extending the monadic name map with ps.$futharkRetrieve notes describing the purpose or origin of the given . The location is used as the *current* location, for the purpose of reporting relative locations.$futhark3Replace all type variables with their substitution.$futhark:Replace any top-level type variable with its substitution.$futhark:Replace any top-level type variable with its substitution.$futharkReplace  dimensions that occur as  or  with a fresh .*futharkIs the given type variable the name of an abstract type or type parameter, which we cannot substitute?*futhark:If the given type variable is nonrigid, what is its level?$futharkUnifies two types.$futharkexpect super sub checks that sub is a subtype of super.$futhark?Assert that this type must be one of the given primitive types.$futhark,Assert that this type must support equality.$futhark)Assert that this type must be zero-order.$futharkIn mustHaveConstr usage c t fs , the type t must have a constructor named c that takes arguments of types ts.$futharkAssert that some type must have a field with this name and type.$futhark)Replace dimension mismatches with AnyDim.$futharkLike unification, but creates new size variables where mismatches occur. Returns the new dimensions thus created.$futharkConstruct a the name of a new type variable given a base description and a tag number (note that this is distinct from actually constructing a VName; the tag here is intended for human consumption but the machine does not care).$futharkPerform a unification of two types outside a monadic context. The type parameters are allowed to be instantiated; all other types are considered rigid.9$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$9$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$ Trustworthy? %futharkMonomorphise a list of top-level declarations. A module-free input program is expected, so only value declarations and type declaration are accepted.%%Safe  ?Z%futharkConvert a program in source Futhark to a program in the Futhark core language.*futharkReplace all named dimensions with a fresh name, and remove all constant dimensions. The point is to remove the constraints, but keep the names around. We use this for constructing the entry point parameters.*futharkPromote to dimension type as appropriate for the original type. Also return original type.*futharkSome operators and functions are overloaded or otherwise special - we detect and treat them here.%% Trustworthy 5>? *futharkA data type for constructor patterns. This is used to make the code for detecting unmatched constructors cleaner, by separating the constructor-pattern cases from other cases.*futharkAn unmatched pattern. Used in in the generation of unmatched pattern warnings by the type checker.*futharkThe state is a set of constraints and a counter for generating type names. This is distinct from the usual counter we use for generating unique names, as these will be user-visible.*futharkMapping function arguments encountered to the sizes they ended up generating (when they could not be substituted directly). This happens for function arguments that are not constants or names.*futharkWhat was the source of some existential size? This is used for using the same existential variable if the same source is encountered in multiple locations.*futhark=Type checking happens with access to this environment. The * will be extended during type-checking as bindings come into scope.*futhark4Aliases in parameters indicate the lexical closure.*futhark2Whether something is a global or a local variable.*futharkThe consumption set is a Maybe so we can distinguish whether a consumption took place, but the variable went out of scope since, or no consumption at all took place.*futharkA null occurence is one that we can remove without affecting anything.*futharkA seminull occurence is one that does not contain references to any variables in scope. The big difference is that a seminull occurence may denote a consumption, as long as the array that was consumed is now out of scope.*futharkGet the type of an expression, with top level type variables substituted. Never call ; directly (except in a few carefully inspected locations)!*futharkGet the type of an expression, with all type variables substituted. Slower than *', but sometimes necessary. Never call ; directly (except in a few carefully inspected locations)!*futharkWrap $; to also perform an observation of every size in the type.*futharkInstantiate a type scheme with fresh type variables for its type parameters. Returns the names of the fresh type variables, the instance list, and the instantiated type.*futharkCreate a new type name and insert it (unconstrained) in the substitution map.*futharkDetermine if the two types of identical, ignoring uniqueness. Mismatched dimensions are turned into fresh rigid type variables. Causes a #; if they fail to match, and otherwise returns one of them.*futhark require ts e causes a # if  expType e is not one of the types in ts. Otherwise, simply returns e.*futhark%returnType ret_type arg_diet arg_type gives result of applying an argument the given types to a function with the given return type, consuming the argument with the given diet.*futharkt * d removes aliases (sets them to () from the parts of t% that are denoted as consumed by the  d.%futharkType-check a single expression in isolation. This expression may turn out to be polymorphic, in which case the list of type parameters will be non-empty.*futharkTraverse the expression, emitting warnings if any of the literals overflow their inferred typesNote: currently unable to detect float underflow (such as 1e-400 -> 0)%futharkType-check a top-level (or module-level) function definition. Despite the name, this is also used for checking constant definitions, by treating them as 0-ary functions.*futharkThis is "fixing" as in "setting them", not "correcting them". We only make very conservative fixing.*futharkExtract all the shape names that occur in positive position (roughly, left side of an arrow) in a given type.*futhark5The set of in-scope variables that are being aliased.*futharkVerify certain restrictions on function parameters, and bail out on dubious constructions.These restrictions apply to all functions (anonymous or otherwise). Top-level functions have further restrictions that are checked during let-generalisation.*futharkFind at all type variables in the given type that are covered by the constraints, and produce type parameters that close over them.The passed-in list of type parameters is always prepended to the produced list of type parameters.*futhark?Proclaim that we have made read-only use of the given variable.*futhark4Proclaim that we have written to the given variable.*futharkProclaim that we have written to the given variable, and mark accesses to it and all of its aliases as invalid inside the given computation.*futharkMake all bindings nonunique.%%%%Safe *futhark"All names defined anywhere in the !.%futharkCreate unique renames for the module type. This is used for e.g. generative functor application.%futhark,Refine the given type name in the given env.%futharkReturn new renamed/abstracted env, as well as a mapping from names in the signature to names in the new env. This is used for functor application. The first env is the module env, and the second the env it must match.%futhark)Apply a parametric module to an argument.%%%%%%%%Safe ?%futharkType check a program containing no type information, yielding either a type error or a program with complete type information. Accepts a mapping from file names (excluding extension) to previously type checker results. The ' is used to resolve relative imports.%futharkType check a single expression containing no type information, yielding either a type error or the same expression annotated with type information. Also returns a list of type parameters, which will be nonempty if the expression is polymorphic. See also %.%futharkType check a single declaration containing no type information, yielding either a type error or the same declaration annotated with type information along the Env produced by that declaration. See also %.%futharkType check a single module expression containing no type information, yielding either a type error or the same expression annotated with type information along the Env produced by that declaration. See also %.%futharkAn initial environment for the type checker, containing intrinsics and such.##%%%%%%%%%##% Safe-Inferred ?%futharkPre-typechecked imports, including a starting point for the name source.%futhark'Files that should be implicitly opened.*futhark?A little monad for reading and type-checking a Futhark program.%futharkA basis that contains no imports, and has a properly initialised name source.%futharkRead Futhark files from some basis, and printing log messages if the first parameter is True.*futharkRead and type-check a Futhark library (multiple files, relative to the same search path), including all imports.%futhark(Read and type-check Futhark imports (no .fut extension; may refer to baked-in prelude). This is an exotic operation that probably only makes sense in an interactive environment.!!!!!!#%%%%%%%%%%!!!!!!#%%%%%%Safe ?" %futharkThe compiler configuration. This only contains options related to core compiler functionality, such as reading the initial program and running passes. Options related to code generation are handled elsewhere.%futhark Warn if True.%futharkIf true, error on any warnings.%futharkIf True, ignore unsafe.%futhark#The default compiler configuration.%futhark'Print a compiler error to stdout. The % controls to which degree auxiliary information (e.g. the failing program) is also printed.%futharkRead a program from the given ', run the given , and finish up with the given .%futharkRead a program from the given ', run the given , and return it.%futhark=Read and type-check a Futhark program, including all imports.%futharkRead and type-check a collection of Futhark files, including all imports.%futhark-Not verbose, and terminates process on error.%futharkRun an operation that produces warnings, and handle them appropriately, yielding the non-warning return value. "Proper handling" means e.g. to print them to the screen, as directed by the compiler configuration.!!!!!!#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% Trustworthy ->?2-%futharkCompile things to .%futharkCompile to an , where the type (must must still be a primitive) is deduced monadically.%futhark*Compile where we know the type in advance.%futhark)The symbol table used during compilation.*futharkUser-extensible environment.*futhark.Name of the function we are compiling, if any.*futharkThe set of attributes that are active on the enclosing statements (including the one we are currently compiling).*futharkThe % is (# if a copy if required. If it is ', then a copy/assignment of a memory block somewhere takes care of this array.*futharkWhen compiling an expression, this is a description of where the result should end up. The integer is a reference to the construct that gave rise to this destination (for patterns, this will be the tag of the first name in the pattern). This can be used to make the generated code easier to relate to the original code.%futhark;Every non-scalar variable must be associated with an entry.%futhark3When an array is dared, this is where it is stored.%futhark,An alternate way of compiling an allocation.%futharkHow to compile an .%futharkHow to compile some .%futharkHow to compile an .%futharkAn operations set for which the expression compiler always returns &.%futharkExecute a code generation action, returning the code that was emitted.%futharkExecute a code generation action, wrapping the generated code within a  with the given description.%futhark$Emit some generated imperative code.%futhark;Emit a warning about something the user should be aware of.%futhark&Emit a function in the generated code.%futhark+Check if a function of a given name exists.*futhark+Note: a hack to be used only for functions.*futharkLike &, but does not create new declarations. Note: a hack to be used only for functions.*futhark Another hack.*futharkRemove the array targets.&futhark Generate a , prefixed with & if it exists.&futhark Generate a , prefixed with & if it exists.*futharkThe active attributes, including those for the statement currently being compiled.*futhark,Add more attributes to what is returning by *.&futharkGet the current symbol table.&futharkRun an action with a modified symbol table. All changes to the symbol table will be reverted once the action is done!*futharkUse an  if possible, otherwise &.*futharkCopy from here to there; both destination and source may be indexeded.*futharkLike &, but the target is a * instead of a variable name.&futharkCopy from here to there; both destination and source be indexeded. If so, they better be arrays of enough dimensions. This function will generally just Do What I Mean, and Do The Right Thing. Both destination and source must be in scope.&futharkAs &, but implicitly es the indexes.&futharkcompileAlloc pat size space allocates n bytes of memory in space, writing the result to dest, which must be a single *,&futharkThe number of bytes needed to represent the array in a straightforward contiguous format, as an  expression.&futhark>Declare an array in row-major order in the given memory block.&futharkLike &, but permute the in-memory representation of the indices as specified.&futhark Uses linear/iota index function.&futhark Uses linear/iota index function.&futhark ASsignment.&futharkConstructing an ad-hoc function that does not correspond to any of the IR functions in the input program.###%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&%%%%%%%%%%%%%%%%%%%%%%%%%&&&&&&&%&&%%%%%%%%%%%%%%%%&&&%%%&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&%&3None?4&futhark Compile a ' program to sequential imperative code.#&&#None4&&None59&futhark$Compile the program to sequential C. & &None??&futharkIs there an atomic  corresponding to this ?&futharkThe mechanism that will be used for performing the atomic update. Approximates how efficient it will be. Ordered from most to least efficient.&futhark Supported directly by primitive.&futharkCan be done by efficient swaps.&futharkRequires explicit locking.&futharkA function for generating code for an atomic update. Assumes that the bucket is in-bounds.&futhark+Locking strategy used for an atomic update.&futharkArray containing the lock.&futhark'Value for us to consider the lock free.&futharkWhat to write when we lock it.&futhark What to write when we unlock it.&futharkA transformation from the logical lock index to the physical position in the array. This can also be used to make the lock array smaller.&futharkA mapping from dimensions of nested SegOps to already computed local thread IDs.&futharkAssign iterations of a for-loop to all threads in the kernel. The passed-in function is invoked with the (symbolic) iteration. * will be in effect in the body. For multidimensional loops, use &.&futharkAssign iterations of a for-loop to threads in the workgroup. The passed-in function is invoked with the (symbolic) iteration. For multidimensional loops, use &.&futharkIterate collectively though a multidimensional space, such that all threads in the group participate. The passed-in function is invoked with a (symbolic) point in the index space.&futhark>Do an atomic update corresponding to a binary operator lambda.*futharkExclude those test cases that have tags we do not wish to run.'futharkRun  futhark test.''None ?U'futharkRun  futhark run.'' Safe-InferredVB'futharkRun  futhark query.''None Zu+futhark$The monad in which futhark-pkg runs.+futhark5Install the packages listed in the build list in the lib directory of the current working directory. Since we are touching the file system, we are going to be very paranoid. In particular, we want to avoid corrupting the lib- directory if something fails along the way.The procedure is as follows:1) Create a directory lib~new. Delete an existing lib~new if necessary. 2) Populate lib~new based on the build list. 3) Rename lib to lib~old. Delete an existing lib~old if necessary. 4) Rename lib~new to lib+5) If the current package has package path p, move  lib~old/p to  lib~new/p. 6) Delete lib~old.Since POSIX at least guarantees atomic renames, the only place this can fail is between steps 3, 4, and 5. In that case, at least the lib~old2 will still exist and can be put back by the user.'futharkRun  futhark pkg.''None?Z'futhark futhark imports'futhark futhark dataget''''None^[ +futharkA human-readable description of the representation expected or contained, usable for error messages.+futharkNothing is distinct from a empty pipeline - it means we don't even run the internaliser.+futharkIf true, prints programs as raw ASTs instead of their prettyprinted form.+futhark3What to do with the program after it has been read.+futharkJust print it.+futhark(Run the type checker; print type errors.+futharkRun this pipeline.+futhark,Partially evaluate away the module language.+futharkDefunctorise and monomorphise.+futhark0Defunctorise, monomorphise, and defunctionalise.+futharkGet a Futhark pipeline from the configuration - an empty one if none exists.'futharkEntry point. Non-interactive, except when reading interpreter input from standard input.''None ^+futharkClosed interval, as in  System.Random.'futharkRun futhark dataset.'' Safe-Inferred _9'futharkRun futhark datacmp'' Safe-Inferred_'futharkRun  futhark check.''None ?`n'futharkRun  futhark bench.+futharkNumerically stable mean+futhark Standard deviation of population+futharkPopulation variance+futharkCentral moments''None ?aO+futharkDepth-first list of thresholds to tune in order, and a corresponding assignment of ancestor thresholds to ensure that they are used.'futharkRun futhark autotune''None d+futharkWe keep a mapping of the names we have actually documented, so we can generate an index.+futharkLocal module types that show up in the interface. These should be documented, but clearly marked local.+futharkA set of names that we should not generate links to, because they are uninteresting. These are for example type parameters.'futhark%renderFiles important_imports imports; produces HTML files documenting the type-checked program imports, with the files in important_imports considered most important. The HTML files must be written to the specific locations indicated in the return value, or the relative links will be wrong.+futharkThe header documentation (which need not be present) can contain an abstract and further sections.''None d'futharkRun  futhark doc.''None ?f+futhark)Are we currently stopped at a breakpoint?+futhark$Skip breakpoints at these locations.+futharkThe currently loaded file.+futharkRepresentation of breaking at a breakpoint, to allow for navigating through the stack frames and such.+futhark>Index of the current breakpoint (with 0 being the outermost).'futharkRun  futhark repl.''+                                                                                                                                                                                                                                                                                                                                                                           ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! " # # # # # # # # # # # # # # # # # # # # # # # # # # # # # $ $ $ $ $ $ $ $ $ % % % % % % % % % % % % % % % % % % % & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ' ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) ) * * * * * * * * * * * * * * * * * * + + + + + + + + + + + + + + + + + + + , , , - - - - - - - - - - - - - - - - - - . . . . . . . . . . . . . . . . . . . . . . . . / / / / / / / / / / / / / / / / / / / / / / / / / 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 00 0001111111111111111111111 1111111111111111111111111122222223333333333333333333333333333333333333333333333334444444444444444444444444444444444444444444444444444444444444444444444444444444555555555555555555555555555555566677777777788888888888888888888 8888888888888888888888888999999999999999999999 9999 9999999 9 9999999999:::::::::::::::::::::::::::::::::::::::::::::;;;<<===================================== ===============================>>?????@@@AAAAAAAAAABBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBCCCCDDDDDDDDDDDDDDDDDEEEEEEEFGGG HHHHHHIIIIIIIIIIIIIIIIIIIJJJJJJJKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK K K K K KKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOPPPPPPQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQQRRRRSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSTTTTTTTTTUUVVVVVVVVVVVWXXXXXXXXXYZZZZZZ[[[[[[\\\\]]]]]]]]]^^^_``````````````aaaaaaaaaaaabbbbbbcddddddddddddeeeeeeffgggghhhhhhhiiiiiiiiijjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjjkkkllllllllllllllllllmmmmmmmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnnnnnnnoooooppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppppp ppppppppppppppppppppppppppppppppppppppppppqrrrrrrsssssssssssssssssssssssssssssssssssssssssttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttuuuuuuuuuuvvvvvvvvvvvwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwwxxxyyyyyyyyyyyyzz{{{{{{{{{{{{{{{{{{{{{{ {{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{|||||||||||}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}~~                                                                                                                                          !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! !!!!!!!! !!"""""""" """" """""""""""""""""""""""""""""""""""""" """""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""###################   ##################################################################################################"#################$$$$$$""$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% % %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%&&&&%%&%%&%&&&&%&&&&&%"&&)&)&%&*&%&%&.&1&%&&44&4&&&4&4&4&4&4&&8&8&8&8&8&8&8&8&8&8&8&8&9&9&9&9&9&:&:&:&:;&<&<&<&<&<&=&=&=&=&=&&&I#I&I&I&I&J&%&K&L&L&&&%&%&%&%&%&%&%&&&&&&&&&%&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&%&%&%&%&&&&&%&%&%&%&%&%&%&%&%&%&%&%''%''%%'%%'%%'%%'''''''''''%%'%%'%%'%%'M'O'O'O'O'R'R'R'T'U'Y'['[$[']']'^'^'^'^'^'_'a'h'h'i'i'j'm'm'm'm'm'n'n'n'n'n'n'n'n'n'n'n'n'n'n'n'n'n'%'s'v'v'v'w'w'w'x'x'x'{{{{''&''''''''''''''''''&'''''''''''''''''''''''''''''''''((((((((((((((((( (((((((((((((((((((((((("(((((((((((&(((((((((((((((((((((((((((((((((($((((((((((((((((((((((((((((((((((((((futhark-0.16.2-inplaceLanguage.Futhark.CoreFuthark.Pkg.TypesFuthark.Util.PrettyFuthark.Internalise.MonadLanguage.Futhark.Query)Futhark.CodeGen.Backends.GenericC.Options2Futhark.CodeGen.Backends.GenericPython.Definitions Futhark.UtilFuthark.IR.Prop.RearrangeFuthark.Util.ConsoleFuthark.Util.IntegralExpFuthark.Util.LogFuthark.Pkg.InfoFuthark.Pkg.SolveFuthark.IR.Primitive Futhark.ErrorFuthark.Util.TableFuthark.IR.Syntax.CoreFuthark.IR.Prop.ConstantsFuthark.IR.Prop.TypesFuthark.IR.RetTypeFuthark.IR.DecorationsFuthark.IR.SyntaxFuthark.IR.Prop.ReshapeFuthark.IR.Prop.PatternsFuthark.IR.PrettyFuthark.IR.Prop.ScopeFuthark.IR.TraversalsFuthark.IR.Prop.TypeOfFuthark.IR.Prop.NamesFuthark.Analysis.PrimExpFuthark.Transform.Substitute!Futhark.CodeGen.OpenCL.Heuristics#Futhark.Analysis.PrimExp.GeneralizeFuthark.IR.Kernels.SizesFuthark.FreshNamesFuthark.MonadFreshNamesFuthark.Transform.RenameFuthark.IR.PropFuthark.IR.Prop.AliasesFuthark.Analysis.UsageTableFuthark.Analysis.RephraseFuthark.Analysis.Metrics!Futhark.Analysis.DataDependencies Futhark.PassFuthark.Binder.ClassFuthark.BinderFuthark.IR.AliasesFuthark.Optimise.Simplify.LoreFuthark.Analysis.AliasFuthark.ConstructFuthark.TypeCheckFuthark.Pipeline2Futhark.Optimise.InPlaceLowering.SubstituteIndices Futhark.Analysis.PrimExp.ConvertFuthark.IR.Mem.IxFunFuthark.Analysis.SymbolTableFuthark.Optimise.Simplify.Rule$Futhark.Optimise.Simplify.ClosedFormFuthark.Optimise.Simplify.Rules Futhark.Optimise.Simplify.Engine!Futhark.Analysis.PrimExp.SimplifyFuthark.Optimise.SimplifyFuthark.Transform.CopyPropagateFuthark.IR.SeqFuthark.IR.SOACS.SOAC Futhark.ToolsFuthark.IR.SOACS%Futhark.Transform.FirstOrderTransform Futhark.Pass.FirstOrderTransform"Futhark.Pass.ExtractKernels.ISRWIM!Futhark.Internalise.AccurateSizesFuthark.IR.SOACS.SimplifyFuthark.Analysis.CallGraphFuthark.IR.Mem Futhark.Pass.ExplicitAllocationsFuthark.IR.SegOp)Futhark.Pass.ExtractKernels.BlockedKernel(Futhark.Pass.ExtractKernels.Distribution'Futhark.Pass.ExtractKernels.Interchange+Futhark.Pass.ExtractKernels.DistributeNestsFuthark.IR.Mem.SimplifyFuthark.IR.Kernels.KernelFuthark.Optimise.CSE Futhark.Optimise.InliningDeadFunFuthark.IR.SeqMem$Futhark.Pass.ExplicitAllocations.SeqFuthark.IR.KernelsFuthark.Pass.KernelBabysitting%Futhark.Pass.ExtractKernels.ToKernels(Futhark.Pass.ExtractKernels.StreamKernel&Futhark.Pass.ExtractKernels.IntragroupFuthark.Pass.ExtractKernelsFuthark.Optimise.TileLoopsFuthark.Optimise.Sink-Futhark.Optimise.InPlaceLowering.LowerIntoStm Futhark.Optimise.InPlaceLoweringFuthark.IR.Kernels.SimplifyFuthark.Optimise.UnstreamFuthark.IR.KernelsMemFuthark.Pass.Simplify&Futhark.Pass.ExplicitAllocations.SegOp(Futhark.Pass.ExplicitAllocations.KernelsFuthark.Pass.ExpandAllocationsFuthark.Optimise.DoubleBufferFuthark.Analysis.HORep.SOAC!Futhark.Optimise.Fusion.ComposingFuthark.Analysis.HORep.MapNest"Futhark.Optimise.Fusion.LoopKernelFuthark.Optimise.FusionFuthark.PassesFuthark.CodeGen.ImpCodeFuthark.CodeGen.SetDefaultSpace"Futhark.CodeGen.ImpCode.SequentialFuthark.CodeGen.ImpCode.OpenCLFuthark.CodeGen.ImpCode.Kernels(Futhark.CodeGen.ImpGen.Kernels.Transpose"Futhark.CodeGen.Backends.SimpleRep!Futhark.CodeGen.Backends.GenericC'Futhark.CodeGen.ImpGen.Kernels.ToOpenCL,Futhark.CodeGen.Backends.COpenCL.Boilerplate*Futhark.CodeGen.Backends.CCUDA.Boilerplate*Futhark.CodeGen.Backends.GenericPython.AST.Futhark.CodeGen.Backends.GenericPython.Options&Futhark.CodeGen.Backends.GenericPython-Futhark.CodeGen.Backends.PyOpenCL.BoilerplateLanguage.Futhark.PreludeLanguage.Futhark.SyntaxLanguage.Futhark.PropLanguage.Futhark.PrettyLanguage.Futhark.ParserLanguage.FutharkLanguage.Futhark.SemanticLanguage.Futhark.InterpreterFuthark.Internalise.TypesValuesFuthark.Internalise.Lambdas#Futhark.Internalise.DefunctionaliseFuthark.Internalise.BindingsFuthark.Test.Values Futhark.Test Futhark.BenchLanguage.Futhark.Traversals Futhark.Internalise.DefunctoriseLanguage.Futhark.Warnings"Language.Futhark.TypeChecker.Monad"Language.Futhark.TypeChecker.Types"Language.Futhark.TypeChecker.Unify Futhark.Internalise.MonomorphiseFuthark.Internalise"Language.Futhark.TypeChecker.Terms$Language.Futhark.TypeChecker.ModulesLanguage.Futhark.TypeCheckerFuthark.Compiler.ProgramFuthark.CompilerFuthark.CodeGen.ImpGen!Futhark.CodeGen.ImpGen.Sequential)Futhark.CodeGen.Backends.SequentialPython$Futhark.CodeGen.Backends.SequentialC#Futhark.CodeGen.ImpGen.Kernels.Base&Futhark.CodeGen.ImpGen.Kernels.SegScan%Futhark.CodeGen.ImpGen.Kernels.SegRed%Futhark.CodeGen.ImpGen.Kernels.SegMap&Futhark.CodeGen.ImpGen.Kernels.SegHistFuthark.CodeGen.ImpGen.KernelsFuthark.CodeGen.ImpGen.OpenCL!Futhark.CodeGen.Backends.PyOpenCL Futhark.CodeGen.Backends.COpenCLFuthark.CodeGen.ImpGen.CUDAFuthark.CodeGen.Backends.CCUDAFuthark.ActionsFuthark.VersionFuthark.Util.OptionsFuthark.Compiler.CLIFuthark.CLI.PythonFuthark.CLI.PyOpenCLFuthark.CLI.OpenCLFuthark.CLI.CUDA Futhark.CLI.CFuthark.CLI.TestFuthark.CLI.RunFuthark.CLI.QueryFuthark.CLI.PkgFuthark.CLI.MiscFuthark.CLI.DevFuthark.CLI.DatasetFuthark.CLI.DatacmpFuthark.CLI.CheckFuthark.CLI.BenchFuthark.CLI.AutotuneFuthark.Doc.GeneratorFuthark.CLI.DocFuthark.CLI.REPLData.Traversable mapAccumLFuthark.Util.Loc Futhark.IRImp ScalarVarLanguage.Futhark.Parser.LexerLanguage.Futhark.Parser.Parser Paths_futharkbaseGHC.IntInt8Int16Int32Int64GHC.WordWord8Word16Word32Word64mgprsc-8.0.0-75eba762Text.Megaparsec.ErrorerrorBundlePrettysrclc-0.5.1.2-db7fd85dData.LoclocOfmnlnd-prtty-0.7.0.1-96a9e0cdText.PrettyPrint.Mainland hPutDocLnhPutDocputDocLnputDocprettyPragmaLazyTextdisplayPragmaLazyTextprettyLazyTextdisplayLazyText prettyPragma prettyPragmaSdisplayPragmaS prettyCompactprettyCompactSprettySdisplayS renderCompactrendererrordocfaildoc fillbreakfillwidthnestingcolumnnestindenthangalignlisttuple enclosesepsemisepcommasep punctuatesepcatstackspreadfolddocparensIfparensbracketsbraces backquotesanglesdquotessquotesencloseflattengroup<|><+/><+> softbreaksoftlinelinesrclocemptyrparenlparenrbracketlbracketrbracelbraceranglelangledquotesquote backquotespacesspacesemiequalsdotcommacolonstarlazyText strictTextrationaldoublefloatintegerintstringcharbooltextDocRLineRPos RLazyTextRTextRStringRCharREmptyRDoc mtl-2.2.2Control.Monad.Error.Class throwErrorsrclocOfPosLocSrcLoc locOfListLocatedvrsns-3.5.3-81c91554 Data.Versions prettySemVersemver_svMeta _svPreRel_svPatch_svMinor_svMajorSemVerStrDigitsVUnitOptionArgument NoArgumentRequiredArgumentOptionalArgumentOptionoptionLongNameoptionShortNameoptionArgument optionActiongenerateOptionParser pyFunctions pyUtilitypyValuespyPanicpyTuning BuildList unBuildList PkgManifestmanifestPkgPathmanifestRequiremanifestEndCommentsRequired requiredPkgrequiredPkgRev requiredHash Commentedcomments commentedComment PkgRevDepsPkgPathpkgPathFilePathisCommitVersion commitVersion parseVersion futharkPkgnewPkgManifestprettyPkgManifest pkgRevDepspkgDiraddRequiredToManifestremoveRequiredFromManifestparsePkgManifestparsePkgManifestFromFileprettyBuildList$fMonoidPkgRevDeps$fSemigroupPkgRevDeps$fTraversableCommented$fFoldableCommented$fFunctorCommented $fEqBuildList$fShowBuildList$fShowPkgManifest$fEqPkgManifest$fShowRequired $fEqRequired$fShowCommented $fEqCommented$fShowPkgRevDeps EncodedString UserString mapAccumLMchunkchunksmaxinumdropAttakeLastdropLast mapEithermaybeNth maybeHead splitFromEndsplitAt3focusNthunixEnvironment isEnvVarSet fancyTerminalrunProgramWithExitCodedirectoryContents roundFloat ceilFloat floorFloat roundDouble ceilDouble floorDoublelgammalgammaftgammatgammaftoPOSIX fromPOSIXtrimpmapIO zEncodeStringrearrangeShaperearrangeInverserearrangeReachrearrangeComposeisPermutationOftransposeIndexisMapTransposecolorinRedinGreeninBoldWrapped wrappedValue IntegralExpquotremdivmodsgndivUpfromInt8 fromInt16 fromInt32 fromInt64$fIntegralExpWrapped $fNumWrapped $fEqWrapped $fOrdWrapped $fShowWrapped MonadLoggerlogMsgaddLogToLogtoLogLogtoText $fMonoidLog$fSemigroupLog $fToLogText $fToLog[]$fMonadLoggerRWST$fMonadLoggerRWST0$fMonadLoggerWriterTMonadPkgRegistrygetPkgRegistryputPkgRegistrymodifyPkgRegistry PkgRegistryPkgInfo pkgVersionspkgLookupCommit PkgRevInfopkgRevZipballUrlpkgRevZipballDir pkgRevCommitpkgRevGetManifest pkgRevTime GetManifest getManifestdownloadZipball lookupPkgRevpkgInfo lookupPackagelookupPackageRevlookupNewestRev$fEqGetManifest$fShowGetManifest$fMonoidPkgRegistry$fSemigroupPkgRegistry$fEqPkgRevInfo$fShowPkgRevInfo PkgRevDepInfo solveDeps solveDepsPure$fFunctorPkgOp$fShowRoughBuildListpretty prettyText prettyOneLine prettyDoc prettyTupleapplyoneLinetextwrapannot nestedBlockshortenConvOpZExtSExtFPConvFPToUIFPToSIUIToFPSIToFPIToBBToICmpOpCmpEqCmpUltCmpUleCmpSltCmpSleFCmpLtFCmpLeCmpLltCmpLleBinOpAddFAddSubFSubMulFMulUDivUDivUpSDivSDivUpFDivFModUModSModSQuotSRemSMinUMinFMinSMaxUMaxFMaxShlLShrAShrAndOrXorPowFPowLogAndLogOrSafetyUnsafeSafeOverflow OverflowWrap OverflowUndefUnOpNot ComplementAbsFAbsSSignumUSignum PrimValueIntValue FloatValue BoolValueChecked Float32Value Float64Value Int8Value Int16Value Int32Value Int64ValuePrimTypeIntType FloatTypeBoolCertFloat32Float64 allIntTypes allFloatTypes allPrimTypesintValue intValueType valueIntegral floatValuefloatValueType primValueTypeblankPrimValueallUnOps allBinOps allCmpOps allConvOpsdoUnOp doComplementdoAbsdoFAbs doSSignum doUSignumdoBinOpdoAdddoMuldoSDivdoSModdoPowdoConvOpdoZExtdoSExtdoFPConvdoFPToUIdoFPToSIdoUIToFPdoSIToFPdoCmpOpdoCmpEqdoCmpUltdoCmpUledoCmpSltdoCmpSledoFCmpLtdoFCmpLe intToWord64 intToInt64 binOpType cmpOpTypeunOpType convOpTypeprimFunszeroIshoneIsh negativeIsh zeroIshInt oneIshInt primBitSize primByteSize intByteSize floatByteSizecommutativeBinOp convOpFun prettySigned$fPrettyIntType$fPrettyFloatType$fPrettyPrimType$fBoundedPrimType$fEnumPrimType$fPrettyIntValue$fPrettyFloatValue$fPrettyPrimValue $fPrettyUnOp $fOrdOverflow $fEqOverflow $fPrettyBinOp $fPrettyCmpOp$fPrettyConvOp $fEqConvOp $fOrdConvOp $fShowConvOp $fEqCmpOp $fOrdCmpOp $fShowCmpOp $fEqBinOp $fOrdBinOp $fShowBinOp $fEqSafety $fOrdSafety $fShowSafety$fShowOverflow$fEqUnOp $fOrdUnOp $fShowUnOp $fEqPrimValue$fOrdPrimValue$fShowPrimValue$fEqFloatValue$fOrdFloatValue$fShowFloatValue $fEqIntValue $fOrdIntValue$fShowIntValue $fEqPrimType $fOrdPrimType$fShowPrimType $fEqFloatType$fOrdFloatType$fShowFloatType$fEnumFloatType$fBoundedFloatType $fEqIntType $fOrdIntType $fShowIntType $fEnumIntType$fBoundedIntType InternalErrorError CompilerError ExternalError ErrorClass CompilerBugCompilerLimitation externalErrorexternalErrorSinternalErrorS compilerBugcompilerLimitation compilerBugScompilerLimitationS$fShowCompilerError$fExceptionInternalError$fShowInternalError$fEqErrorClass$fOrdErrorClass$fShowErrorClassEntrymkEntry buildTable$fShowRowTemplateVNameName CommutativityNoncommutative Commutative Uniqueness NonuniqueUniquedefaultEntryPoint nameToStringnameFromString nameToText nameFromTextlocStr locStrRelprettyStacktracebaseTagbaseName baseStringquotepquote$fPrettyUniqueness$fMonoidUniqueness$fSemigroupUniqueness$fMonoidCommutativity$fSemigroupCommutativity $fPrettyName $fOrdVName $fEqVName $fShowVName $fShowName$fEqName $fOrdName$fIsStringName$fSemigroupName$fEqCommutativity$fOrdCommutativity$fShowCommutativity$fEqUniqueness$fOrdUniqueness$fShowUniqueness ErrorMsgPart ErrorString ErrorInt32ErrorMsgPatElemTPatElem patElemName patElemDecSliceDimIndexDimFixDimSliceParam paramNameparamDecSubExpConstantVar CertificatesunCertificatesIdent identName identTypeDietConsumeObserve ObservePrim DeclExtTypeDeclTypeExtTypeTypeTypeBasePrimArrayMem NoUniquenessSpaceIdSpace DefaultSpace ScalarSpace ArrayShape shapeRank stripDims subShapeOfRankExtShapeExtSizeExtFreeShape ShapeBase shapeDimsdimFix sliceIndices sliceDims unitSlicefixSlice sliceSliceerrorMsgArgTypes$fFunctorShapeBase$fMonoidShapeBase$fSemigroupShapeBase $fFunctorExt $fMonoidRank$fSemigroupRank$fArrayShapeRank$fMonoidCertificates$fSemigroupCertificates$fArrayShapeShapeBase$fArrayShapeShapeBase0 $fOrdIdent $fEqIdent$fTraversableParam$fFunctorParam$fFoldableParam$fTraversableDimIndex$fFoldableDimIndex$fFunctorDimIndex$fTraversablePatElemT$fFoldablePatElemT$fFunctorPatElemT$fTraversableErrorMsgPart$fFoldableErrorMsgPart$fFunctorErrorMsgPart$fIsStringErrorMsgPart$fTraversableErrorMsg$fFoldableErrorMsg$fFunctorErrorMsg$fIsStringErrorMsg $fEqErrorMsg $fOrdErrorMsg$fShowErrorMsg$fEqErrorMsgPart$fOrdErrorMsgPart$fShowErrorMsgPart $fOrdPatElemT$fShowPatElemT $fEqPatElemT $fEqDimIndex $fOrdDimIndex$fShowDimIndex $fOrdParam $fShowParam $fEqParam $fShowIdent$fShowTypeBase $fEqTypeBase $fOrdTypeBase $fShowSpace $fEqSpace $fOrdSpace $fShowSubExp $fEqSubExp $fOrdSubExp$fEqCertificates$fOrdCertificates$fShowCertificates$fEqDiet $fOrdDiet $fShowDiet$fEqNoUniqueness$fOrdNoUniqueness$fShowNoUniqueness $fShowRank$fEqRank $fOrdRank$fEqExt$fOrdExt $fShowExt $fEqShapeBase$fOrdShapeBase$fShowShapeBaseIsValuevalueconstantintConst floatConst$fIsValueFloatValue$fIsValueIntValue$fIsValuePrimValue $fIsValueBool$fIsValueFloat$fIsValueDouble$fIsValueWord64$fIsValueWord32$fIsValueWord16$fIsValueWord8$fIsValueInt64$fIsValueInt32$fIsValueInt16 $fIsValueInt8 $fIsValueIntFixExtfixExtSetTypesetType DeclExtTyped declExtTypeOfExtTyped extTypeOf DeclTyped declTypeOfTypedtypeOf rankShaped arrayRank arrayShape setArrayShape existential uniquenessunique staticShapes staticShapes1arrayOf arrayOfRow arrayOfShape setArrayDims setOuterSize setDimSize setOuterDimsetDim peelArray stripArray shapeSize arrayDims arrayExtDims arraySize arraysSizerowTypeprimTypeelemType transposeType rearrangeTypediet subtypeOf subtypesOftoDeclfromDeclisExtextractShapeContext shapeContexthasStaticShapegeneraliseExtTypesexistentialiseExtTypes shapeMappingshapeExtMappingint8int16int32int64float32float64 $fTyped(,)$fTypedPatElemT $fTypedParam $fTypedIdent$fTypedTypeBase$fTypedTypeBase0$fDeclTypedParam$fDeclTypedTypeBase$fSetTypePatElemT $fSetType(,)$fSetTypeTypeBase $fFixExt() $fFixExtExt $fFixExt[]$fFixExtShapeBase$fFixExtTypeBase$fDeclExtTypedTypeBase$fExtTypedTypeBase IsRetType primRetType applyRetType IsBodyType primBodyType expectedTypes$fIsBodyTypeTypeBase$fIsRetTypeTypeBase DecorationsLetDecExpDecBodyDec FParamInfo LParamInfoRetType BranchTypeOpProg progConstsprogFunsEntryPointType TypeUnsigned TypeOpaque TypeDirect EntryPointFunDeffunDefEntryPoint funDefAttrs funDefName funDefRetType funDefParams funDefBodyLParamFParamLambdaLambdaT lambdaParams lambdaBodylambdaReturnTypeExpIfSortIfNormal IfFallbackIfEquivIfDec ifReturnsifSortLoopFormForLoop WhileLoopExpTBasicOpApplyIfDoLoopOpaqueArrayLitAssertIndexUpdateConcatCopyManifestIota ReplicateScratchReshape RearrangeRotate ShapeChange DimChange DimCoercionDimNewBodyBodyTbodyDecbodyStms bodyResultResultStmsStmLet stmPatternstmAuxstmExpStmAux stmAuxCerts stmAuxAttrs stmAuxDecPatternPatternTpatternContextElementspatternValueElementsAttrsunAttrsAttrAttrAtomAttrComponeAttrinAttrs withoutAttrsoneStm stmsFromList stmsToListstmsHead$fIsStringAttr$fTraversablePatternT$fFoldablePatternT$fFunctorPatternT$fMonoidPatternT$fSemigroupPatternT$fSemigroupStmAux$fTraversableDimChange$fFoldableDimChange$fFunctorDimChange $fEqDimChange$fEqProg $fOrdProg $fShowProg$fEqEntryPointType$fShowEntryPointType$fOrdEntryPointType $fEqIfDec $fShowIfDec $fOrdIfDec $fEqIfSort $fShowIfSort $fOrdIfSort $fEqBasicOp $fOrdBasicOp $fShowBasicOp$fOrdDimChange$fShowDimChange $fOrdStmAux $fShowStmAux $fEqStmAux $fOrdPatternT$fShowPatternT $fEqPatternT $fOrdAttrs $fShowAttrs $fEqAttrs $fMonoidAttrs$fSemigroupAttrs $fOrdAttr $fShowAttr$fEqAttr $fOrdFunDef $fShowFunDef $fEqFunDef $fOrdLambdaT $fShowLambdaT $fEqLambdaT $fOrdLoopForm$fShowLoopForm $fEqLoopForm $fOrdExpT $fShowExpT$fEqExpT $fEqBodyT $fShowBodyT $fOrdBodyT$fEqStm $fShowStm$fOrdStmnewDimnewDimsnewShape shapeCoerce reshapeOuter reshapeInner shapeCoercion fuseReshape informReshape reshapeIndexunflattenIndex flattenIndex sliceSizes paramType paramDeclType paramIdent patElemIdent patElemTypesetPatElemLorepatternElements patternIdentspatternContextIdentspatternValueIdents patternNamespatternContextNamespatternValueNames patternTypespatternValueTypes patternSize basicPattern PrettyLore ppExpLore PrettyAnnotppAnnotppTuple'$fPrettyDimIndex$fPrettyDimChange$fPrettyErrorMsg$fPrettyBasicOp $fPrettyParam$fPrettyParam0$fPrettyParam1$fPrettyPatElemT$fPrettyPatElemT0$fPrettyPatternT $fPrettyAttr$fPrettyCertificates$fPrettySubExp $fPrettyIdent$fPrettyTypeBase$fPrettyTypeBase0$fPrettyTypeBase1 $fPrettySpace$fPrettyShapeBase $fPrettyExt$fPrettyShapeBase0$fPrettyCommutativity$fPrettyNoUniqueness $fPrettyVName$fPrettyAnnot()$fPrettyAnnotParam$fPrettyAnnotPatElemT $fPrettyProg$fPrettyFunDef$fPrettyLambdaT $fPrettyExpT $fPrettyStm $fPrettyBodyT $fPrettySeq ExtendedScope SameScopeScopedscopeOf LocalScope localScopeHasScope lookupType lookupInfoaskScope asksScopeScopeNameInfoLetName FParamName LParamName IndexName inScopeOfscopeOfPatternscopeOfPatElemscopeOfLParamsscopeOfFParams castScope extendedScope$fTypedNameInfo$fHasScopeloreRWST$fHasScopeloreRWST0$fHasScopeloreExceptT$fHasScopeloreReaderT$fLocalScopeloreRWST$fLocalScopeloreRWST0$fLocalScopeloreReaderT$fLocalScopeloreExceptT$fScopedloreLambdaT$fScopedloreLoopForm$fScopedlore(,)$fScopedloreFunDef$fScopedloreStm$fScopedloreSeq$fScopedlore[]$fHasScopeloreExtendedScope$fFunctorExtendedScope$fApplicativeExtendedScope$fMonadExtendedScope$fMonadReaderMapExtendedScope$fShowNameInfoWalker walkOnSubExp walkOnBody walkOnVName walkOnRetTypewalkOnBranchType walkOnFParam walkOnLParamwalkOnOpMapper mapOnSubExp mapOnBody mapOnVName mapOnRetTypemapOnBranchType mapOnFParam mapOnLParammapOnOpidentityMappermapExpMmapExp mapOnTypeidentityWalkerwalkExpMTypedOpopType subExpTypemapType primOpType expExtTypeexpExtTypeSize$fHasScopeloreFeelBad$fApplicativeFeelBad$fFunctorFeelBad $fTypedOp()FreeDec precomputedFreeInfreeIn'FVNames namesIntMapnameIn namesFromList namesToListoneNamenamesIntersectionnamesIntersect namesSubtractmapNamesfvBindfvNamefvNamesfreeInStmsAndResfreeIn boundInBody boundByStm boundByStms boundByLambda $fPrettyNames $fMonoidNames$fSemigroupNames $fOrdNames $fSemigroupFV $fMonoidFV $fFreeInIfDec$fFreeInStmAux $fFreeInAttrs$fFreeInCertificates$fFreeInPatternT$fFreeInDimIndex$fFreeInDimChange$fFreeInLoopForm$fFreeInPatElemT $fFreeInParam$fFreeInTypeBase $fFreeInExt$fFreeInShapeBase $fFreeInSpace$fFreeInSubExp $fFreeInIdent $fFreeInVName $fFreeInMaybe $fFreeInBool $fFreeInNames $fFreeInSeq $fFreeIn[] $fFreeIn(,,) $fFreeIn(,) $fFreeInInt $fFreeIn() $fFreeInFV$fFreeDecNames$fFreeDecMaybe $fFreeDec[] $fFreeDec(,) $fFreeDec() $fFreeInStm $fFreeInExpT $fFreeInBodyT$fFreeInLambdaT$fFreeInFunDef $fEqNames $fShowNamesPrimExpLeafExpValueExpBinOpExpCmpOpExpUnOpExp ConvOpExpFunExpprimExpSizeAtLeastconstFoldPrimExp.&&..||..<..<=..==..>..>=..&..|..^. evalPrimExp primExpTypecoerceIntPrimExptruefalse leafExpTypes$fPrettyPrimExp$fIntegralExpPrimExp$fFractionalPrimExp $fNumPrimExp$fFreeInPrimExp$fTraversablePrimExp$fFoldablePrimExp$fFunctorPrimExp $fEqPrimExp $fOrdPrimExp $fShowPrimExp Substitutable SubstitutesubstituteNames Substitutions$fSubstituteFV$fSubstitutePrimExp$fSubstituteDimIndex$fSubstituteDimChange$fSubstituteIdent$fSubstituteTypeBase$fSubstituteNames$fSubstituteExt$fSubstituteShapeBase$fSubstitute()$fSubstituteRank$fSubstituteCertificates$fSubstitutePatternT$fSubstituteParam$fSubstituteStmAux$fSubstituteAttrs$fSubstitutePatElemT$fSubstituteSubExp$fSubstituteVName$fSubstituteBool$fSubstituteMaybe$fSubstitute(,,,)$fSubstitute(,,)$fSubstitute(,)$fSubstituteSeq$fSubstitute[]$fSubstituteNameInfo$fSubstituteLambdaT$fSubstituteBodyT$fSubstituteStm$fSubstituteExpT SizeHeuristic platformName deviceType heuristicSizeheuristicValue WhichSize LockstepWidth NumGroups GroupSizeTileSize Threshold DeviceInfo DeviceType DeviceCPU DeviceGPUsizeHeuristicsTable$fPrettyDeviceInfoleastGeneralGeneralization NumThreadsCountunCount SizeClass SizeThreshold SizeGroup SizeNumGroupsSizeTileSizeLocalMemory SizeBespoke KernelPath$fPrettySizeClass$fTraversableCount$fFoldableCount$fFunctorCount $fEqCount $fOrdCount $fShowCount $fNumCount$fIntegralExpCount $fFreeInCount $fPrettyCount$fSubstituteCount $fEqSizeClass$fOrdSizeClass$fShowSizeClass VNameSourcenewNameblankNameSource newNameSource$fMonoidVNameSource$fSemigroupVNameSource$fLiftLiftedRepVNameSource$fEqVNameSource$fOrdVNameSourceMonadFreshNames getNameSource putNameSourcemodifyNameSourcenewNameFromStringnewVNamenewIdent newIdent'newParam$fMonadFreshNamesExceptT$fMonadFreshNamesMaybeT$fMonadFreshNamesWriterT$fMonadFreshNamesWriterT0$fMonadFreshNamesReaderT$fMonadFreshNamesRWST$fMonadFreshNamesRWST0$fMonadFreshNamesStateT$fMonadFreshNamesStateT0 RenameableRenamerenameRenameM renameProg renameExp renameStm renameBody renameLambda renamePatternsubstituteRename renamingStms$fRenameDimIndex $fRename() $fRenameExt$fRenameShapeBase $fRenameRank $fRenameNames$fRenameTypeBase$fRenameStmAux $fRenameAttrs$fRenameCertificates$fRenamePatElemT$fRenamePatternT $fRenameParam$fRenameSubExp $fRenameIdent $fRenameBool $fRenameMaybe $fRename(,,) $fRename(,) $fRename[] $fRenameVName$fRenameLambdaT $fRenameExpT $fRenameStm $fRenameBodyT$fRenameFunDef$fFunctorRenameM$fApplicativeRenameM$fMonadRenameM$fMonadFreshNamesRenameM$fMonadReaderRenameEnvRenameMASTLoreexpTypesFromPatternIsOpsafeOpcheapOpASTConstraintsisBuiltInFunctionbuiltInFunctions asBasicOpsafeExp subExpVars subExpVar shapeVarscommutativeLambdaentryPointSizedefAuxstmCertscertifyexpExtTypesFromPatternattrsForAssert$fIsOp() CanBeAliased OpWithAliasesremoveOpAliases addOpAliases AliasedOp opAliases consumedInOp AliasesOf aliasesOfAliased bodyAliasesconsumedInBody subExpAliases expAliases consumedInStm consumedInExpconsumedByLambdapatternAliases$fAliasesOfPatElemT$fAliasesOfNames $fAliasedOp()$fCanBeAliased()Usages UsageTablewithoutlookupusedexpand isConsumed isInResultisUsedDirectlyisSizeusagesusage consumedUsage inResultUsage sizeUsage sizeUsages usageInStm$fMonoidUsages$fSemigroupUsages$fMonoidUsageTable$fSemigroupUsageTable$fEqUsageTable$fShowUsageTable $fEqUsages $fOrdUsages $fShowUsages RephraserrephraseExpLorerephraseLetBoundLorerephraseFParamLorerephraseLParamLorerephraseBodyLorerephraseRetTyperephraseBranchType rephraseOp rephraseProgrephraseFunDef rephraseExp rephraseStmrephrasePatternrephrasePatElem rephraseBodyrephraseLambdaMetricsM OpMetrics opMetrics AstMetricsseeninside progMetrics stmMetrics lambdaMetrics$fReadAstMetrics$fShowAstMetrics$fMonoidCountMetrics$fSemigroupCountMetrics $fOpMetrics()$fMonadMetricsM$fApplicativeMetricsM$fFunctorMetricsM!$fMonadWriterCountMetricsMetricsM DependenciesdataDependenciesfindNecessaryForReturnedPasspassNamepassDescription passFunctionPassMrunPassM liftEither liftEitherMpassLongOptionparPass'intraproceduralTransformationWithConstsintraproceduralTransformation$fMonadFreshNamesPassM$fMonadLoggerPassM$fFunctorPassM$fApplicativePassM $fMonadPassM MonadBinderLore mkExpDecMmkBodyM mkLetNamesMaddStmaddStms collectStms certifyingBindablemkExpPatmkExpDecmkBody mkLetNames attributingauxingletBindmkLetmkLet' letBindNames collectStms_bodyBind insertStms insertStmBinderBinderT BinderOps mkExpDecBmkBodyB mkLetNamesB runBinderT runBinderT_ runBinderT' runBinderT'_ runBinder runBinder_ runBodyBinder$fMonadErroreBinderT$fMonadWriterwBinderT$fMonadStatesBinderT$fMonadReaderrBinderT$fMonadBinderBinderT$fLocalScopeloreBinderT$fHasScopeloreBinderT$fMonadFreshNamesBinderT$fMonadTransBinderT$fFunctorBinderT$fMonadBinderT$fApplicativeBinderTAliasesAndConsumed BodyAliasing ConsumedInExp VarAliasesAliasDec unAliasesAliasesremoveScopeAliasesremoveProgAliasesremoveFunDefAliasesremoveExpAliasesremoveStmAliasesremoveLambdaAliasesremovePatternAliasesaddAliasesToPattern mkAliasedBodymkPatternAliases mkBodyAliasesconsumedInStms trackAliasesmkAliasedLetStm$fBinderOpsAliases$fASTLoreAliases$fBindableAliases$fPrettyLoreAliases$fAliasedAliases$fFreeDecAliasDec$fPrettyAliasDec$fFreeInAliasDec$fSubstituteAliasDec$fRenameAliasDec $fOrdAliasDec $fEqAliasDec$fMonoidAliasDec$fSemigroupAliasDec$fAliasesOf(,)$fDecorationsAliases$fShowAliasDec CanBeWise OpWithWisdomremoveOpWisdom ExpWisdom VarWisdomvarWisdomAliasesWiseremoveScopeWisdomaddScopeWisdomremoveFunDefWisdomremoveStmWisdomremoveLambdaWisdomremoveBodyWisdomremoveExpWisdomremovePatternWisdomaddWisdomToPattern mkWiseBody mkWiseLetStm mkWiseExpDec$fFreeInVarWisdom$fSubstituteVarWisdom$fRenameVarWisdom$fRenameExpWisdom$fSubstituteExpWisdom$fFreeDecExpWisdom$fFreeInExpWisdom$fFreeDecBodyWisdom$fFreeInBodyWisdom$fSubstituteBodyWisdom$fRenameBodyWisdom $fCanBeWise()$fBindableWise $fAliasedWise$fPrettyLoreWise $fASTLoreWise$fDecorationsWise$fEqBodyWisdom$fOrdBodyWisdom$fShowBodyWisdom $fEqExpWisdom$fOrdExpWisdom$fShowExpWisdom $fEqVarWisdom$fOrdVarWisdom$fShowVarWisdom AliasTable aliasAnalysis analyseFun analyseBody analyseStms analyseExp analyseLambdaToExptoExp letSubExpletExp letInPlace letSubExps letTupExp letTupExp'eSubExpeIfeIf'eBinOpeCmpOpeConvOpeNoteSignumeCopyeAsserteBodyeLambdaeRoundToMultipleOf eSliceArray eOutOfBounds eWriteArrayeBlankasIntSasIntZ foldBinOpeAll binOpLambda cmpOpLambdasliceDim fullSlicesliceAt fullSliceNum isFullSliceifCommon resultBody resultBodyM insertStmsM mapResultinstantiateShapesinstantiateShapes'removeExistentialssimpleMkLetNamestoSubExp $fToExpVName $fToExpSubExp Checkable checkExpLore checkBodyLorecheckFParamLorecheckLParamLorecheckLetBoundLore checkRetType matchPattern primFParammatchReturnTypematchBranchTypematchLoopResult CheckableOpcheckOpTypeM TypeError ErrorCaseUnexpectedTypeReturnTypeErrorDupDefinitionError DupParamErrorDupPatternErrorInvalidPatternErrorUnknownVariableErrorUnknownFunctionErrorParameterMismatch SlicingError BadAnnotation ReturnAliasedUniqueReturnAliased NotAnArrayPermutationErrorbadcontextmessageconsume checkOpWithconsumeOnlyParamsbinding lookupVar lookupAliasesrequirerequireI checkProg checkSubExp checkStms checkBodycheckExpcheckSOACArrayArgs checkType checkExtTypecheckStmmatchExtPatternmatchExtBranchTypeargType argAliases noArgAliasescheckArg checkLambdarequirePrimExp$fMonoidConsumption$fSemigroupConsumption$fHasScopeAliasesTypeM$fShowTypeError$fShowErrorCase $fMonadTypeM$fFunctorTypeM$fApplicativeTypeM$fMonadReaderEnvTypeM$fMonadWriterConsumptionTypeM$fMonadStateNamesTypeM$fShowConsumption $fEqOccurence$fShowOccurence $fEqUsage $fOrdUsage $fShowUsagePipelinePipelineConfigpipelineVerbosepipelineValidateAction actionNameactionDescriptionactionProcedureFutharkM Verbosity NotVerboseVerbose VeryVerbose runFutharkM runPipelineonePasspasses$fMonadLoggerFutharkM$fMonadFreshNamesFutharkM$fCategoryTYPEPipeline$fApplicativeFutharkM$fFunctorFutharkM$fMonadFutharkM!$fMonadErrorCompilerErrorFutharkM $fMonadStateFutharkStateFutharkM$fMonadReaderFutharkEnvFutharkM$fMonadIOFutharkM $fEqVerbosity$fOrdVerbosityIndexSubstitutionsIndexSubstitutionsubstituteIndicesprimExpFromExpprimExpFromSubExpMprimExpFromSubExpreplaceInPrimExpMreplaceInPrimExpsubstituteInPrimExp primExpSlice subExpSlice$fToExpPrimExpIxFun ixfunLMADs ixfunContigsubstituteInIxFunisDirectshapeindexiotapermuterotateslicereshaperankrebaselinearWithOffsetrearrangeWithOffsetisLinearexistentialize closeEnough$fPrettyMonotonicity$fTraversableLMAD$fFoldableLMAD $fFunctorLMAD $fFreeInLMAD $fRenameLMAD$fSubstituteLMAD $fPrettyLMAD$fTraversableIxFun$fFoldableIxFun$fFunctorIxFun $fFreeInIxFun $fRenameIxFun$fSubstituteIxFun $fPrettyIxFun $fShowIxFun $fEqIxFun $fShowLMAD$fEqLMAD $fShowLMADDim $fEqLMADDim$fShowMonotonicity$fEqMonotonicityIndexOpindexOp entryDepth entryIsSizeIndexed IndexedArray SymbolTable loopDepthbindingsavailableAtClosestLoopsimplifyMemory fromScopetoScopedeepenindexedAddCertsentryLetBoundDecelem lookupStm lookupExp lookupBasicOp lookupSubExp lookupLoopVar availableindex' insertFParams insertLParam insertLoopVar hideCertified$fFreeInIndexed $fTypedEntry$fMonoidSymbolTable$fSemigroupSymbolTable $fIndexOp()RuleBook BottomUpRuleBottomUpRuleOpBottomUpRuleDoLoopBottomUpRuleIfBottomUpRuleBasicOpBottomUpRuleGenericBottomUp TopDownRule TopDownRuleOpTopDownRuleDoLoop TopDownRuleIfTopDownRuleBasicOpTopDownRuleGenericTopDownSimplificationRule RuleGeneric RuleBasicOpRuleIf RuleDoLoopRuleOpRuleSimplifySkipRuleMcannotSimplify liftMayberuleBooktopDownSimplifyStmbottomUpSimplifyStm$fMonadBinderRuleM $fMonoidRules$fSemigroupRules$fMonoidRuleBook$fSemigroupRuleBook$fFunctorRuleM$fApplicativeRuleM $fMonadRuleM$fMonadFreshNamesRuleM$fHasScopeloreRuleM$fLocalScopeloreRuleM VarLookupfoldClosedFormloopClosedForm standardRulesremoveUnnecessaryCopy SimplifiablesimplifySimplifiableLoreSimplifiedBody BlockPredSimpleM SimplifyOp SimpleOps mkExpDecSmkBodySprotectHoistedOpSopUsageS simplifyOpSEnvenvRulesenvHoistBlockers HoistBlockers blockHoistPar blockHoistSeqblockHoistBranch isAllocationnoExtraHoistBlockers neverHoistemptyEnvbindableSimpleOps runSimpleM asksEngineEnv askVtable localVtable bindLParams hoistStms neverBlocksisFalseorIfisOpblockIfhasFree isNotSafe simplifyBody simplifyStmssimplifyLambdasimplifyLambdaNoHoisting simplifyFun$fMonadFreshNamesSimpleM$fSimplifiableCertificates$fSimplifiableDimIndex$fSimplifiableTypeBase$fSimplifiableSpace$fSimplifiableExt$fSimplifiableShapeBase$fSimplifiableVName$fSimplifiable()$fSimplifiableSubExp$fSimplifiable[]$fSimplifiableMaybe$fSimplifiableInt$fSimplifiable(,,)$fSimplifiable(,)$fLocalScopeWiseSimpleM$fHasScopeWiseSimpleM$fApplicativeSimpleM$fFunctorSimpleM$fMonadSimpleM$fMonadReader(,)SimpleM$fMonadState(,,)SimpleMsimplifyPrimExpsimplifyExtPrimExp simplifyProgsimplifySomethingcopyPropagateInProgcopyPropagateInStmscopyPropagateInFunSeq$fBinderOpsWise$fPrettyLoreSeq$fBinderOpsSeq $fBindableSeq$fCheckableSeq$fCheckableOpSeq $fASTLoreSeq$fDecorationsSeq SOACMappermapOnSOACSubExpmapOnSOACLambdamapOnSOACVNameReduceredComm redLambda redNeutralScan scanLambda scanNeutral ScremaForm StreamFormParallel Sequential StreamOrdInOrderDisorderHistOp histWidthhistRaceFactorhistDest histNeutralhistOpSOACStreamScatterHistScrema scanResults singleScan redResults singleReduce scremaTypemkIdentityLambdaisIdentityLambdanilFn scanomapSOAC redomapSOACscanSOAC reduceSOACmapSOACisScanomapSOAC isScanSOAC isRedomapSOAC isReduceSOAC isMapSOACidentitySOACMappermapSOACMsoacType typeCheckSOACgetStreamAccumsppScremappHist $fPrettyScan$fPrettyReduce $fPrettySOAC$fOpMetricsSOAC $fIndexOpSOAC $fIsOpSOAC$fAliasedOpSOAC $fTypedOpSOAC$fCanBeWiseSOAC$fCanBeAliasedSOAC $fRenameSOAC$fSubstituteSOAC $fFreeInSOAC$fEqSOAC $fOrdSOAC $fShowSOAC$fEqScremaForm$fOrdScremaForm$fShowScremaForm $fEqReduce $fOrdReduce $fShowReduce$fEqScan $fOrdScan $fShowScan$fEqStreamForm$fOrdStreamForm$fShowStreamForm $fEqStreamOrd$fOrdStreamOrd$fShowStreamOrd $fEqHistOp $fOrdHistOp $fShowHistOpredomapToMapAndReduce dissectScremasequentialStreamWholeArraypartitionChunkedFoldParametersSOACS$fPrettyLoreSOACS$fBinderOpsSOACS$fBindableSOACS$fCheckableSOACS$fCheckableOpSOACS$fASTLoreSOACS$fDecorationsSOACS TransformerFirstOrderLoretransformFunDeftransformConststransformStmRecursively transformSOACtransformLambdafirstOrderTransformiswimirwim rwimPossibleInternaliseTypeMDimTable InternaliseMInternaliseEnv envSubstsenvDoBoundsChecksenvSafeenvAttrsVarSubstitutionsFunInfoClosurerunInternaliseMsubstitutingVars lookupSubst addFunDeflookupFunction'lookupFunction lookupConst allConsts bindFunction bindConstantlocalConstsScopeassertliftInternaliseMrunInternaliseTypeMwithDims lookupDim$fMonoidInternaliseResult$fSemigroupInternaliseResult$fMonadBinderInternaliseM$fFunctorInternaliseTypeM$fApplicativeInternaliseTypeM$fMonadInternaliseTypeM$$fMonadReaderTypeEnvInternaliseTypeM$fMonadStateIntInternaliseTypeM$fFunctorInternaliseM$fApplicativeInternaliseM$fMonadInternaliseM'$fMonadReaderInternaliseEnvInternaliseM($fMonadStateInternaliseStateInternaliseM$fMonadFreshNamesInternaliseM$fHasScopeSOACSInternaliseM$fLocalScopeSOACSInternaliseM argShapesensureResultShapeensureResultExtShapeensureExtShape ensureShapeensureArgShapesHasSOACasSOACsoacOp simpleSOACS simplifySOACSsimplifyConsts simplifySOAC soacRulesliftIdentityMappingremoveReplicateMappingsimplifyKnownIterationSOAC $fHasSOACWise $fEqArrayOp $fOrdArrayOp $fShowArrayOp CallGraphisFunInCallGraphcallscalledByConsts allCalledBybuildCallGraphfindNoninlined OpReturns opReturns FunReturns BodyReturns ExpReturns MemReturnReturnsInBlockReturnsNewBlockMemBindArrayInMemBoundMemInfoMemPrimMemMemMemArrayExtIxFunMemOpAllocInnerAllocOpallocOp BranchTypeMem RetTypeMem LParamMem FParamMem LetDecMem isStaticIxFunexistentialiseIxFunnoUniquenessReturnsbodyReturnsToExpReturnsmatchFunctionReturnTypematchLoopResultMemmatchBranchReturnTypematchPatternToExp lookupMemInfo subExpMemInfolookupArraySummary checkMemInfobodyReturnsFromPattern extReturns varReturns expReturns$fIndexOpMemOp$fCanBeWiseMemOp $fIsOpMemOp$fOpMetricsMemOp $fPrettyMemOp$fSubstituteMemOp $fRenameMemOp$fCanBeAliasedMemOp$fAliasedOpMemOp$fTypedOpMemOp $fFreeInMemOp$fAllocOpMemOp$fPrettyMemInfo$fSimplifiableMemInfo$fRenameMemInfo$fSubstituteMemInfo$fFreeInMemInfo$fDeclTypedMemInfo$fTypedMemInfo$fTypedMemInfo0$fFixExtMemInfo$fExtTypedMemInfo$fDeclExtTypedMemInfo$fSimplifiableMemBind$fFreeInMemBind$fPrettyMemBind$fSubstituteMemBind$fRenameMemBind $fOrdMemBind $fEqMemBind$fSimplifiableMemReturn$fFreeInMemReturn$fPrettyMemReturn$fFixExtMemReturn$fSubstituteMemReturn$fRenameMemReturn$fOrdMemReturn $fEqMemReturn$fIsBodyTypeMemInfo$fIsRetTypeMemInfo$fShowMemReturn $fShowMemBind $fEqMemInfo $fShowMemInfo $fOrdMemInfo $fEqMemOp $fOrdMemOp $fShowMemOpExpHintNoHintHint SizeSubst opSizeSubst opIsConstAllocMAllocEnvchunkMapaggressiveReuse allocSpace envConsts allocInOp envExpHints Allocable Allocator addAllocStmaskDefaultSpacedimAllocationSize askConstsexpHintsarraySizeInBytesExp allocForArrayexplicitAllocationsGeneric explicitAllocationsInStmsGeneric allocInStms mkLetNamesB' mkLetNamesB'' simplifiabledefaultExpHints$fSizeSubstMemOp $fSizeSubst()$fAllocatorlorePatAllocM$fAllocatortoloreAllocM$fMonadBinderAllocM$fApplicativeAllocM$fFunctorAllocM $fMonadAllocM$fMonadFreshNamesAllocM$fHasScopetoloreAllocM$fLocalScopetoloreAllocM$fMonadReaderAllocEnvAllocM$fApplicativePatAllocM$fFunctorPatAllocM$fMonadPatAllocM$fHasScopelorePatAllocM$fMonadWriter[]PatAllocM$fMonadFreshNamesPatAllocM $fEqAllocStm $fOrdAllocStm$fShowAllocStmHasSegOp SegOpLevelasSegOpsegOp SegOpMappermapOnSegOpSubExpmapOnSegOpLambdamapOnSegOpBodymapOnSegOpVNamemapOnSegOpLevelSegOpSegMapSegRedSegScanSegHistSegSpacesegFlat unSegSpaceSegVirt SegNoVirt SegNoVirtFull KernelResultReturns WriteReturns ConcatReturns TileReturnsResultManifestResultNoSimplifyResultMaySimplify ResultPrivate KernelBodykernelBodyLorekernelBodyStmskernelBodyResultSegBinOp segBinOpCommsegBinOpLambdasegBinOpNeutral segBinOpShape histShape SplitOrderingSplitContiguous SplitStridedhistTypesegBinOpResultssegBinOpChunkskernelResultSubExpaliasAnalyseKernelBodyconsumedInKernelBody segSpaceDimsscopeOfSegSpacesegLevelsegSpacetypeCheckSegOpidentitySegOpMapper mapSegOpM simplifySegOp segOpRules segOpReturns$fSimplifiableSplitOrdering$fRenameSplitOrdering$fSubstituteSplitOrdering$fFreeInSplitOrdering$fPrettySegBinOp$fSimplifiableKernelResult$fPrettyKernelResult$fRenameKernelResult$fSubstituteKernelResult$fFreeInKernelResult$fPrettyKernelBody$fRenameKernelBody$fSubstituteKernelBody$fFreeInKernelBody$fSimplifiableSegSpace$fPrettySegSpace $fIsOpSegOp$fIndexOpSegOp $fPrettySegOp$fOpMetricsSegOp$fAliasedOpSegOp$fTypedOpSegOp$fCanBeWiseSegOp$fCanBeAliasedSegOp $fFreeInSegOp $fRenameSegOp$fSubstituteSegOp $fEqSegOp $fOrdSegOp $fShowSegOp $fEqSegSpace $fOrdSegSpace$fShowSegSpace $fEqSegVirt $fOrdSegVirt $fShowSegVirt$fEqKernelResult$fShowKernelResult$fOrdKernelResult$fEqResultManifest$fShowResultManifest$fOrdResultManifest $fEqSegBinOp $fOrdSegBinOp$fShowSegBinOp$fEqSplitOrdering$fOrdSplitOrdering$fShowSplitOrdering$fEqKernelBody$fShowKernelBody$fOrdKernelBody KernelInputkernelInputNamekernelInputTypekernelInputArraykernelInputIndices MkSegLevelThreadRecommendation ManyThreadsNoRecommendationDistLore mkSegSpacesegRedsegScansegMapdummyDim nonSegRedsegHist mapKernelreadKernelInput$fShowKernelInput KernelNestNestingsNestingnestingLetBound nestingLoop LoopNesting MapNestingloopNestingPatternloopNestingAuxloopNestingWidthloopNestingParamsAndArrsTargetsTarget ppTargets singleTarget outerTarget innerTargetpushInnerTargetpopInnerTarget targetsScopescopeOfLoopNesting ppLoopNesting ppNestings singleNestingpushInnerNestingletBindInInnerNesting ppKernelNestinnermostKernelNestingpushKernelNestingpushInnerKernelNesting newKernelkernelNestLoopsboundInKernelNestboundInKernelNestskernelNestWidthsconstructKernel flatKernel tryDistributetryDistributeStm$fFreeInLoopNesting $fShowNesting$fShowLoopNestingBranchSeqLoopinterchangeLoopsinterchangeBranch DistNestTDistAcc distTargetsdistStmsDistEnvdistNest distScopedistOnTopLevelStmsdistOnInnerMapdistOnSOACSStmsdistOnSOACSLambda distSegLevelMapLoop mapLoopStm addStmsToAcc addStmToAcc runDistNestT addPostStmspostStm inNestingbodyContainsParallelismlambdaContainsParallelismdistributeMapBodyStms distributedistributeSingleStm histKerneldetermineReduceOppermutationAndMissing distributeMap$fMonoidPostStms$fSemigroupPostStms$fMonoidDistRes$fSemigroupDistRes$fMonadLoggerDistNestT$fLocalScopeloreDistNestT$fHasScopeloreDistNestT$fMonadFreshNamesDistNestT$fMonadTransDistNestT$fFunctorDistNestT$fApplicativeDistNestT$fMonadDistNestT$fMonadReaderDistEnvDistNestT$fMonadWriterDistResDistNestTSimplifyMemory simpleGenericsimplifyProgGenericsimplifyStmsGenericHostOpSizeOpOtherOp SplitSpaceGetSize GetSizeMax CmpSizeLe CalcNumGroupsSegLevel SegThreadSegGroup segNumGroups segGroupSizesegVirttypeCheckHostOp$fFreeInSegLevel$fRenameSegLevel$fSubstituteSegLevel$fSimplifiableSegLevel$fPrettySegLevel$fOpMetricsSizeOp$fPrettySizeOp$fFreeInSizeOp$fAliasedOpSizeOp$fTypedOpSizeOp $fIsOpSizeOp$fRenameSizeOp$fSubstituteSizeOp$fOpMetricsHostOp$fPrettyHostOp$fIndexOpHostOp$fCanBeWiseHostOp$fCanBeAliasedHostOp$fFreeInHostOp$fAliasedOpHostOp$fTypedOpHostOp $fIsOpHostOp$fRenameHostOp$fSubstituteHostOp $fEqHostOp $fOrdHostOp $fShowHostOp $fEqSizeOp $fOrdSizeOp $fShowSizeOp $fEqSegLevel $fOrdSegLevel$fShowSegLevelCSEInOp performCSEperformCSEOnFunDefperformCSEOnStms $fCSEInOpSOAC$fCSEInOpMemOp$fCSEInOpSegOp$fCSEInOpHostOp $fCSEInOp()inlineFunctionsremoveDeadFunctionsSeqMem simpleSeqMem$fBinderOpsSeqMem$fCheckableSeqMem$fCheckableOpSeqMem$fPrettyLoreSeqMem$fOpReturnsSeqMem$fASTLoreSeqMem$fDecorationsSeqMemexplicitAllocationsKernels$fHasSegOpKernels$fPrettyLoreKernels$fBinderOpsKernels$fBindableKernels$fCheckableKernels$fCheckableOpKernels$fASTLoreKernels$fDecorationsKernelsbabysitKernelsgetSize segThreadsoacsStmToKernelssoacsLambdaToKernels scopeForSOACsscopeForKernels streamRed streamMapsegThreadCapped$fEqKernelSize$fOrdKernelSize$fShowKernelSizeintraGroupParallelise $fMonoidAcc$fSemigroupAcc$fMonadLoggerBinderTextractKernels$fMonadFreshNamesDistribM$fFunctorDistribM$fApplicativeDistribM$fMonadDistribM$fHasScopeKernelsDistribM$fLocalScopeKernelsDistribM$fMonadStateStateDistribM$fMonadLoggerDistribM tileLoops$fMonoidPrivStms$fSemigroupPrivStmssink LowerUpdate DesiredUpdate updateName updateTypeupdateCertificates updateSource updateIndices updateValue lowerUpdatelowerUpdateKernels$fFunctorDesiredUpdate$fShowLoopResultSummary$fShowDesiredUpdateinPlaceLoweringKernelsinPlaceLoweringSeq$fMonoidBottomUp$fSemigroupBottomUp$fHasScopeAliasesForwardingM$fMonadFreshNamesForwardingM$fMonadForwardingM$fApplicativeForwardingM$fFunctorForwardingM$fMonadReaderTopDownForwardingM $fMonadWriterBottomUpForwardingM"$fMonadStateVNameSourceForwardingMsimplifyKernelssimplifyKernelOp$fHasSegOpWiseunstream KernelsMemsimpleKernelsMem$fBinderOpsKernelsMem$fCheckableKernelsMem$fCheckableOpKernelsMem$fPrettyLoreKernelsMem$fOpReturnsKernelsMem$fASTLoreKernelsMem$fDecorationsKernelsMem simplifySeqsimplifyKernelsMemsimplifySeqMemallocInKernelBodyallocInBinOpLambdaexplicitAllocationsInStms$fSizeSubstSegOp$fSizeSubstHostOpexpandAllocations$fApplicativeOffsetM$fFunctorOffsetM$fMonadOffsetM$fHasScopeKernelsMemOffsetM$fLocalScopeKernelsMemOffsetM$fMonadError[]OffsetM doubleBuffer#$fLocalScopeKernelsMemDoubleBufferM!$fHasScopeKernelsMemDoubleBufferM$fShowDoubleBuffer$fFunctorDoubleBufferM$fApplicativeDoubleBufferM$fMonadDoubleBufferM$fMonadReaderEnvDoubleBufferM$fMonadFreshNamesDoubleBufferMNotSOACInputViewLEmptyL:>ViewFEmptyF:<ArrayTransformsArrayTransform ReshapeOuter ReshapeInner noTransformsnullTransformsviewfviewl|><|transformFromExpvarInput identInput isVarInput isVarishInput addTransformaddInitialTransforms inputArray inputType inputRowType inputRank transformRowstransposeInputinputs setInputslambda setLambdatoSOACfromExp soacToStream$fSubstituteArrayTransform$fSubstituteArrayTransforms$fMonoidArrayTransforms$fSemigroupArrayTransforms $fPrettyInput$fSubstituteInput $fShowNotSOAC $fShowInput $fEqInput $fOrdInput$fEqArrayTransforms$fOrdArrayTransforms$fShowArrayTransforms$fShowArrayTransform$fEqArrayTransform$fOrdArrayTransformfuseMaps fuseRedomapmergeReduceOpsMapNestnestingParamNames nestingResultnestingReturnType nestingWidthparamsfromSOAC $fShowMapNest $fEqNesting $fOrdNestingFusedKerfsoacinplace fusedVars fusedConsumed kernelScopeoutputTransformoutNameskerAuxtransformOutput arrInputs attemptFusion$fShowFusedKer$fFunctorTryFusion$fApplicativeTryFusion$fAlternativeTryFusion$fMonadTryFusion$fMonadFailTryFusion$fMonadFreshNamesTryFusion$fHasScopeSOACSTryFusion$fLocalScopeSOACSTryFusion fuseSOACs $fShowError$fMonoidFusedRes$fSemigroupFusedRes$fHasScopeSOACSFusionGM$fMonadFreshNamesFusionGM$fMonadFusionGM$fApplicativeFusionGM$fFunctorFusionGM$fMonadErrorErrorFusionGM$fMonadStateVNameSourceFusionGM$fMonadReaderFusionGEnvFusionGM $fEqKernName $fOrdKernName$fShowKernNamestandardPipelinekernelsPipelinesequentialPipelinesequentialCpuPipeline gpuPipelineBytesElementsArgExpArgMemArgExpLeafSizeOf VolatilityVolatile NonvolatileCode:>>:ForWhile DeclareMem DeclareScalar DeclareArrayAllocateWrite SetScalarSetMemCall DebugPrint ArrayContents ArrayValues ArrayZerosFunction FunctionT functionEntryfunctionOutput functionInput functionBodyfunctionResult functionArgs ExternalValue OpaqueValueTransparentValue ValueDesc ArrayValue ScalarValue Signedness Constants constsDecl constsInit Functions Definitions defConstsdefFunsMemParam ScalarParamDimSizeMemSizelexicalMemoryUsage calledFuncselementsbytes withElemTypevarvi32$fPrettyValueDesc$fPrettyExternalValue$fPrettyArrayContents$fFreeInExpLeaf$fPrettyExpLeaf $fFreeInArg $fPrettyArg $fFreeInCode$fTraversableCode$fFoldableCode $fFunctorCode $fPrettyCode $fMonoidCode$fSemigroupCode$fTraversableFunctionT$fFoldableFunctionT$fFunctorFunctionT$fPrettyFunctionT$fFreeInFunctions$fTraversableFunctions$fFoldableFunctions$fFunctorFunctions$fPrettyFunctions$fMonoidFunctions$fSemigroupFunctions$fPrettyConstants$fPrettyDefinitions$fShowFunctionT $fShowCode $fShowArg $fEqExpLeaf $fShowExpLeaf$fEqVolatility$fOrdVolatility$fShowVolatility$fShowArrayContents$fShowExternalValue $fEqValueDesc$fShowValueDesc$fEqSignedness$fShowSignednesssetDefaultSpaceProgram$fFreeInSequential$fPrettySequential KernelTarget TargetOpenCL TargetCUDAOpenCL LaunchKernel KernelSafety SafetyNone SafetyCheap SafetyFull KernelArg ValueKArgMemKArgSharedMemoryKArg KernelName FailureMsg failureErrorfailureBacktrace openClProgram openClPreludeopenClKernelNamesopenClUsedTypes openClSizesopenClFailureshostDefinitionsnumFailureParams$fPrettyOpenCL$fEqKernelTarget $fShowOpenCL$fEqKernelSafety$fOrdKernelSafety$fShowKernelSafety $fShowMayFail$fShowKernelArgAtomicOp AtomicAdd AtomicFAdd AtomicSMax AtomicSMin AtomicUMax AtomicUMin AtomicAndAtomicOr AtomicXor AtomicCmpXchg AtomicXchgKernelOp GetGroupId GetLocalId GetLocalSize GetGlobalSize GetGlobalIdGetLockstepWidthAtomicBarrierMemFence LocalAlloc ErrorSyncFence FenceLocal FenceGlobal KernelUse ScalarUse MemoryUseConstUseKernel kernelBody kernelUseskernelNumGroupskernelGroupSize kernelNamekernelFailureTolerant CallKernelKernelConstExp KernelConst SizeConst KernelCode$fPrettyKernelConst$fPrettyKernelUse$fFreeInAtomicOp$fFreeInKernelOp$fPrettyKernelOp$fPrettyKernel$fFreeInKernel $fShowKernel$fShowKernelOp$fShowAtomicOp $fShowFence $fEqKernelUse$fShowKernelUse$fEqKernelConst$fOrdKernelConst$fShowKernelConst TransposeArgs TransposeTypeTransposeNormalTransposeLowWidthTransposeLowHeightTransposeSmallmapTransposeKernel$fEqTransposeType$fOrdTransposeType$fShowTransposeTypeprimTypeToCTypesignedPrimTypeToCType tupleFieldfunNamedefaultMemBlockTypecIntOps cFloat32Ops cFloat64Ops cFloatConvOps cFloat32Funs cFloat64FunsCPartscHeadercUtilscCLIcLib CompilerM OperationsopsWriteScalar opsReadScalar opsAllocate opsDeallocateopsCopyopsStaticArray opsMemoryType opsCompileropsErroropsCall opsFatMemory CallCompiler StaticArray Deallocate ReadScalar WriteScalar MemoryType PointerQuals ErrorCompiler OpCompiler HeaderSection ArrayDecl OpaqueDecl EntryDeclMiscDeclInitDecl CompilerState compUserStatedefaultOperationscontextContentscontextFinalInits runCompilerM getUserStatemodifyUserStateatInititemitems publicDef publicDef_ headerDecllibDecl earlyDecl contextField profileReportstmstmsdecl publicName contextTyperawMemcopyMemoryDefaultSpace asLibrary asExecutable compileProg cachingMemory compileFuncompilePrimValuewriteScalarPointerWithQualsreadScalarPointerWithQualscompileExpToName compileExpcompilePrimExp compileCode blockScope$fToExpPrimValue$fToExpFloatValue$fToExpIntValue$fToIdentVName $fToIdentName$fMonoidCompilerAcc$fSemigroupCompilerAcc$fMonadFreshNamesCompilerM$fFunctorCompilerM$fApplicativeCompilerM$fMonadCompilerM"$fMonadStateCompilerStateCompilerM!$fMonadReaderCompilerEnvCompilerM!$fMonadWriterCompilerAccCompilerM$fEqHeaderSection$fOrdHeaderSection kernelsToCUDAkernelsToOpenCL $fEqOpsMode failureSwitch copyDevToDev copyDevToHost copyHostToDevcopyScalarToDevcopyScalarFromDevprofilingEventgenerateBoilerplate kernelRuntime kernelRunscostCentreReport commonOptionsprofilingEnclosurePyProg PyClassDefClassPyFunDefDefPyExceptCatchPyStmtTryWithAssignAssignOpRaiseReturnImportClassDefEscapePyArg ArgKeywordPyIdxIdxRangeIdxExpPyExpIntegerFloatStringRawStringLiteralCondCastTupleListFieldDictNone $fPrettyPyExp $fPrettyPyArg $fPrettyPyIdx$fPrettyPyExcept$fPrettyPyClassDef$fPrettyPyFunDef$fPrettyPyStmt$fPrettyPyProg $fEqPyProg $fShowPyProg$fEqPyClassDef$fShowPyClassDef $fEqPyStmt $fShowPyStmt $fEqPyFunDef$fShowPyFunDef $fEqPyExcept$fShowPyExcept $fEqPyArg $fShowPyArg $fEqPyExp $fShowPyExp $fEqPyIdx $fShowPyIdx Constructor compNameSrccompInit CompilerEnv envOperations envVarExpopsEntryOutput opsEntryInput EntryInput EntryOutputcollectcollect'emptyConstructor simpleCall compileName compileDim unpackDimcompilePrimTypecompilePrimTypeExtcompilePrimToNpcompilePrimToExtNp compileVar$fMonadWriter[]CompilerM openClInitpreludeProgBaseprogDocprogDecsDecBaseValDecTypeDecSigDecModDecOpenDecLocalDec ImportDec ModParamBaseModParam modParamName modParamType modParamAbsmodParamLocation ModBindBaseModBindmodName modParams modSignaturemodExpmodDoc modLocation ModExpBaseModVar ModParens ModImportModDecsModApply ModAscript ModLambda SigBindBaseSigBindsigNamesigExpsigDocsigLoc TypeRefBaseTypeRef SigExpBaseSigVar SigParensSigSpecsSigWithSigArrowSpecBaseValSpec TypeAbbrSpecTypeSpecModSpec IncludeSpecspecNamespecTypeParamsspecTypespecDoc specLocation TypeParamBase TypeParamDim TypeParamType LiftednessUnlifted SizeLiftedLifted TypeBindBaseTypeBind typeAliastypeLiftedness typeParamstypeExptypeDoctypeBindLocation ValBindBaseValBindvalBindEntryPoint valBindNamevalBindRetDeclvalBindRetTypevalBindTypeParams valBindParams valBindBody valBindDoc valBindAttrsvalBindLocation entryParams entryReturn EntryType entryType entryAscribed DocComment PatternBase TuplePattern RecordPattern PatternParensIdWildcardPatternAscription PatternLit PatternConstr LoopFormBaseForInCaseBaseCasePat FieldBaseRecordFieldExplicitRecordFieldImplicitExpBaseLiteralIntLitFloatLit StringLitParens QualParensTupLit RecordLitRangeAscriptCoerceLetPatLetFunNegate OpSection OpSectionLeftOpSectionRightProjectSection IndexSectionProjectLetWith RecordUpdateConstrMatchQualName qualQualsqualLeaf DimIndexBase InclusivenessDownToExclusive ToInclusive UpToExclusiveBacktickPlusMinusTimesDivideModQuotRemShiftRShiftLBandBorEqualNotEqualLessLeqGreaterGeq PipeRightPipeLeft IdentBase identSrcLocValue RecordDietFuncDiet TypeDeclBaseTypeDecl declaredType expandedType TypeArgExp TypeArgExpDimTypeArgExpTypeTypeExpTEVarTETupleTERecordTEArrayTEUniqueTEApplyTEArrowTESumDimExp DimExpNamed DimExpConst DimExpAny ValueType StructType PatternTypeAliasingAlias AliasBound AliasFreealiasVarTypeArg TypeArgDim TypeArgTypeScalarScalarTypeBaseTypeVarRecordSumArrowPNameNamedUnnamedTypeName typeQualstypeLeaf ShapeDeclDimDeclNamedDimConstDimAnyDimArrayDim unifyDimsAttrInfo IsPrimValue primValue SignedValue UnsignedValueSignedUnsignedInfounInfoNoInfoShowable unifyShapestypeNameFromQualNamequalNameFromTypeName typeParamName$fTraversableNoInfo$fFoldableNoInfo$fFunctorNoInfo$fTraversableInfo$fFoldableInfo $fFunctorInfo$fIsPrimValueBool$fIsPrimValueDouble$fIsPrimValueFloat$fIsPrimValueWord64$fIsPrimValueWord32$fIsPrimValueWord16$fIsPrimValueWord8$fIsPrimValueInt64$fIsPrimValueInt32$fIsPrimValueInt16$fIsPrimValueInt8$fIsPrimValueInt $fArrayDim()$fMonoidShapeDecl$fSemigroupShapeDecl$fFunctorShapeDecl$fTraversableShapeDecl$fFoldableShapeDecl $fOrdTypeName $fEqTypeName $fOrdPName $fEqPName$fFoldableTypeArg$fFunctorTypeArg$fTraversableTypeArg$fBifoldableTypeBase$fBifunctorTypeBase$fBitraversableTypeBase$fBifoldableScalarTypeBase$fBifunctorScalarTypeBase$fBitraversableScalarTypeBase$fTraversableInclusiveness$fFoldableInclusiveness$fFunctorInclusiveness$fLocatedInclusiveness$fTraversableQualName$fFoldableQualName$fFunctorQualName $fOrdQualName$fOrdQualName0 $fEqQualName $fEqQualName0$fLocatedTypeArgExp$fLocatedTypeExp$fArrayDimDimDecl$fTraversableDimDecl$fFoldableDimDecl$fFunctorDimDecl$fLocatedTypeDeclBase$fLocatedIdentBase$fOrdIdentBase $fEqIdentBase$fLocatedDocComment$fShowableInfovn$fShowableNoInfovn$fLocatedTypeParamBase$fTraversableTypeParamBase$fFoldableTypeParamBase$fFunctorTypeParamBase$fLocatedTypeBindBase$fLocatedPatternBase$fLocatedCaseBase$fLocatedFieldBase$fLocatedExpBase$fLocatedValBindBase$fLocatedTypeRefBase$fLocatedSigExpBase$fLocatedSpecBase$fLocatedSigBindBase$fLocatedModParamBase$fLocatedDecBase$fLocatedModBindBase$fLocatedModExpBase$fEqTypeParamBase$fOrdTypeParamBase$fShowTypeParamBase$fEqLiftedness$fOrdLiftedness$fShowLiftedness$fShowEntryPoint$fShowEntryType$fShowDocComment $fShowDimDecl $fShowTypeExp$fShowTypeArgExp $fShowDimExp$fShowQualName$fEqInclusiveness$fOrdInclusiveness$fShowInclusiveness $fEnumBinOp$fBoundedBinOp $fEqValue $fShowValue $fEqAlias $fOrdAlias $fShowAlias $fEqTypeArg $fOrdTypeArg $fShowTypeArg$fEqScalarTypeBase$fOrdScalarTypeBase$fShowScalarTypeBase $fShowPName$fShowTypeName $fEqShapeDecl$fOrdShapeDecl$fShowShapeDecl $fEqAttrInfo $fOrdAttrInfo$fShowAttrInfo$fEqInfo $fOrdInfo $fShowInfo $fEqNoInfo $fOrdNoInfo $fShowNoInfo$fShowProgBase $fShowDecBase$fShowModParamBase$fShowModBindBase$fShowModExpBase$fShowSigBindBase$fShowTypeRefBase$fShowSigExpBase$fShowSpecBase$fShowTypeBindBase$fShowValBindBase$fOrdPatternBase$fEqPatternBase$fShowPatternBase$fOrdLoopFormBase$fEqLoopFormBase$fShowLoopFormBase $fOrdCaseBase $fEqCaseBase$fShowCaseBase$fOrdFieldBase $fEqFieldBase$fShowFieldBase $fOrdExpBase $fEqExpBase $fShowExpBase$fOrdDimIndexBase$fEqDimIndexBase$fShowDimIndexBase$fShowIdentBase$fOrdTypeDeclBase$fEqTypeDeclBase$fShowTypeDeclBase$fOrdTypeArgExp$fOrdTypeArgExp0$fEqTypeArgExp$fEqTypeArgExp0 $fOrdTypeExp $fOrdTypeExp0 $fEqTypeExp $fEqTypeExp0 $fOrdDimExp $fOrdDimExp0 $fEqDimExp $fEqDimExp0 $fOrdDimDecl $fOrdDimDecl0 $fEqDimDecl $fEqDimDecl0 UncheckedCase UncheckedProg UncheckedSpec UncheckedDecUncheckedValBindUncheckedPatternUncheckedTypeParamUncheckedSigExpUncheckedModExp UncheckedExpUncheckedDimIndexUncheckedIdentUncheckedTypeDeclUncheckedTypeExp UncheckedType IntrinsicIntrinsicMonoFunIntrinsicOverloadedFunIntrinsicPolyFun IntrinsicTypeIntrinsicEqualityDimPos PosImmediatePosParam PosReturn nestedDimsnoSizesaddSizesanySizes traverseDimsmustBeExplicitInTypemustBeExplicitaliases toStructuraltoStruct fromStruct tupleRecord isTupleRecordareTupleFields tupleFieldstupleFieldNames sortFields sortConstrs isTypeParam isSizeParamcombineTypeShapes matchDims setUniqueness setAliases addAliases valueType unscopeType onRecordField foldFunType unfoldFunTypetypeVars orderZeropatternDimNames typeDimNamespatternOrderZero patternMap patternTypepatternStructType patternParamnamesToPrimTypes intrinsicsmaxIntrinsicTagqualNamequalifytypeName progImports decImportsprogModuleTypesidentifierReferenceleadingOperator $fEqDimPos $fOrdDimPos $fShowDimPosAnnotunAnnotIsNamepprName prettyName$fPrettyLiftedness$fPrettyAttrInfo$fPrettyTypeArg$fPrettyShapeDecl$fPrettyShapeDecl0$fPrettyShapeDecl1 $fPrettyValue$fPrettyTypeParamBase$fPrettyIdentBase$fPrettyQualName$fPrettyTypeArgExp$fPrettyTypeExp$fPrettyScalarTypeBase$fPrettyShapeDecl2$fPrettyDimExp$fPrettyDimDecl $fIsNameName $fIsNameVName$fPrettyModBindBase$fPrettyModParamBase$fPrettySigBindBase$fPrettySigExpBase$fPrettySpecBase$fPrettyValBindBase$fPrettyTypeBindBase$fPrettyModExpBase$fPrettyDecBase$fPrettyProgBase$fPrettyPatternBase$fPrettyLoopFormBase$fPrettyCaseBase$fPrettyFieldBase$fPrettyExpBase$fPrettyDimIndexBase$fPrettyTypeDeclBase $fAnnotInfo $fAnnotNoInfoTokenIDINDEXING QUALINDEXING QUALPARENUNOPQUALUNOPSYMBOL CONSTRUCTOR PROJ_FIELD PROJ_INDEXINTLIT STRINGLITI8LITI16LITI32LITI64LITU8LITU16LITU32LITU64LITFLOATLITF32LITF64LITCHARLITCOLONCOLON_GT BACKSLASH APOSTROPHEAPOSTROPHE_THEN_HATAPOSTROPHE_THEN_TILDEBACKTICK HASH_LBRACKETTWO_DOTS TWO_DOTS_LT TWO_DOTS_GT THREE_DOTSLPARRPARRPAR_THEN_LBRACKETLBRACKETRBRACKETLCURLYRCURLYCOMMA UNDERSCORE RIGHT_ARROWEQUASTERISKNEGATELTHHATTILDEPIPEIFTHENELSELETLOOPINFORDOWITHASSERTTRUEFALSEWHILEINCLUDEIMPORTENTRYTYPEMODULEVALOPENLOCALMATCHCASEDOCEOFLscanTokensText ParseErrorparseDecOrExpIncrM parseFutharkparseExp parseModExp parseType parseValue parseValuesCase ScalarType TypeParam StructTypeArgSpecDecSigExpModExp envVtable envTypeTable envSigTable envModTable envNameMapNameMapBoundV TypeBindingTypeAbbrMTymtyAbsmtyModFunSig funSigAbs funSigMod funSigMtyModEnvModFunTySet NamespaceTerm SignatureImports FileModulefileAbsfileEnvfileProg ImportNamemkInitialImport mkImportFromincludeToFilePathincludeToString$fLocatedImportName$fPrettyNamespace $fPrettyEnv $fPrettyMod $fPrettyMTy $fMonoidEnv$fSemigroupEnv $fShowEnv $fShowMTy $fShowMod $fShowFunSig $fShowBoundV$fEqTypeBinding$fShowTypeBinding $fEqNamespace$fOrdNamespace$fShowNamespace$fEnumNamespace$fEqImportName$fOrdImportName$fShowImportNameCtxctxEnv ctxImportsInterpreterError ValuePrim ValueArray ValueRecordExtOp ExtOpTrace ExtOpBreak ExtOpError BreakReason BreakPointBreakNaN StackFrame stackFrameLoc stackFrameCtx isEmptyArrayprettyEmptyArray fromTupletypeCheckerEnv initialCtx interpretExp interpretDecinterpretImportinterpretFunction $fPrettyShape$fShowInterpreterError$fPrettyIndexing$fFunctorExtOp$fLocatedStackFrame $fMonadEvalM$fApplicativeEvalM$fFunctorEvalM$fMonadFreeExtOpEvalM$fMonadReader(,)EvalM$fMonadStateMapEvalM $fEqShape $fShowShape$fFunctorShape$fFoldableShape$fTraversableShape BoundInTypes boundInTypesinternaliseParamTypesinternaliseReturnTypeinternaliseEntryReturnTypeinternaliseTypeinternaliseSumTypeinternalisedTypeSizeinternalisePrimTypeinternalisePrimValue$fSemigroupBoundInTypes$fMonoidBoundInTypesInternaliseLambdainternaliseMapLambdainternaliseStreamMapLambdainternaliseFoldLambdainternaliseStreamLambdainternalisePartitionLambda transformProg$fMonoidNameSet$fSemigroupNameSet $fShowNameSet $fFunctorDefM$fApplicativeDefM $fMonadDefM$fMonadReader(,)DefM$fMonadWriterSeqDefM$fMonadFreshNamesDefM$fShowStaticVal $fShowExtExp MatchPattern bindingParamsbindingLambdaParamsMismatch Word8Value Word16Value Word32Value Word64ValueVector readValues compareValuescompareValues1 $fBinaryValue$fPrettyValueType$fShowMismatch$fShowValueTypeSuccess SuccessValuesSuccessGenerateValuesExpectedResultSucceedsRunTimeFailureValuesInFile GenValuesTestRunrunTagsrunInputrunExpectedResultrunIndexrunDescription WarningTestExpectedWarning StructureTestStructurePipelineKernelsPipeline SOACSPipelineSequentialCpuPipeline GpuPipeline ExpectedErrorAnyError ThisError InputOutputs iosEntryPoint iosTestRuns TestActionCompileTimeFailureRunCases ProgramTesttestDescriptiontestTags testActiontestSpecFromFiletestSpecFromFileOrDietestSpecsFromPathstestSpecsFromPathsOrDievaluesFromByteString getValues getValuesBStestRunReferenceOutputgetExpectedResult binaryNamecompileProgram runProgramensureReferenceOutputdetermineTuning$fShowExpectedError$fShowWarningTest$fShowProgramTest$fShowTestAction$fShowInputOutputs $fShowTestRun $fShowSuccess$fShowExpectedResult $fShowValues$fShowGenValue$fShowStructureTest$fShowStructurePipelineCompileOptions compFuthark compBackend compOptions RunOptions runRunnerrunRunsrunExtraOptions runTimeout runVerboserunResultAction BenchResult DataResult RunResultrunMicrosecondsencodeBenchResultsdecodeBenchResultsbenchmarkDatasetprepareBenchmarkProgram$fFromJSONRunResult$fToJSONRunResult$fFromJSONDataResults$fToJSONDataResults$fFromJSONBenchResults$fToJSONBenchResults$fEqBenchResult$fShowBenchResult$fEqDataResult$fShowDataResult $fEqRunResult$fShowRunResult ASTMappableastMap ASTMappermapOnExp mapOnName mapOnQualNamemapOnStructTypemapOnPatternTypebareExp$fASTMappable(,,)$fASTMappable(,)$fASTMappableNonEmpty$fASTMappable[]$fASTMappableInfo$fASTMappableCaseBase$fASTMappableFieldBase$fASTMappablePatternBase$fASTMappableIdentBase$fASTMappableTypeDeclBase$fASTMappableTypeBase$fASTMappableTypeBase0$fASTMappableSet$fASTMappableAlias$fASTMappableDimIndexBase$fASTMappableTypeParamBase$fASTMappableDimDecl$fASTMappableDimExp$fASTMappableTypeArgExp$fASTMappableTypeExp$fASTMappableLoopFormBase$fASTMappableExpBaseAtPosAtNameBoundTo BoundTerm BoundModuleBoundModuleType BoundTypeboundLocatPos $fEqAtPos $fShowAtPos$fEqDef $fShowDef $fEqBoundTo $fShowBoundTo $fMonoidScope$fSemigroupScope$fApplicativeTransformM$fFunctorTransformM$fMonadTransformM$fMonadFreshNamesTransformM$fMonadReaderEnvTransformM$fMonadWriterDListTransformM $fShowScopeWarnings singleWarningsingleWarning'$fShowWarnings$fMonoidWarnings$fSemigroupWarnings $fEqWarningsMonadTypeCheckerwarnnewID bindNameMapbindVal checkQualName lookupMod checkNamedDim typeError ImportTableNotesaNoteunappliedFunctorunknownVariable unknownType underscoreUserunTypeMaskEnv askImportName lookupMTy lookupImportlocalEnv checkName bindSpacedqualifyTypeVars badOnLeft anySignedTypeanyUnsignedType anyIntType anyFloatType anyNumberType anyPrimTypeintrinsicsNameMaptopLevelNameMap $fPrettyNote $fPrettyNotes$fPrettyTypeError$fMonadTypeCheckerTypeM$fMonadReaderContextTypeM$fMonadWriterWarningsTypeM$fMonadStateVNameSourceTypeM$fMonadErrorTypeErrorTypeM$fSemigroupNotes $fMonoidNotes applySubstSubst PrimSubstTypeSubsTypeSubDimSub unifyTypesU subuniqueOf checkTypeDecl checkTypeExpcheckForDuplicateNamescheckTypeParamstypeParamToArgsubstituteTypes substTypesAny$fFunctorSubst$fSubstitutablePatternBase$fSubstitutableShapeDecl$fSubstitutableDimDecl$fSubstitutableTypeBase$fSubstitutableTypeBase0 $fShowSubst $fShowTypeSub MonadUnifygetConstraintsputConstraintsmodifyConstraints newTypeVar newDimVarcurLevel matchError unifyErrorRigidityRigidNonrigid RigidSourceRigidArgRigidRet RigidLoop RigidSlice RigidRange RigidBound RigidCond RigidUnifyRigidOutOfScope Constraints Constraint NoConstraint ParamType Overloaded HasFieldsEquality HasConstrs ParamSizeSizeUnknowableSizeLevelUsage BreadCrumbs noBreadCrumbshasNoBreadCrumbsmkUsagemkUsage'dimNotes normTypeFullynormTypenormPatternTypeinstantiateEmptyArrayDimsunifyexpect mustBeOneOf equalityType zeroOrderTypemustHaveConstr mustHaveFieldanyDimOnMismatchunifyMostCommon mkTypeVarName doUnification$fPrettyBreadCrumb$fPrettyBreadCrumbs$fLocatedUsage $fPrettyUsage$fLocatedConstraint$fMonadUnifyUnifyM $fMonadUnifyM$fFunctorUnifyM$fApplicativeUnifyM$fMonadState(,)UnifyM$fMonadErrorTypeErrorUnifyM $fEqRigidity $fOrdRigidity$fShowRigidity$fShowConstraint$fEqRigidSource$fOrdRigidSource$fShowRigidSource$fFunctorMonoM$fApplicativeMonoM $fMonadMonoM$fMonadReaderEnvMonoM$fMonadWriterSeqMonoM$fMonadFreshNamesMonoMinternaliseProg checkOneExp checkFunDef$fLocatedOccurence$fSemigroupTermScope $fOrdFName $fEqFName$fPrettyChecking$fMonadTypeCheckerTermTypeM$fMonadUnifyTermTypeM$fPrettyUnmatched$fOrdConstrPat $fEqConstrPat$fFunctorUnmatched$fShowUnmatched$fMonadTermTypeM$fFunctorTermTypeM$fApplicativeTermTypeM$fMonadReaderTermEnvTermTypeM$fMonadWriter[]TermTypeM"$fMonadStateTermTypeStateTermTypeM$fMonadErrorTypeErrorTermTypeM$fEqSizeSource$fOrdSizeSource$fShowSizeSource $fShowFName$fShowTermScope$fShowValBinding$fShowLocalitynewNamesForMTy refineEnv matchMTys applyFunctorcheckDec checkModExp initialEnvBasis basisImportsbasisNameSource basisRoots emptyBasisreadLibraryWithBasis readImports FutharkConfigfutharkVerbose futharkWarn futharkWerror futharkSafenewFutharkConfig dumpErrorrunCompilerOnProgramrunPipelineOnProgram readProgram readLibraryreadProgramOrDiehandleWarningstoExp'ImpMVTableVarEntryArrayVarMemVar ScalarEntryentryScalarTypeMemEntry entryMemSpace ArrayEntryentryArrayLocationentryArrayElemType MemLocationmemLocationNamememLocationShapememLocationIxFunopsExpCompiler opsOpCompileropsStmsCompileropsCopyCompileropsAllocCompilers AllocCompiler CopyCompiler ExpCompiler StmsCompilersubImpM_subImpMcommentemit emitFunction hasFunction compileBody compileBody'compileLoopBody compileStmsdefCompileStms defCompileExpdFParamsdLParams dPrimVol_dPrim_dPrimdPrimV_dPrimVdPrimVEdScopedArrayeverythingVolatilelocalDefaultSpace askFunctionnewVNameForFun nameForFunlocalOps getVTable localVTable lookupArray lookupMemoryfullyIndexArrayfullyIndexArray'copycopyElementWisecopyDWIM copyDWIMFix compileAlloctypeSizesForsWhilesCommentsIfsWhensUnlesssOp sDeclareMemsAlloc_sAllocsArray sArrayInMemsAllocArrayPerm sAllocArray sStaticArraysWritesUpdate sLoopNest<--function$fHasScopeSOACSImpM$fMonadFreshNamesImpM $fFunctorImpM$fApplicativeImpM $fMonadImpM$fMonadStateImpStateImpM$fMonadReaderEnvImpM$fShowDestination$fShowValueDestination$fShowVarEntry$fShowScalarEntry$fShowMemEntry$fShowArrayEntry$fEqMemLocation$fShowMemLocation AtomicBinOp AtomicUpdate AtomicPrim AtomicCAS AtomicLockingDoAtomicUpdateLocking lockingArraylockingIsUnlocked lockingToLocklockingToUnlocklockingMappingKernelConstantskernelGlobalThreadIdkernelLocalThreadId kernelGroupIdkernelGlobalThreadIdVarkernelLocalThreadIdVarkernelGroupIdVarkernelNumThreadskernelWaveSizekernelThreadActivekernelLocalIdMap InKernelGen CallKernelGen KernelEnv kernelAtomicskernelConstantsHostEnv hostAtomicsprecomputeSegOpIDskeyWithEntryPoint kernelLoop groupLoopgroupCoverSpaceatomicUpdateLockingcomputeThreadChunkSizeisActive groupReduce groupScanvirtualiseGroups sKernelThread sKernelGroup sReplicatesIotasCopycompileGroupResultcompileThreadResultcompileSegScan DoSegBody compileSegRedcompileSegRed' compileSegMapcompileSegHist $fEqPassage $fOrdPassagecompileProgOpenCLcompileProgCUDA printAction metricsActionimpCodeGenActionkernelImpCodeGenActionversion versionString FunOptDescrmainWithOptions CompilerMode ToLibrary ToExecutableCompilerOption compilerMain$fEqCompilerMode$fOrdCompilerMode$fShowCompilerModemain $fOrdTestCase $fEqTestCase$fShowTestCase $fEqTestMode$fShowTestMode$fShowProgConfig$fEqTestResult$fShowTestResult$fMonadLoggerPkgM$fMonadPkgRegistryPkgM$fMonadFailPkgM $fMonadPkgM $fFunctorPkgM$fApplicativePkgM $fMonadIOPkgM$fMonadReaderPkgConfigPkgM mainImports mainDataget$fPrettyUntypedPassState $fRepresentationUntypedPassState$fRepresentationUntypedAction$fEqOutputFormat$fOrdOutputFormat$fShowOutputFormat$fEqSkipReason$fShowDatasetResult renderFiles$fFunctorFutharkiM$fApplicativeFutharkiM$fMonadFutharkiM"$fMonadStateFutharkiStateFutharkiM$fMonadIOFutharkiM$fMonadErrorStopReasonFutharkiMGHC.BaserequiredInManifest GHC.MaybeNothingGHC.IOFilePath Data.Foldablemaximummap Data.EitherpartitionEithersGHC.ListsplitAtprcss-xtrs-0.7.4-c8cba4bfSystem.Process.ByteStringreadProcessWithExitCodeghc-prim GHC.TypesIOGHC.RealIntegral displaySLoc displayLoc displaySPos displayPosunLocnoLocsrcspan<-->locEndlocStart advancePoslinePosstartPosposCoffposColposLineposFileNoLoc IsLocationfromLocfromPos RelocatablerelocControl.Monad.IO.ClassMonadIOcurlmemoiseGetManifestRoughBuildList doSolveDeps text-1.2.3.2Data.Text.InternalTextText.PrettyPrint.Mainland.ClasspprintPrettypprListpprpprPrec GHC.ClassesOrdEqinteger-wired-inGHC.Integer.TypeRationaldoSubdoUDivdoUDivUpdoSDivUpdoUModdoSQuotdoSRemdoSMindoUMindoSMaxdoUMaxdoShldoLShrdoAShrdoAnddoOrdoXorintToIntnegativeIshIntMonoid==memptymodifyArrayShapeTrue shapeMapping'transformers-0.5.6.2Control.Monad.Trans.ReaderReaderGHC.ErrerrorData.Functor.IdentityIdentity loopExtTypeEQLTFunctor TraversableGHC.NumNumlengthControl.Monad.Failfail zeroIshExp oneIshExprenamerSubstitutionsmatcheswithoutUMaybe rephraseParamEitherLeft censorStms BodyWisdomControl.Monad.Trans.Writer.LazyWriter Consumption FunBindingGHC.ShowShowboundobserve expandAliasescheckAnnotationControl.CategoryCategoryLMADUnknownsubstituteInLMADhasContiguousPerm lmadShape lmadShapeBase sliceOneLMADreshapeCoercionreshapeOneLMAD rebaseNice makeRotIotaixfunMonotonicityRots freeVarIndex letBoundIndex entryConsumed IndexArrayhideIf BottomUpRules TopDownRulesRules checkResults SimpleRule TypeLookuphoistBranchInvariantcopyScratchToScratchremoveDeadBranchResultchangedprotectIfHoistedprotectLoopHoistednotWorthHoistingsimplifyResult asserting assertingOneremoveReplicateWriteremoveUnusedSOACInputremoveDeadReductionremoveDeadWrite buildFGfunJust getExtMaps PatAllocMChunkMap Control.MonadguardjoinMonadreturn>>=>>fmap<$Control.Monad.FixMonadFixmfix MonadFailsequencemapMliftIOmfilter<$!>unless replicateM_ replicateMfoldM_foldM zipWithM_zipWithM mapAndUnzipMforever<=<>=>filterMforMmsum sequence_forM_mapM_ Data.Functionfix Data.FunctorvoidapliftM5liftM4liftM3liftM2liftMwhen=<< MonadPlusmzeromplusControl.Monad.Trans.Class MonadTransliftReaderT runReaderT mapReaderTControl.Monad.Reader.Classasks MonadReaderreaderasklocal runReader mapReader withReader withReaderT segOpTypeDistributionBodydistributionExpandTargetletBindInNestingboundInNestingunExistentialiseMemorycopyCopyToCopyremoveIdentityCopycseInOpinlineInFunDefExpMapkernelElementsPerThreadkerneliseLambdaworthIntraGroupworthSequentialising VarianceTableTilingPrivStmspreludeToPostludepartitionPrelude multiplicityinPlaceLowering RebaseMap Extraction DoubleBuffer BufferCopyinputsToSubExps mapFusionOKmapWriteFusionOKfuseSOACwithKer toSeqStreamrearrangeReturnTypesrsuccoutArrinpArr infusiblekernelsKernNamesoacsbindVarbindingFamilyVar bindingFamilybindResrunFusionGatherMexpandSoacInpArr greedyFuse finaliseSOACmkFreshFusionRes getIdentArr SemigroupMayFailintTypeToCTypeuintTypeToCTypefloatTypeToCType envCachedMemprintStmcproductkernelSyncPendingtranslateKernels cleanSizessuffZero scanTokensshow parseExpIncrM ParserMonadprog futharkType expression modExpressionanyValue anyValuesparseHappyStk envShapes TermBindingTermPolyEvalMmkArraysignum'signumevalTypeDefM StaticValLambdaSVSumSVExtExp restrictEnvTorunDefM defuncExp defuncExp' defuncSoacExpdefuncDimIndex defuncLet defuncApply fullyApplied liftDynFunenvFromPatternDynamicenvFromShapeParams liftValDecbuildEnvPattern buildRetType typeFromSVdynamicFunTypematchPatternSV updatePattern svFromTypefreeVars patternVars defuncValBind DynamicFun defuncValsflattenPatternPrimValueMismatchbinary-0.8.8.0Data.Binary.Classput constituentexplainMismatchGenValueGenPrim genValueTypetestSpecsFromPathgetGenBS genFileSizefollowprogDefsModModtransformNamesNotegetTypecheckForDuplicateNamesInType BreadCrumb breadCrumbisRigid isNonRigidallDimsFreshInPatinternaliseDimExpisOverloadedFunction ConstrPat Unmatched TermTypeState stateDimTable SizeSourceTermEnv TermScopeLocality Occurence nullOccurenceseminullOccurenceexpType expTypeFullyinstantiateTypeSchemeinstantiateTypeParamunifyBranchTypes returnType maskAliasesliteralOverflowCheckfixOverloadedTypestypeDimNamesPos boundAliasesverifyFunctionParamscloseOverTypes consumingnoUnique allNamesInEnv readLibrary'envEnv envFunctionArrayDestination Destination addArrays addFParams addLoopVarfuncallTargetsaskAttrs localAttrs defaultCopy copyArrayDWIM copyDWIMDestValueDestinationMemoryDestinationthreadOperationssplitOpmakeAllMemoryGlobalsReplicateKernel sIotaKernel scanStage1 SegBinOpSlugslugArrsslugAccs maxNumOpsintermediateArraysgroupResultArraysPassagecomputeHistoUsageslugMaxLocalMemPasses getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNameerrputnewCompilerConfigconfigExtraOptions excludeCasesPkgMinstallBuildListrepresentationfutharkPipelinefutharkPrintASTFutharkPipeline PrettyPrint TypeCheck Defunctorise MonomorphiseDefunctionalisegetFutharkPipelinemeanstddevppvar centralMoment tuningPaths DocumentedctxVisibleMTysNoLink headerDocfutharkiBreakingfutharkiSkipBreaksfutharkiLoadedBreaking breakingAt