Skip to content

SSC Compute Modules

Janine edited this page May 18, 2018 · 10 revisions

Compute modules in SSC are a structure that contain complete functions calculating large sections of a model in SAM. They serve as the main access points from external applications, including the SAM user interface and the SAM SDK. . For example, each technology model and financial model has its own compute module. Cost models may also have their own compute module. If you’re unsure whether your function should be a new compute module or not, please contact the SAM team.

Adding a new compute module to ssc

  1. Create a new file named cmod_compute_module_name.cpp in the ssc folder of the ssc project (you can do this by copying, pasting, and renaming another compute module that you wish to emulate).
  2. Add the compute module to the projects for all three platforms:
    1. Windows: Open the ssc project solution ssc/build_vs2017/ssc_vs2017.sln and add the new compute module to the project solution. In Visual Studio, you do this by right clicking on the ssc project in the Solution Explorer, then selecting “Add” > “Existing Item”. Add the compute module file you just created.
    2. Linux: open the file ssc/build_linux/Makefile-ssc in a text editor. Add the new compute module in the OBJECTS list. Follow the formatting of the other entries.
    3. Mac: open the file ssc/build_osx/Makefile-ssc in a text editor. Add the new compute module in the OBJECTS list. Follow the formatting of the other entries.1.
  3. Compute modules must be listed twice in ssc/sscapi.cpp, once in extern module_entry_info and once in static module_entry_info *module_table[]. Follow the formatting of the other compute modules in each list.

Compute module structure

The easiest way to create a new compute module is to copy and edit an existing compute module. lib_windbos.cpp provides a fairly simple example with most of the required features. In general, all compute modules have the following sections:

  • License at the top of the file
  • #include “core.h”
  • Variable table- contains inputs and outputs to the compute module
    • Vartype- options are SSC_INPUT, SSC_OUTPUT, or SSC_INOUT for things that are both an input and output to the function
    • Datatype- options are SSC_NUMBER, SSC_ARRAY, SSC_TABLE, SSC_MATRIX, SSC_STRING. For the most part, you should only use number, array, or string.
    • Name- the variable name that will show up externally to the compute module. This should be fairly descriptive.
    • Label- the description of the variable that will show up externally. This should be more descriptive.
    • Units- the units of the variable, ex “kW” or “%/yr”
    • Group- used in the user interface to sort variables. For the most part, this should be the name of the compute module.
    • Required_if- automatically parsed to determine if all required variables are supplied to a compute module.
      • “*” indicates a required variable
      • “?” or “” indicates an optional variable
      • “?=20” indicates an optional variable, that if a value is not supplied, will default to a value of 20
      • “variable_xyz=1” indicates that the current variable is required only if variable_xyz is equal to 1
    • Constraints- items that are automatically parsed to provide some level of input checking. You should utilize the constraints as much as possible. Possible options for variables of type SSC_NUMBER include INTEGER, BOOLEAN, POSITIVE, NEGATIVE, MIN=5, MAX=25, and for variables of type SSC_ARRAY can specify length with LENGTH=12, where all numbers are specified by the writer.
  • Declaration of instance of compute_module class
  • add_var_info function to add the variable table to the compute module
  • exec() function as the main function that gets called when someone calls the compute module
    • Read in all inputs- make sure to perform any input checking that was not possible using the variable table constraints.
      • Inputs are usually read in as double x = (double) as_number(“input_variable_name”);. Other options include as_string, or as_array. The as_array function returns a pointer to an array and also requires an input to save the length of the array, used to check its length as needed.
    • Model calculations- can call out to external functions located in libraries or defined above the exec function in the compute module
    • Assignation of all outputs
      • Output assignations generally look like assign( “output_variable_name”, var_data(previously_calculated_variable) );
  • Definition of compute module entry, including description of what the compute module accomplishes