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

SCM Repository

[diderot] View of /trunk/src/compiler/c-util/runtime-names.sml
ViewVC logotype

View of /trunk/src/compiler/c-util/runtime-names.sml

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1372 - (download) (annotate)
Wed Jun 22 21:24:17 2011 UTC (7 years, 9 months ago) by jhr
File size: 5265 byte(s)
  merging changes from pure-cfg
(* runtime-names.sml
 *
 * COPYRIGHT (c) 2011 The Diderot Project (http://diderot-language.cs.uchicago.edu)
 * All rights reserved.
 *)

structure RuntimeNames =
  struct

    local
      structure Ty = TreeIL.Ty
      structure F = Format
    in

  (* globals that specify the target characteristics.  These should be initialized
   * when the program object is created.
   *)
    val doublePrecision = ref false
    val gVectorWid = ref 4
    val gIntTy = ref CLang.int32
    val gRealTy = ref CLang.float
    val gRealSuffix = ref "?"
    val gIntSuffix = ref "?"
    val gIntFormat = ref "?"

  (* initialize globals based on target precision *)
    fun initTargetSpec double = (
	  doublePrecision := double;
	  if double
	    then (
	      gVectorWid := 2;
	      gIntTy := CLang.int64;
	      gRealTy := CLang.double;
	      gRealSuffix := "d";
	      gIntSuffix := "l";
	      gIntFormat := "%ld")
	    else (
	      gVectorWid := 4;
	      gIntTy := CLang.int32;
	      gRealTy := CLang.float;
	      gRealSuffix := "f";
	      gIntSuffix := "i";
	      gIntFormat := "%d"))

    fun addRealSuffix stem = stem ^ !gRealSuffix
    fun addVecSuffix stem n = concat[stem, Int.toString n, !gRealSuffix]
    fun addIVecSuffix stem n = concat[stem, Int.toString n, !gIntSuffix]

    fun addTySuffix (stem, 1) = stem ^ !gRealSuffix
      | addTySuffix (stem, n) = addVecSuffix stem n

    fun vecTy n = concat["vec", Int.toString n, !gRealSuffix, "_t"]
    fun ivecTy n = concat["vec", Int.toString n, !gIntSuffix, "_t"]
    fun imageTy n = concat["Diderot_image", Int.toString n, "D_t"]
    fun matTy (n, m) = concat["Diderot_Mat", Int.toString n, "x", Int.toString m, "_t"]

  (* names of generated tyes, functions, and globals *)
    val initGlobals = "Diderot_InitGlobals"	(* function for initializing program globals *)
    val registerOpts = "Diderot_RegisterGlobalOpts" (* function for registering command-line options *)
    val shutdown = "Diderot_Shutdown"		(* function that gets called at the end *)
    val initially = "Diderot_Initially"		(* function for creating initial strands *)
    fun strandInit strand = strand ^ "_InitState"
    fun strandTy strand = concat["Strand_", strand, "_t"]
    fun strandDesc strand = concat["Strand_", strand]
    val numStrands = "Diderot_NumStrands"
    val strands = "Diderot_Strands"

  (* scalar math functions *)
    fun max () = addRealSuffix "max"
    fun min () = addRealSuffix "min"
    fun fabs () = addRealSuffix "fabs"

  (* clamp and lerp *)
    fun clamp n = addTySuffix("clamp", n)
    fun lerp n = addTySuffix("lerp", n)

  (* vector math functions *)
    val mkVec = addVecSuffix "vec"
    val scale = addVecSuffix "scale"
    val truncToInt = addVecSuffix "truncToInt"
    val dot = addVecSuffix "dot"
    fun cross () = addVecSuffix "cross" 3
    val length = addVecSuffix "length"
    val normalize = addVecSuffix "normalize"
    fun vecitof n = concat["vec", Int.toString n, "ito", !gRealSuffix]
    fun vecftoi n = concat["vec", Int.toString n, !gRealSuffix, "toi"]

  (* matrix operations *)
    fun zeroMat (n, m) = concat["zero", Int.toString n, "x", Int.toString m, !gRealSuffix]
    fun identityMat n = concat["identity", Int.toString n, "x", Int.toString n, !gRealSuffix]
    fun trace n = concat["trace", Int.toString n, "x", Int.toString n, !gRealSuffix]
    fun norm (n, m) = concat["norm", Int.toString n, "x", Int.toString m, !gRealSuffix]
    fun copyMat (n, m) = concat["copy", Int.toString n, "x", Int.toString m, !gRealSuffix]
    fun scaleMat (n, m) = concat["scale", Int.toString n, "x", Int.toString m, !gRealSuffix]
    fun addMat (n, m) = concat["add", Int.toString n, "x", Int.toString m, !gRealSuffix]
    fun subMat (n, m) = concat["sub", Int.toString n, "x", Int.toString m, !gRealSuffix]
    fun mulVecMat (m, n) = F.format "mulVec%dMat%dx%d%s"
	  [F.INT m, F.INT m, F.INT n, F.STR(!gRealSuffix)]
    fun mulMatVec (m, n) = F.format "mulMat%dx%dVec%d%s"
	  [F.INT n, F.INT m, F.INT n, F.STR(!gRealSuffix)]
    fun mulMatMat (m, n, p) = F.format "mulMat%dx%dMat%dx%d%s"
	  [F.INT m, F.INT n, F.INT n, F.INT p, F.STR(!gRealSuffix)]

  (* Status_t symbols *)
    val kActive = "DIDEROT_ACTIVE"
    val kDie = "DIDEROT_DIE"
    val kStabilize = "DIDEROT_STABILIZE"

  (* Diderot runtime system hooks *)
    val statusTy = "Status_t"
    val toImageSpace = addVecSuffix "ToImageSpace"
    fun toWorldSpace ty = let
	  val suffix = (case ty
		 of Ty.TensorTy[d] => [Int.toString d, !gRealSuffix]
		  | Ty.TensorTy[m,n] => [Int.toString n, "x", Int.toString n, !gRealSuffix]
		(* end case *))
	  in
	    concat("ToWorldSpace" :: suffix)
	  end
    val inside = addVecSuffix "Inside"
    fun loadImage dim = concat["Diderot_LoadImage", Int.toString dim, "D"]
    val strandDescTy = "Strand_t"
    val worldTy = "Diderot_World_t"
    val optionsTy = "Diderot_Options_t"
    val allocInitially = "Diderot_AllocInitially"
    val inState = "Diderot_InState"

    fun input ty = (case ty
	   of Ty.StringTy => "Diderot_InputString"
	    | Ty.TensorTy[] => "Diderot_InputReal"
	    | Ty.TensorTy[2] => "Diderot_InputVec2"
	    | Ty.TensorTy[3] => "Diderot_InputVec3"
	    | ty => raise Fail("unsupported input type " ^ Ty.toString ty)
	  (* end case *))

    end (* local *)
  end

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