Skip to main content

A library to communicate with Omron Sysmac Simulator

Project description

Omron Sysmac Simulator Driver

This project is a Python library that enables communication with the Sysmac Studio simulator using the NexSocket.dll installed with the Omron IDE. It can be used to exercise and unit test PLC projects in the simulator without the need to connect actual hardware. The main methods are similar to the APHYT Ethernet/IP project used for real Sysmac hardware on the network, so code can be reused to test both simulated and real systems. There are some limitations on simulated systems because the NexSocket.dll does not provide as much data as Ethernet/IP.

This code modifies and expands a GPL3 module released by Simumatik Digital Twin platform and the modifications:

  • Allow it to be used as a stand-alone Python interface to the Simulator
  • Variables can be assigned PLC data types in order to implicitly format the bytes during read and write operations
  • Can import a text file created by pasting the results of Sysmac Studio's "Export Global Variables" in order to define the data types of PLC variables automatically

Creating an Import File of Published Global Variables

Begin by exporting a formatted list of published global variables by navigating Sysmac Studio's menu structure to: Tools - Export Global Variables - CX-Designer

Export Global Variables Dialog

This should result in a dialog that alerts the user that the data has been copied to the clipboard

Pop Up From Export Global Variables Tool

Paste the results into a text file and save it in a location accessible to the Python code. The result should look something like this below:

Screen Cap of Global Variables Text File

The file "global_variables.txt", created using this process, is used in the example code below.

Example

The following code will connect to the running simulator

from omron_sysmac_simulator import *
import time

sim_driver = SysmacSimulator()
sim_driver.connect()
sim_driver.populate_from_file('global_variables.txt')

var_name = "hmiPositionTarget"
for i in range(5):
    print(sim_driver.read_variable(var_name))
    time.sleep(1)
    sim_driver.write_variable(var_name, 12.34)
    print(sim_driver.read_variable(var_name))
    time.sleep(1)
    sim_driver.write_variable(var_name, 0.0)

sim_driver.disconnect()

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

omron_sysmac_simulator-0.1.4.tar.gz (16.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

omron_sysmac_simulator-0.1.4-py3-none-any.whl (19.6 kB view details)

Uploaded Python 3

File details

Details for the file omron_sysmac_simulator-0.1.4.tar.gz.

File metadata

  • Download URL: omron_sysmac_simulator-0.1.4.tar.gz
  • Upload date:
  • Size: 16.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.11

File hashes

Hashes for omron_sysmac_simulator-0.1.4.tar.gz
Algorithm Hash digest
SHA256 7137bc6f59f470fb2260d5009bee356bdf52e572d5a31d571587f8258b2436a3
MD5 76166f3c4b6ac1da7a829f7b807699e9
BLAKE2b-256 72fe8c8c536d1f9d66682b1f1bd2d4be364a8733cec4cf8f991bec9b03ea75a1

See more details on using hashes here.

File details

Details for the file omron_sysmac_simulator-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for omron_sysmac_simulator-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a1d419eebdd03225711aef93a6e94c6c93003fb31d855cd0b2c186067791715c
MD5 e1855eef3fa7bc8d8903a645fee899ec
BLAKE2b-256 1bc5f28dde4be27313e2ba39bb5d443a566b2cc774e06c0e6891459e850c6776

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page