Contract automation and calculating a value automatically

Contract automation and calculating a value automatically

Weagree’s contract automation wizard permits automatically calculating a value and inserting the result into the contract text. Such calculation operates with the calc-tag (calculation options and examples are below). The calc-tag must contain all variables as are necessary to calculate and produce the required result.

The variables may be Q&A-answers. Therefore, a calculation tag may contain global questions and local questions (which local questions may be used to reflect a value in the same contract clause).

By exception, inserting such calculation is not achieved by a dedicated button, but (given the indefinite number of possible calculations) requires that you add


  • Like in mathematical formulae, any round brackets ( ) used within the calculation tag determine the order of the calculation.
  • An edit question or choice question can be used without that answer being inserted in the contract. In such case, the answer will only be used in the calculation.
  • Using brackets to open and close the calculation part of the tag permits using decimals with a full stop.
  • It is possible to format the calculated value (see below)

Calculation tag structure:

[calc.<tag name>.(<calculation>)]

If formatting requirements apply to the calculation result (see also here):

[calc.<tag name>.(<calculation>).<formatting parameter>]


Examples of simple calculations:

Sum ( + ):

[calc.Example of a sum.(200+[edit.Amount 1]+[edit.Amount 2]+[gq.Value entered elsewhere])]

Example – Deduct ( – ):

[calc.Example of a deduction.(200-[edit.Amount 1]-[edit.Amount 2]-[gq.Value entered elsewhere])]

Example – Divide ( / ):

[calc.Example of a divide.(200/[edit.Amount X])]

Example – Multiply ( * ):

[calc.Example of a multiply.(200*[edit.sum1])]

Example – Combine: sum and divide ( + and / ):

[calc.Example of both sum and divide.((200+[edit.sum1]+[edit.sum2]+[gq.sumglobal])/2)]

Example – Combine a nested calculation and sum (calculation within a calculation and + ):

[calc.Calculate with existing value.(200+[calc.Example A divide])]


Possible other parameters in a calc-tag are:

Name Description Usage Result
Pow Results in a specified number raised to the specified power. Pow(3, 2) 9d
Sqrt Results in the square root of a specified number. Sqrt(4) 2d
Ceiling Results in the smallest integer greater than or equal to the specified number. Ceiling(1.5) 2d
Max Results in the larger of two specified numbers. Max(1, 2) 2
Floor Results in the largest integer less than or equal to the specified number. Floor(1.5) 1d
Min Results in the smaller of two numbers. Min(1, 2) 1
Round Rounds a value to the nearest integer or specified number of decimal places. The mid number behaviour can be changed by using EvaluateOption.RoundAwayFromZero during construction of the Expression object. Round(3.222, 2) 3.22d
Truncate Calculates the integral part of a number. Truncate(1.7) 1
Abs Results in the absolute value of a specified number. Abs(-1) 1M
IEEERemainder Results in the remainder resulting from the division of a specified number by another specified number. IEEERemainder(3, 2) -1d
Log Results in the logarithm of a specified number. Log(1, 10) 0d
Log10 Results in the base 10 logarithm of a specified number. Log10(1) 0d
Sign Results in a value indicating the sign of a number. Sign(-10) -1
Cos Results in the cosine of the specified angle. Cos(0) 1d
Sin Results in the sine of the specified angle. Sin(0) 0d
Tan Results in the tangent of the specified angle. Tan(0) 0d
Acos Results in the angle whose cosine is the specified number. Acos(1) 0d
Asin Results in the angle whose sine is the specified number. Asin(0) 0d
Atan Results in the angle whose tangent is the specified number. Atan(0) 0d
Exp Results in e raised to the specified power. Exp(0) 1d


[calc.Example A.(([edit.value1] +([edit.value2] * 3)/2))]


Reusing an existing calculation:

[calc.Example B.([calc.Example A]+2)]

[calc.Example C.([calc.const]+[calc.Example B])]

When inserting the tag (in the template creation tool), regardless of the applicable template language or culture, any decimals must be separated with a full stop ( . ):

[calc.Example D.([calc.Example A]+2.5)]

To force the user to enter a number whether as an integer or a numeral with decimals (and not a text string with thousand-separators or spaces), the edit-question dialogue screen permits enforcing certain data formatting.

The dropdown in the edit-question dialogues screen can be set to require an integer (natural number, containing no decimals) or a numeral with decimals. In such case, the value to be entered may not contain thousand separators (or decimal, if applicable), prompting an error message during the questionnaire.

Related Articles

Terms of Use

I hereby accept (or reconfirm my acceptance of) Weagree’ Terms of use, in which: