Skip to main content

tools for communicating with Bronkhorst MFCs with the API for BM31

Project description

repository for communicating with Bronkhorst MFCs remotely. Intended to be used with Pylatus or similar scripting environment. To install, clone the repository, then run 'pip install -e .' inside. This will create the bronkhorstServer program. Can also get from PyPi, 'pip install bronkhorstControlbm31'

Usage: On the PC connected to the MFCs run bronkhorstServer in a terminal. Options are -c/--com input the com number as an integer (default 1, but check com ports in Device Manager), this will save next time you run so you shouldn't need to input it again. -p/--port port number, (default is value in the script, probably unnecessary to change). A positional argument which can be 'local' or 'remote' (default local). If remote the hostname will be displayed to connect from another computer, otherwise it will be 'localhost'. The port number will also be displayed.

e.g.

bronkhorstServer remote -c 7

To send commands import the MFCclient class and connect function, then run it's methods. Initial arguments are MFC address (will be an integer), the IP address (default localhost) and the port (default is that in the script).

E.g.

from bronkhorstControlbm31.bronkhorstClient import MFCclient

MFCclient(3,'<hostname or ip address>').pollAll()

(this gives information about all MFCs that are connected in a dataframe, the MFC address isn't used and can be anything in this case).

To change setpoint on MFC address 3:

MFCclient(3,'<hostname or ip address>').writeSetpoint(value)

A second server is available for accepting multiple clients:

bronkhorstMultiServer remote

then for the client use multi=True:

MFCclient(3,'<hostname or ip address>', multi=True).pollAll()

There are also 2 other functions in bronkhorstClient called plotLoop() and timePlot() which can be run in conjunction with the bronkhorstMultiServer. Takes host as a required aguement.

I should mention this article https://realpython.com/python-sockets/ and the associated repository which helped me to make this.

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

bronkhorstcontrolbm31-1.1.0.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

bronkhorstControlbm31-1.1.0-py3-none-any.whl (8.2 kB view details)

Uploaded Python 3

File details

Details for the file bronkhorstcontrolbm31-1.1.0.tar.gz.

File metadata

  • Download URL: bronkhorstcontrolbm31-1.1.0.tar.gz
  • Upload date:
  • Size: 7.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for bronkhorstcontrolbm31-1.1.0.tar.gz
Algorithm Hash digest
SHA256 a48816ce9a60f33ef4a0dbefcd5fd22de439f158880d499e31869939e7fc8169
MD5 3d8542d3edfdbbe53b63ba9c849c4962
BLAKE2b-256 4e4d03c32611f335fffc5079bbdf472af36d1a1054a2a24ba576aca75887f215

See more details on using hashes here.

File details

Details for the file bronkhorstControlbm31-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for bronkhorstControlbm31-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bc275cb2ae9bfefcedb8b492131b21561fed05ac88f55daff0d573a8a0ed136a
MD5 26ca1ae2c9e7f4befbe5e167da19de8a
BLAKE2b-256 fe75736e916fc1c555e3141dff874123655b8eead9d2c27119a394924a642e0f

See more details on using hashes here.

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