HomeFormulas

If statements

When you want a variable to have different values or formulas based on a condition, you can use if-statements. They always have to follow the structure if condition then X else Y

You can link multiple conditions with and and/or or:

  • if condition1 or condition2 then value1 else value2
  • if condition1 and condition2 then value1 else value2

You can also link conditions with a list using the syntax IN, for example:

  • if month in [11, 12, 1, 2] then 90% else 100% -> means if the month is Nov, Dec, Jan or Feb, return 90% else return 100%.
  • You can also use categories / category items in if-statements, see Category Items in formulas for more.

You can also link conditions with the exclusion of a list using the syntax NOT IN, for example:

  • if month not in [11, 12, 1, 2] then 90% else 100% -> means if the month isn't Nov, Dec, Jan or Feb, return 90%, if it is return 100%.

You can have multiple layers of if statements too, for example:

  • if condition1 then value 1 else if condition2 then value2 else [...]
  • You can break each of these layers out onto separate lines of your formula editor using shift + enter
  • Note that every if statement must have an else, otherwise Causal will return an error.

Examples of if statements:

  • if timestep > 4 then 1 else 0
  • if variable1 > variable2 then 100 else 200
  • if timestep > 4 and timestep < 10 then 1 else 0
  • if variable1 < 10 then 100 else if variable1 < 20 then 200 else 300