doc/programming/stdlib/index.rst
author Edouard Tisserant <edouard@beremiz.fr>
Wed, 13 Nov 2024 14:42:34 +0100
changeset 4049 80fc760d4a4a
parent 3929 1a0bed0b4f1c
permissions -rw-r--r--
Modbus: allows modbus thread stack size customization with MODBUS_STACK_SIZE macro.

For example, add "-DMODBUS_STACK_SIZE=0x2000" to target CFLAGS to limit stack size to 128kB
Standard library
================

..
    Documentation originally part of Smarteh's user Manual, and donated to Beremiz project.


.. list-table::

    * - .. figure:: library_panel.png

            Library browser

      - Library contains various groups of standard
        and user defined functions. They support the
        usage in different programmable controller
        programming languages inside POUs.


    * - .. figure:: block_properties.png

            Block Properties

      - Block Properties pop-up window can be
        opened by double-click on function block.
        Some of the blocks can have more inputs than
        default. This is selectable in the Inputs field
        (e.g. ADD block). Also an Execution Order of
        the blocks can be programmer-defined. All
        blocks have an additional Execution Control
        check-box. If it is checked than two new pins
        are added (EN – input and ENO – output) to
        control dynamically their execution.


Standard function blocks
------------------------

.. highlight:: text

.. list-table::

    * - .. figure:: std_block-012.png

            SR bistable

      - The SR bistable is a latch where the Set dominates.::

            ( BOOL:S1, BOOL:R ) => ( BOOL:Q1 )

        This function represents a standard set-dominant set/reset flip
        flop. The Q1 output become TRUE when the input S1 is TRUE and
        the R input is FALSE. In the same way, the Q1 output become
        FALSE when the input S1 is FALSE and the R input is TRUE. After
        one of these transitions, when both the S1 and R signals return to
        FALSE, the Q1 output keeps the previous state until a new
        condition occurs. If you apply a TRUE condition for both the
        signals, the Q1 output is forced to TRUE (set-dominant).


    * - .. figure:: std_block-010.png

            RS bistable

      - The RS bistable is a latch where the Reset dominates.::

            ( BOOL:S, BOOL:R1 ) => ( BOOL:Q1 )

        This function represents a standard reset-dominant set/reset flip
        flop. The Q1 output become TRUE when the input S is TRUE and
        the R1 input is FALSE. In the same way, the Q1 output become
        FALSE when the input S is FALSE and the R1 input is TRUE. After
        one of these transitions, when both the S and R1 signals return to
        FALSE, the Q1 output keeps the previous state until a new
        condition occurs. If you apply a TRUE condition for both the
        signals, the Q1 output is forced to FALSE (reset-dominant).


    * - .. figure:: std_block-019.png

            SEMA Semaphore

      - The semaphore provides a mechanism to allow software elements
        mutually exclusive access to certain resources.::

            ( BOOL:CLAIM, BOOL:RELEASE ) => ( BOOL:BUSY )

        This function block implements a semaphore function. Normally
        this function is used to synchronize events. The BUSY output is
        activated by a TRUE condition on the CLAIM input and it is de-
        activated by a TRUE condition on the RELEASE input.


    * - .. figure:: std_block-021.png

            R_TRIG Rising edge detector

      - The output produces a single pulse when a rising edge is detected.::

            ( BOOL:CLK ) => ( BOOL:Q )

        This function is a rising-edge detector. The Q output becomes
        TRUE when a 0 to 1 (or FALSE to TRUE or OFF to ON) condition is
        detected on the CLK input and it sustains this state for a complete
        scan cycle.


    * - .. figure:: std_block-023.png

            F TRIG

      - Falling edge detector
        The output Q produces a single pulse when a falling edge is
        detected.::

            ( BOOL:CLK ) => ( BOOL:Q )

        This function is a falling-edge detector. The Q output becomes
        TRUE when a 1 to 0 (or TRUE to FALSE or ON to OFF) condition is
        detected on the CLK input and it sustains this state for a complete
        scan cycle.


    * - .. figure:: std_block-030.png

            CTU
            CTU_DINT,
            CTU_LINT,
            CTU_UDINT, CTU_ULINT
            Up-counter

      - The up-counter can be used to signal when a count has reached a
        maximum value.::

            CTU:       ( BOOL:CU, BOOL:R, INT:PV ) => ( BOOL:Q, INT:CV )
            CTU_DINT:  ( BOOL:CU, BOOL:R, DINT:PV ) => ( BOOL:Q, DINT:CV )
            CTU_LINT:
            ( BOOL:CU, BOOL:R, LINT:PV ) => ( BOOL:Q, LINT:CV )
            CTU_UDINT: ( BOOL:CU, BOOL:R, UDINT:PV ) => ( BOOL:Q, UDINT:CV )
            CTU_ULINT: ( BOOL:CU, BOOL:R, ULINT:PV ) => ( BOOL:Q, ULINT:CV )

        The CTU function represents an up-counter. A rising-edge on CU
        input will increment the counter by one. When the programmed
        value, applied to the input PV, is reached, the Q output becomes
        TRUE. Applying a TRUE signal on R input will reset the counter to
        zero (Asynchronous reset). The CV output reports the current
        counting value.


    * - .. figure:: std_block-028.png

            CTD
            CTD_DINT, CTD_LINT,
            CTD_UDINT, CTD_ULINT
            Down-counter

      - The down-counter can be used to signal when a count has reached
        zero, on counting down from a pre-set value.::

            CTD:       ( BOOL:CD, BOOL:LD, INT:PV ) => ( BOOL:Q, INT:CV )
            CTD_DINT:  ( BOOL:CD, BOOL:LD, DINT:PV ) => ( BOOL:Q, DINT:CV )
            CTD_LINT:  ( BOOL:CD, BOOL:LD, LINT:PV ) => ( BOOL:Q, LINT:CV )
            CTD_UDINT: ( BOOL:CD, BOOL:LD, UDINT:PV ) => ( BOOL:Q, UDINT:CV )
            CTD_ULINT: ( BOOL:CD, BOOL:LD, ULINT:PV ) => ( BOOL:Q, ULINT:CV )

        The CTD function represents a down-counter. A rising-edge on CD
        input will decrement the counter by one. The Q output becomes
        TRUE when the current counting value is equal or less than zero.
        Applying a TRUE signal on LD (LOAD) input will load the counter
        with the value present at input PV (Asynchronous load). The CV
        output reports the current counting value.


    * - .. figure:: std_block-035.png

            CTUD
            CTUD_DINT,
            CTUD_LINT,
            CTUD_UDINT,
            CTUD_ULINT
            Up-down counter

      - The up-down counter has two inputs CU and CD. It can be used to
        both count up on one input and down on the other.::

            CTUD:       ( BOOL:CU, BOOL:CD, BOOL:R, BOOL:LD, INT:PV ) => ( BOOL:QU, BOOL:QD, INT:CV )
            CTUD_DINT:  ( BOOL:CU, BOOL:CD, BOOL:R, BOOL:LD, DINT:PV ) => ( BOOL:QU, BOOL:QD, DINT:CV )
            CTUD_LINT:  ( BOOL:CU, BOOL:CD, BOOL:R, BOOL:LD, LINT:PV ) => ( BOOL:QU, BOOL:QD, LINT:CV )
            CTUD_UDINT: ( BOOL:CU, BOOL:CD, BOOL:R, BOOL:LD, UDINT:PV ) => ( BOOL:QU, BOOL:QD, UDINT:CV )
            CTUD_ULINT: ( BOOL:CU, BOOL:CD, BOOL:R, BOOL:LD, ULINT:PV ) => ( BOOL:QU, BOOL:QD, ULINT:CV )
        
        This function represents an up-down programmable counter. A
        rising-edge on the CU (COUNT-UP) input increments the counter
        by one while a rising-edge on the CD (COUNT-DOWN) decreases
        the current value. Applying a TRUE signal on R input will reset the
        counter to zero. A TRUE condition on the LD signal will load the
        counter with the value applied to the input PV (PROGRAMMED
        VALUE). QU output becomes active when the current counting
        value is greater or equal to the programmed value. The QD output
        becomes active when the current value is less or equal to zero.
        The CV output reports the current counter value.


    * - .. figure:: std_block-037.png

            TP
            Pulse timer

      - The pulse timer can be used to generate output pulses of a given
        time duration.::

            ( BOOL:IN, TIME:PT ) => ( BOOL:Q, TIME:ET )

        This kind of timer has the same behaviour of a single-shot timer or
        a monostable timer.
        When a rising-edge transition is detected on the IN input, the Q
        output becomes TRUE immediately. This condition continues until
        the programmed time PT, applied to the relative pin, is elapsed.
        After that the PT is elapsed, the Q output keeps the ON state if
        the input IN is still asserted else the Q output returns to the OFF
        state. This timer is not re-triggerable. This means that after that
        the timer has started it can't be stopped until the complete
        session ends. The ET output reports the current elapsed time.


    * - .. figure:: std_block-042.png

            TON
            On-delay timer
                    
      - The on-delay timer can be used to delay setting an output true,
        for fixed period after an input becomes true.::

            ( BOOL:IN, TIME:PT ) => ( BOOL:Q, TIME:ET )

        Asserting the input signal IN of this function starts the timer.
        When the programmed time, applied to the input PT, is elapsed
        and the input IN is still asserted, the Q output becomes TRUE. This
        condition will continue until the input IN is released. If the IN
        input is released before time elapsing, the timer will be cleared.
        The ET output reports the current elapsed time.


    * - .. figure:: std_block-044.png

            TOF
            Off-delay timer

      - The off-delay timer can be used to delay setting an output false,
        for fixed period after input goes false.::

        ( BOOL:IN, TIME:PT ) => ( BOOL:Q, TIME:ET )

        Asserting the input signal IN of this function immediately activates
        the Q output. At this point, releasing the input IN will start the
        time elapsing. When the programmed time, applied to the input
        PT, is elapsed and the input IN is still released, the Q output
        becomes FALSE. This condition will be kept until the input IN is
        released. If the IN input is asserted again before time elapses, the
        timer will be cleared and the Q output remains TRUE. The ET
        output reports the current elapsed time.


Additional function blocks
--------------------------


.. list-table::

    * - .. figure:: std_block-055.png
    
            RTC
            Real Time Clock

      - The RTC function block sets the output CDT to the input value PDT at the next
        evaluation of the function block following a transition from 0 to 1 of the IN input. The CDT output
        of the RTC function block is undefined when the value of IN is 0.

        .. line-block:: 

            PDT = Preset date and time, loaded on rising edge of IN
            CDT = Current date and time, valid when IN=1
            Q = copy of EN

        .. code-block:: 

            (BOOL:IN, PDT:DT) => (BOOL:Q, CDT:DT)


    * - .. figure:: std_block-049.png
    
            INTEGRAL
            Integral

      - The integral function block integrates the value of input XIN over
        time.::

            ( BOOL:RUN, BOOL:R1, REAL:XIN, REAL:X0, TIME:CYCLE ) => ( BOOL:Q, REAL:XOUT )

        When input RUN is True and override R1 is False, XOUT will
        change for XIN value depends on CYCLE time value sampling
        period. When RUN is False and override R1 is True, XOUT will hold
        the last output value. If R1 is True, XOUT will be set to the X0
        value.::

            XOUT = XOUT + (XIN * CYCLE)


    * - .. figure:: std_block-051.png
    
            DERIVATIVE
            Derivative

      - The derivative function block produces an output XOUT
        proportional to the rate of change of the input XIN.::

            ( BOOL:RUN, REAL:XIN, TIME:CYCLE ) => ( REAL:XOUT )

        When RUN is True, XOUT will change proportional to the rate of
        changing of the value XIN depends on CYCLE time value sampling
        period.::

            XOUT = ((3 * (XIN - XIN(to-3))) + XIN(to-1) – XIN(to-2) ) / (10 * CYCLE)


    * - .. figure:: std_block-060.png
    
            PID
            Proportional, Integral, Derivative

      - The PID (Proportional, Integral, Derivative) function block
        provides the classical three term controller for closed loop
        control. It does not contain any output limitation parameters
        (dead-band, minimum, maximum, …) or other parameters
        normally used for real process control (see also PID_A).::

            ( BOOL:AUTO, REAL:PV, REAL:SP, REAL:X0, REAL:KP, REAL:TR, REAL:TD, TIME:CYCLE ) => ( REAL:XOUT )

        When AUTO is False, PID function block XOUT will follow X0 value.
        When AUTO is True, XOUT will be calculated from error value (PV
        process variable – SP set point), KP proportional constant, TR
        reset time, TD derivative constant and CYCLE time value sampling
        period.::

            XOUT = KP * ((PV-SP) + (I_OUT/TR) + (D_OUT * TD))


    * - .. figure:: std_block-062.png
    
            RAMP
            Ramp

      - The RAMP function block is modelled on example given in the
        standard but with the addition of a 'Holdback' feature.::

            ( BOOL:RUN, REAL:X0, REAL:X1, TIME:TR, TIME:CYCLE, BOOL:HOLDBACK, REAL:ERROR, REAL:PV ) => ( BOOL:RAMP, REAL:XOUT )

        When RUN and HOLDBACK are False, XOUT will follow X0 value.
        When RUN is True and HOLDBACK value is False, XOUT will change
        for ``OUT(to-1) + (X1 – XOUT(to-1))`` every CYCLE time value sampling
        period.


    * - .. figure:: std_block-064.png
    
            HYSTERESIS
            Hysteresis

      - The hysteresis function block provides a hysteresis boolean output
        driven by the difference of two floating point (REAL) inputs XIN1
        and XIN2.::

            ( REAL:XIN1, REAL:XIN2, REAL:EPS ) => ( BOOL:Q )

        When XIN1 value will be grater than XIN2 + EPS value, Q becomes
        True. When XIN1 value will be less than XIN2 - EPS value, Q
        becomes False.