Skip to main content

A collection of different scripts and drivers (PSU, EtherCAT, Labjack,...)

Project description

All modules to make successful and complete testing of SOMANET modules possible.

Even though this suite is written for Linux, at least the Elektronik Automation Power Supply Driver also runs under Windows.

Installation

  1. Install non-python tools (only Linux)

    sudo ./install.sh -a -m <MAC_OF_ETHERCAT_INTERFACE>

    This will install:
    • IgH EtherCAT Master

    • UDEV rules for power supplies

    • LabJack driver and Kipling

    • SOEM EtherCAT Master

    If one of these tools are already installed, the script will skip the installation and continue with the next tool. Call “-h” to show the help text.

  2. Install python script

    python setup.py install

Usage

1. PSU

Import module

import somanet_test_suite as sts

Create object

To connect to a specific PSU, you can call

Linux: psu = sts.PsuEA(comport='ttyACM0') or psu = sts.PsuEA(comport='usb-EA_Elektro-Automatik_PS_2042-10B_2815450332-if00')

Windows: psu = sts.PsuEA(comport='COM1') or as com port description: psu = sts.PsuEA(comport='PS 2000 B')

If you added the device rule and you connected only one PSU, there is no need to provide a device name:

psu = sts.PsuEA()

Also possible is:

psu = sts.PsuEA(comport='ea-ps-20xx-xx-0')

If there is more then one PSU connected to the host, the script will connect to the first device found.
It is also possible to take the S/N written on the back of the PSU and call:

psu = sts.PsuEA(sn='0123456789')

or to use the device designator:

psu = sts.PsuEA(desi='PS 2142-10B')

Dis/connect to power supply for controlling

psu.remote_on()

psu.remote_off()

For multi output devices most functions provide an additional output argument:

psu.remote_on(output_num=0)

psu.remote_on(output_num=1)

It’s only necessary to call remote_on(), when you want to control the PSU.
If you just want to read device information, you don’t need to.

Power on and off output

psu.output_on()

psu.output_off()

or

psu.output_on(output_num=1)

psu.output_off(output_num=1)

Set parameters

Arguments can be int or float.

psu.set_voltage(24, output_num=0)

psu.set_current(0.5, output_num=0)

psu.set_ovp(30, output_num=0)

psu.set_ocp(8, output_num=0)

The script will always set the maximum possible values in dependency of the nominal power.

For example:
Nominal power = 160 W
When you set the voltage to 40 V, it’s not possible to set a higher current than 4 A (=160W/40V),
regardless of the maximum current output of the device.
If you want to set a higher current, you must first reduce the voltage.
Also this script treats voltage with a higher priority.
It will decrease the current, if the maximum power is reached.
For example:
Nominal power = 160 W, set current = 10 A
When you set the voltage to 32 V, it’ll results in a maximum current of 5 A.

Get parameters

Return argument: float.

psu.get_voltage(output_num: int)

psu.get_current(output_num: int)

psu.get_power(output_num: int)

Maximum sampling rate is ~10 Hz.

Nominal values:

If update is true, the value will be pulled directly from the device.

psu.get_nominal_voltage(output_num: int, update: bool)

psu.get_nominal_current(output_num: int, update: bool)

psu.get_nominal_power(output_num: int, update: bool)

Reset error

If an overcurrent, overvoltage, overpower or overtemperature protection error happens, you can reset the error with:

psu.reset_error(output_num: int)

Tracking

(Only 3-port devices). Tracking disables the controlling of output 2. Output 1 controls then also output 2.

psu.tracking_on()

psu.tracking_off()

Get status

Return argument: dictionary

psu.get_status(update: bool)

List of dictionary containing the following keys (index is output number):

  • ‘output’ (int)

  • ‘remote on’ (bool)

  • ‘output on’ (bool)

  • ‘controller state’ (‘CV’, ‘CC’)

  • ‘tracking active’ (bool)

  • ‘OVP activ’ (bool)

  • ‘OCP activ’ (bool)

  • ‘OPP activ’ (bool)

  • ‘OTP activ’ (bool)

  • ‘act voltage’ (float)

  • ‘act current’ (float)

Get device description

Return argument: tuple (name, SN)

psu.get_device_description(update : bool)

Close connection

To close the connection, call:

psu.close()

This will just stop the communication, the PSU outputs will remain in their current states.

2. SANSSOUCI - So(manet) Se(nsor) Si(mulator)

A framework to simulate different sensors (Hall, QEI, …). Currently only velocity is supported for Hall and QEI.

Preperation

What you need:
  • LabJack

  • SN75174 Differential Line Driver (for RS-422 communication and as level shifter 3.3V -> 5V)

Connection

See also: https://doc.synapticon.com/hardware/drive/drive_1000/d3/docs/index.html#encoder-port-1

Pin SN75174

Encoder/Labjack

1

LJ: FIO0

2

A+

3

A-

4

Connect with 10kOhm to Vcc or NC

5

B-

6

B+

7

LJ: FIO01

8

GND of LJ and Encoder

9

LJ: FIO2

10

I+

11

I-

12

Connect with 10kOhm to Vcc or NC

13

N.C.

14

N.C.

15

N.C.

16

Vcc (5V)

Usage

Hall

sensor = Sanssouci(printer.write, 'HALL', pole_pairs=7)

sensor.set_velocity(20)

QEI

sensor = Sanssouci(printer.write, 'QEI', resolution=100)

sensor.set_velocity(20)

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

somanet_test_suite-1.1.3.tar.gz (59.2 kB view hashes)

Uploaded Source

Built Distribution

somanet_test_suite-1.1.3-py3-none-any.whl (64.1 kB view hashes)

Uploaded Python 3

Supported by

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