Eclipse 4diac Logo design once use everywhere Open Source PLC Framework for
Industrial Automation & Control

Documentation

Step 6 - Advanced Features

Step 6 - Advanced Features

This page is part of a guide that gives a walk-through over the major 4diac IDE features.

  1. 4diac IDE Overview
  2. Use 4diac Locally (Blinking tutorial)
  3. Distribute 4diac Applications
  4. Deploy Applications Remotely
  5. Create Your own Function Block Types
  6. Other Basic Features
  7. Advanced Features (YOU ARE HERE!)
  8. Deploying new FBs with the Dynamic Type Loader

This page shows some advanced features about 4diac IDE that are usually used in more complicated applications:

  1. Adapter Usage
  2. Subapplications (implemented since version 1.9)

Adapter Usage

Adapters group interface elements into reusable interface descriptions. They reduce the number of interface elements (event and data inputs and outputs) and by that the number of connections that have to be created between interacting function blocks. In 4diac IDE, adapters are listed in the type library and represented by this symbol: adapter.

Create a new Adapter Type

These interface descriptions can be added to the interface of any Function Block Type. Currently, adapters can not contain other adapters. There are two types of adapters, which are mirrored interfaces:

socket and plug.
  • socket: added as input of a function block and represented by this symbol socket of adapter within the function block's interface.
  • plug: added as output of a function block and represented by this symbol plug of adapter within the function block's interface.

When a new adapter is created, it should be a socket. The mirrored plug is derived automatically by 4diac IDE and is NOT created by the user. An adapter (socket) is created by File → New → New Type and selecting Adapter.adp as Type. All adapter names should start with an A (naming convention).

socket creation.

Use Your new Adapter Type

After creating your desired adapter type (socket), it can be added to a function block's interface by drag and drop from the Palette, as illustrated in the following figure.

add adapter to the interface of a function block.

The function blocks used within the following application snippet are part of the TrafficLight example system. Two different adapter types have been used, ATimeOut in PedLightCtl_AT and E_TimeOut and ATrafficLight in PedLightCtl_AT.

The PedLightCtl_AT is a basic function block. Within basic function blocks adapters are accessed by FB_INTERFACE_NAME.ADAPTER_INTERFACE_NAME. The elements of the ATimeOut adapter are therefore accessed by timeOut.START, timeOut.STOP and timeOut.TimeOut.

The E_TimeOut is a composite function block. Within the network of a composite function block, any adapter added to its interface is represented by an adapter block which looks like a Function Block. The interface elements of this adapter block are connected like a function block.

application with function blocks that contain adapters.

Further examples for the usage of adapters can be found within the FestoMPS example system.

Where to go from here?

If you want to see some examples, behind the following link is an index of the available examples in the documentation:

4diac Examples

If you have a specific platform that has input and outputs and is supported by 4diac FORTE, for example a Raspberry Pi or a PLC, and you want to use them, go to following page:

Parameters for Different Platforms

If you want to use a specific communication protocol supported by 4diac FORTE, for example MQTT, OPC UA, Modbus and so on, go this page:

Supported Communication Protocols

If you want to go back to see again the basic features, here's a link:

Step 5 - Other Basic Features

If you want to go back to the Start Here page, we leave you here a fast access:

Where to Start

Go to top