Documentation Home Page RT-LAB Home Page
Pour la documentation en FRANÇAIS, utilisez l'outil de traduction de votre navigateur Chrome, Edge ou Safari. Voir un exemple.

New I/O Interfaces

Page Content

What are the advantages?

The new I/O interfaces allows enabling the visualisation and editing of IO connections within the new UI, offering improved scalability, performance, and an enhanced user experience.

How to update old projects to new I/O interfaces

Starting from RT-LAB 2025.1, the migration is carried automatically when a project is opened.

  1. Using your older RT-LAB version (2024.4 or older), make sure all models in the project are in a compiled/loadable state. If not, launch compilation and wait for its completion.

Compiling the model is essential to ensure that all information required for automatic migration is available within the workspace. This step is very important.

  1. Close the older RT-LAB version and start using the newer RT-LAB version.

  2. Open your Workspace

  3. Open your project

  4. Follow the migration wizard instructions

    image-20241217-224246.png
    image-20241217-224332.png


    Don’t worry, your project will be backed up in case you want to use with older RT-LAB versions

  5. Your project now can be used with the new I/O Interfaces!

Migrated project into Dashboards

Dashboards can be opened by clicking on “Dashboards” in the RT-LAB Project Explorer.

For more information on how to configure connections of I/O Interfaces in Dashboards, please refer to the following documentation:

Considerations

Once the project has been migrated to Dashboards,

  • Functionality of the Recorder remains the same.

  • Dynamic LabVIEW panels are still available for consultation, but do not interact with the simulation anymore. The Dashboards panels are now to be used instead of LabVIEW panels.

  • Configuration view of IO Interfaces remains in RT-LAB.

  • Aliases are no more supported.

  • All RT-LAB API calls remain compatible.

    • GetConnectionsDescription return may differ

      • For IO data points:

        • Field name is no longer present.

        • Field alias has been added, it is the IO data point UI name.

      • For model data points:

        • Field level, alias and name are no more present.

  • Connections configuration:

    • Can be done via Dashboards

    • Is no longer accessible via the Configuration panel of RT-LAB.

Migration failure

If the project migration fails, please read the <Project Path>/configurations/opalone/migration_report.log file and refer to the Known issues section.

If the issue persist please contact OPAL-RT support and provide the full project in a zip file or the following files

  1. The folder located at <Project Path>/configurations

  2. The file located at <Project Path>/Controller.log

  3. Opal Ones log files at C:/OPAL-RT/OpalOne/services/appserver/logs/appserver.log and C:/OPAL_RT/OpalOne/vX.Y.Z/server/logs/unicon.prod*.text.log

Migration report

The migration_report.log (under <Project Path>/configurations/opalone) should be generated no matter the migration failed or not.
If it’s not the case, it could be because the Controller.exe of the project was not properly closed before starting migration or if unicon.exe is not running.

A migration report should content :

  • Information about IO Interfaces

MIG #### Start migration of IO interfaces #### MIG -- Start IO synchronization -- MIG IO Interface: Name: DNP3 Slave, Metadata: map[guid:D9F9CC87-4BDE-49F4-AA23-E8FA9636956E type:DNP3Slave]
  • Information about IO datapoints

MIG -- Synchronization of IO datapoints -- MIG Insert IO signal path=DNP3 Slave/Slaves/9FE36F43-E67A-407E-B047-38AD06272490/Analog inputs/656B6654-805D-478D-B74C-84C3B1CF553F name=Analog input 0 MIG Insert IO signal path=DNP3 Slave/Slaves/9FE36F43-E67A-407E-B047-38AD06272490/Analog inputs/FD876C62-3F56-41A7-9BFE-9EA57E5F551E name=Analog input 1 ... MIG New entries in database : 8 levels, 5 blocks, 0 parameters and 10 signals MIG -- End synchronization of IO datapoints --
  • Information about connections between IO Interfaces and models

MIG -- Synchronisation of connections -- MIG 10 connections found. MIG Connection between 'DNP3_Slave/sm_dnp3_slave/Analog_to_master/OpOutput/port1' and 'DNP3 Slave/Slaves/9FE36F43-E67A-407E-B047-38AD06272490/Analog inputs/656B6654-805D-478D-B74C-84C3B1CF553F' MIG Connection between 'DNP3_Slave/sm_dnp3_slave/Analog_from_master/In1/Value' and 'DNP3 Slave/Slaves/9FE36F43-E67A-407E-B047-38AD06272490/Analog outputs/8E8AEAA4-8ED8-4F16-87B3-8AA56D609090' ... MIG 10 connections to insert in database INF IO DNP3 Slave assigned to DNP3 Slave/sm_dnp3_slave MIG -- End synchronisation of connections --
  • Any error reported stop the migration process. It may be related to one of the previous sections, ie.

error on IO interface synchronization:

error on connections:

Known issues

Use of new I/O interfaces not possible because of unresolved connections

If in a project there are unresolved connections, the migration cannot be done.

Unresolved connections can be seen in the Configuration panel of RT-LAB when the top-level connection count is inconsistent with the sum of the connections present at the data point level. The following image illustrates what unresolved connections may look like.

Contrastingly, in the next image, all connections are resolved.

In the migration report, you will find datapoints of connections which cannot be resolved.

In case of DNP3 Slave the best things to do is

  1. Export connections by using RT-LAB API

  1. Separate exported files in 2 files

    1. One for DNP3 Slave connections

    2. One for the other connections

  1. Remove all existing connections in the Project

  1. Import files containing all connections except the one related to DNP3 Slave

If you have LabVIEW panels please, open them before doing those steps.

  1. Update and import DNP3 Slave connections

Path has change from ‘DNP3 Slave/Analog inputs/Analog input 0’ to 'DNP3 Slave/Slaves/Slave_1/Analog inputs/Analog input 0'

Update all path and use CreateConnection RtlabApi call to create connections with new path

Example:

  • Content of connections_dnp3_slave_connections.csv

  • New files generated dnp3_connections_path_updated.csv

Take 3rd column (Datapoint 1: Secondary ID)

Take 5th column (Datapoint 2: Primary ID)

Add in the column containing path of IOs Slaves/Slave_1 if your data points are related to Slave_1 of DNP3 Slave configurations

  • Create new connections

From python command line in RT-LAB

 

 

 

OPAL-RT TECHNOLOGIES, Inc. | 1751, rue Richardson, bureau 1060 | Montréal, Québec Canada H3K 1G6 | opal-rt.com | +1 514-935-2323
Follow OPAL-RT: LinkedIn | Facebook | YouTube | X/Twitter