diff options
author | Ian Hinder <ian.hinder@aei.mpg.de> | 2013-09-09 12:34:45 +0200 |
---|---|---|
committer | Ian Hinder <ian.hinder@aei.mpg.de> | 2013-09-09 12:34:45 +0200 |
commit | 575f6fdeee767384348adfeccb515f812663418c (patch) | |
tree | a60b78d23a104e1085ed0277f3ea723c03bb20e6 /Tools/CodeGen/CodeGenCalculation.m | |
parent | df70d64bd618338c4dcefbd9b3d31032828526f0 (diff) |
Thorn.m: Move CreateSetterSource to CodeGenCalculation.m
Diffstat (limited to 'Tools/CodeGen/CodeGenCalculation.m')
-rw-r--r-- | Tools/CodeGen/CodeGenCalculation.m | 77 |
1 files changed, 75 insertions, 2 deletions
diff --git a/Tools/CodeGen/CodeGenCalculation.m b/Tools/CodeGen/CodeGenCalculation.m index befc256..2c30bf6 100644 --- a/Tools/CodeGen/CodeGenCalculation.m +++ b/Tools/CodeGen/CodeGenCalculation.m @@ -19,13 +19,14 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *) -BeginPackage["CalculationFunction`", {"CodeGenCactus`", "CodeGenC`", "CodeGen`", +BeginPackage["CodeGenCalculation`", {"CodeGenCactus`", "CodeGenC`", "CodeGen`", "CodeGenKranc`", "MapLookup`", "KrancGroups`", "Differencing`", "Errors`", "Helpers`", "Kranc`", "Optimize`", "Jacobian`", "Profile`", "Vectorisation`", - "Calculation`", "DGFE`", "OpenCL`"}]; + "Calculation`", "DGFE`", "OpenCL`", "CalculationBoundaries`"}]; CreateCalculationFunction::usage = ""; +CreateSetterSource::usage = ""; GridFunctionsInExpression; Begin["`Private`"]; @@ -50,6 +51,78 @@ VerifyListContent[l_, type_, while_] := " objects, but found the following types of object: ", ToString[types], " in ", l, while]]]; +(* ------------------------------------------------------------------------ + Setter + ------------------------------------------------------------------------ *) + +(* calculation = {Name -> "ClassicADM_Setter", + optional Before -> {functions}, + optional After -> {functions}, + Shorthands -> {gInv11, ...}, + GridFunctions -> {g11rhs, K11}, + CollectList -> {hInv11, hInv22, ...}, + optional DeclarationIncludes -> {include file list}, + optional LoopPreIncludes -> {include file list}, + Equations -> {{K11_rhs -> 2 A K11, ...}...}} *) + + +(* Given a list of Calculation structures as defined above, create a + CodeGen representation of a source file that defines a function for + each Calculation. *) + +Options[CreateSetterSource] = ThornOptions; + +CreateSetterSource[calcs_, debug_, include_, + opts:OptionsPattern[]] := + Module[{calc = First[calcs],bodyFunction}, + + If[!MatchQ[include, _List], + ThrowError["CreateSetterSource: Include should be a list but is in fact " <> ToString[include]]]; + + SetDataType[If[OptionValue[UseVectors],VectorisationType[], "CCTK_REAL"]]; + + {FileHeader["C"], + + "#define KRANC_" <> ToUpperCase[CodeGenC`SOURCELANGUAGE] <> "\n\n", + + If[CodeGenC`SOURCELANGUAGE == "C", + {IncludeSystemFile["assert.h"], + IncludeSystemFile["math.h"], + IncludeSystemFile["stdio.h"], + IncludeSystemFile["stdlib.h"], + IncludeSystemFile["string.h"]}, + {"\n"} + ], + + Map[IncludeFile, Join[{"cctk.h", "cctk_Arguments.h", "cctk_Parameters.h", + (*"precomputations.h",*) "GenericFD.h", "Differencing.h"}, + include, + {"cctk_Loop.h", "loopcontrol.h"}, + If[OptionValue[UseOpenCL], OpenCLIncludeFiles[], {}], + If[OptionValue[UseVectors], VectorisationIncludeFiles[], {}]]], + CalculationMacros[OptionValue[UseVectors]], + + (* For each function structure passed, create the function and + insert it *) + + CalculationBoundariesFunction[First[calcs]], + + bodyFunction = DefineFunction[lookup[calc,Name]<>"_Body", "static void", "const cGH* restrict const cctkGH, const int dir, const int face, const CCTK_REAL normal[3], const CCTK_REAL tangentA[3], const CCTK_REAL tangentB[3], const int imin[3], const int imax[3], const int n_subblock_gfs, CCTK_REAL* restrict const subblock_gfs[]", + { + "DECLARE_CCTK_ARGUMENTS;\n", + "DECLARE_CCTK_PARAMETERS;\n\n", + # + }] &; + + calc = Join[calc, {BodyFunction -> bodyFunction, + CallerFunction -> True, + LoopFunction -> (GenericGridLoop[lookup[calc,Name],#,opts] &), + GFAccessFunction -> ({#,"[","index","]"} &), + InitFDVariables -> InitialiseFDVariables[OptionValue[UseVectors]], + MacroPointer -> True}]; + + CreateCalculationFunction[calc, opts]}]; + (* -------------------------------------------------------------------------- Calculations -------------------------------------------------------------------------- *) |